forked from filipg/gonito
does not check for correctness of Git URLs
(URL copied&pasted from, for instance, GitLab does not have the protocol anyway.)
This commit is contained in:
parent
0b1263af27
commit
1262cc7cb8
@ -103,12 +103,6 @@ runViewProgress' route action = do
|
|||||||
writeTVar jobs $ IntMap.delete jobId m
|
writeTVar jobs $ IntMap.delete jobId m
|
||||||
redirect $ route jobId
|
redirect $ route jobId
|
||||||
|
|
||||||
validGitProtocols :: [String]
|
|
||||||
validGitProtocols = ["git", "http", "https", "ssh"]
|
|
||||||
|
|
||||||
validGitProtocolsAsText :: Text
|
|
||||||
validGitProtocolsAsText = T.pack $ intercalate ", " $ map (++"://") validGitProtocols
|
|
||||||
|
|
||||||
data RepoCloningSpec = RepoCloningSpec {
|
data RepoCloningSpec = RepoCloningSpec {
|
||||||
cloningSpecRepo :: RepoSpec,
|
cloningSpecRepo :: RepoSpec,
|
||||||
cloningSpecReferenceRepo :: RepoSpec
|
cloningSpecReferenceRepo :: RepoSpec
|
||||||
@ -180,14 +174,12 @@ cloneRepo' :: RepoCloningSpec -> Channel -> Handler (Maybe (Key Repo))
|
|||||||
cloneRepo' repoCloningSpec chan = do
|
cloneRepo' repoCloningSpec chan = do
|
||||||
let url = repoSpecUrl $ cloningSpecRepo repoCloningSpec
|
let url = repoSpecUrl $ cloningSpecRepo repoCloningSpec
|
||||||
msg chan $ concat ["Preparing to clone repo ", url]
|
msg chan $ concat ["Preparing to clone repo ", url]
|
||||||
if checkRepoUrl url
|
msg chan "Cloning..."
|
||||||
then do
|
r <- randomInt
|
||||||
msg chan "Cloning..."
|
arenaDir <- arena
|
||||||
r <- randomInt
|
let tmpRepoDir = arenaDir </> ("t" ++ show r)
|
||||||
arenaDir <- arena
|
exitCode <- rawClone tmpRepoDir repoCloningSpec chan
|
||||||
let tmpRepoDir = arenaDir </> ("t" ++ show r)
|
case exitCode of
|
||||||
exitCode <- rawClone tmpRepoDir repoCloningSpec chan
|
|
||||||
case exitCode of
|
|
||||||
ExitSuccess -> do
|
ExitSuccess -> do
|
||||||
maybeHeadCommit <- getHeadCommit tmpRepoDir chan
|
maybeHeadCommit <- getHeadCommit tmpRepoDir chan
|
||||||
case maybeHeadCommit of
|
case maybeHeadCommit of
|
||||||
@ -211,9 +203,6 @@ cloneRepo' repoCloningSpec chan = do
|
|||||||
ExitFailure _ -> do
|
ExitFailure _ -> do
|
||||||
err chan "git failed"
|
err chan "git failed"
|
||||||
return Nothing
|
return Nothing
|
||||||
else do
|
|
||||||
err chan $ concat ["Wrong URL to a Git repo (note that one of the following protocols must be specified: ", validGitProtocolsAsText]
|
|
||||||
return Nothing
|
|
||||||
|
|
||||||
rawClone :: FilePath -> RepoCloningSpec -> Channel -> Handler ExitCode
|
rawClone :: FilePath -> RepoCloningSpec -> Channel -> Handler ExitCode
|
||||||
rawClone tmpRepoDir repoCloningSpec chan = runWithChannel chan $ do
|
rawClone tmpRepoDir repoCloningSpec chan = runWithChannel chan $ do
|
||||||
@ -261,12 +250,6 @@ getRepoDir repoId = do
|
|||||||
return $ arenaDir </> ("r" ++ repoIdAsString)
|
return $ arenaDir </> ("r" ++ repoIdAsString)
|
||||||
where repoIdAsString = show $ fromSqlKey repoId
|
where repoIdAsString = show $ fromSqlKey repoId
|
||||||
|
|
||||||
checkRepoUrl :: Text -> Bool
|
|
||||||
checkRepoUrl url = case parsedURI of
|
|
||||||
Just uri -> (uriScheme uri) `elem` (map (++":") validGitProtocols)
|
|
||||||
Nothing -> False
|
|
||||||
where parsedURI = parseURI $ T.unpack url
|
|
||||||
|
|
||||||
getOpenViewProgressR :: Int -> Handler TypedContent
|
getOpenViewProgressR :: Int -> Handler TypedContent
|
||||||
getOpenViewProgressR = getViewProgressR
|
getOpenViewProgressR = getViewProgressR
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user