add "make it public" feature
This commit is contained in:
parent
cf55550453
commit
923b1fe8f0
@ -41,6 +41,7 @@ import Handler.Graph
|
||||
import Handler.Home
|
||||
import Handler.CreateChallenge
|
||||
import Handler.ListChallenges
|
||||
import Handler.MakePublic
|
||||
import Handler.Query
|
||||
import Handler.ShowChallenge
|
||||
import Handler.Shared
|
||||
|
50
Handler/MakePublic.hs
Normal file
50
Handler/MakePublic.hs
Normal file
@ -0,0 +1,50 @@
|
||||
module Handler.MakePublic where
|
||||
|
||||
import Import
|
||||
|
||||
import Handler.Shared
|
||||
|
||||
import PersistSHA1
|
||||
|
||||
import Text.Printf
|
||||
import Database.Persist.Sql
|
||||
|
||||
import Data.Text as T
|
||||
|
||||
getMakePublicR :: SubmissionId -> Handler TypedContent
|
||||
getMakePublicR submissionId = runViewProgress $ doMakePublic submissionId
|
||||
|
||||
doMakePublic :: SubmissionId -> Channel -> Handler ()
|
||||
doMakePublic submissionId chan = do
|
||||
isOwner <- checkWhetherUserRepo submissionId
|
||||
if not isOwner
|
||||
then
|
||||
err chan "Only the submitter can make a submission public!"
|
||||
else do
|
||||
msg chan "Making the submission public..."
|
||||
runDB $ update submissionId [SubmissionIsPublic =. True]
|
||||
let targetBranchName = printf "submission-%05d" $ fromSqlKey submissionId
|
||||
submission <- runDB $ get404 submissionId
|
||||
challenge <- runDB $ get404 $ submissionChallenge submission
|
||||
let submissionRepoId = submissionRepo submission
|
||||
submissionRepoDir <- getRepoDir submissionRepoId
|
||||
let targetRepoUrl = T.unpack $ gitServer ++ challengeName challenge
|
||||
msg chan $ T.pack $ "Start pushing from " ++ submissionRepoDir ++ " to repo " ++ targetRepoUrl ++ ", branch " ++ targetBranchName ++ " ..."
|
||||
let commit = submissionCommit submission
|
||||
pushRepo submissionRepoDir commit targetRepoUrl targetBranchName chan
|
||||
return ()
|
||||
|
||||
|
||||
pushRepo :: String -> SHA1 -> String -> String -> Channel -> Handler ()
|
||||
pushRepo repoDir commit targetRepoUrl targetBranchName chan = do
|
||||
(exitCode, _) <- runProgram (Just repoDir) gitPath [
|
||||
"push",
|
||||
targetRepoUrl,
|
||||
(T.unpack $ fromSHA1ToText commit) ++ ":refs/heads/" ++ targetBranchName] chan
|
||||
return ()
|
||||
|
||||
checkWhetherUserRepo :: SubmissionId -> Handler Bool
|
||||
checkWhetherUserRepo submissionId = do
|
||||
submission <- runDB $ get404 submissionId
|
||||
userId <- requireAuthId
|
||||
return $ userId == submissionSubmitter submission
|
@ -42,6 +42,9 @@ gitPath = "/usr/bin/git"
|
||||
browsableGitSite :: Text
|
||||
browsableGitSite = "http://gonito.net/gitlist/"
|
||||
|
||||
gitServer :: Text
|
||||
gitServer = "ssh://gitolite@gonito.net/"
|
||||
|
||||
browsableGitRepo :: Text -> Text
|
||||
browsableGitRepo bareRepoName
|
||||
| ".git" `isSuffixOf` bareRepoName = browsableGitSite ++ bareRepoName
|
||||
|
@ -22,5 +22,6 @@
|
||||
/q QueryFormR GET POST
|
||||
/q/#Text QueryResultsR GET
|
||||
|
||||
/make-public/#SubmissionId MakePublicR GET
|
||||
|
||||
/account YourAccountR GET POST
|
||||
|
@ -35,6 +35,7 @@ library
|
||||
Handler.Graph
|
||||
Handler.Home
|
||||
Handler.ListChallenges
|
||||
Handler.MakePublic
|
||||
Handler.Shared
|
||||
Handler.ShowChallenge
|
||||
Handler.Extract
|
||||
|
Loading…
Reference in New Issue
Block a user