2016-02-18 06:53:53 +09:00
|
|
|
{- This file is part of Vervis.
|
|
|
|
-
|
|
|
|
- Written in 2016 by fr33domlover <fr33domlover@riseup.net>.
|
|
|
|
-
|
|
|
|
- ♡ Copying is an act of love. Please copy, reuse and share.
|
|
|
|
-
|
|
|
|
- The author(s) have dedicated all copyright and related and neighboring
|
|
|
|
- rights to this software to the public domain worldwide. This software is
|
|
|
|
- distributed without any warranty.
|
|
|
|
-
|
|
|
|
- You should have received a copy of the CC0 Public Domain Dedication along
|
|
|
|
- with this software. If not, see
|
|
|
|
- <http://creativecommons.org/publicdomain/zero/1.0/>.
|
|
|
|
-}
|
|
|
|
|
2016-02-23 17:45:03 +09:00
|
|
|
module Vervis.Handler.Project
|
2016-02-18 06:53:53 +09:00
|
|
|
( getProjectsR
|
2016-02-25 12:10:30 +09:00
|
|
|
, postProjectsR
|
|
|
|
, getProjectNewR
|
2016-02-18 06:53:53 +09:00
|
|
|
, getProjectR
|
2016-06-05 19:43:28 +09:00
|
|
|
, putProjectR
|
|
|
|
, postProjectR
|
|
|
|
, getProjectEditR
|
2016-06-01 17:52:14 +09:00
|
|
|
, getProjectDevsR
|
|
|
|
, postProjectDevsR
|
|
|
|
, getProjectDevNewR
|
|
|
|
, getProjectDevR
|
|
|
|
, deleteProjectDevR
|
|
|
|
, postProjectDevR
|
2016-02-18 06:53:53 +09:00
|
|
|
)
|
|
|
|
where
|
|
|
|
|
2016-05-14 20:36:45 +09:00
|
|
|
import Prelude
|
|
|
|
|
|
|
|
import Data.Maybe (fromMaybe)
|
|
|
|
import Data.Text (Text)
|
|
|
|
import Database.Persist
|
2016-06-01 17:52:14 +09:00
|
|
|
import Database.Esqueleto hiding (delete, (%), (==.))
|
2016-05-14 20:36:45 +09:00
|
|
|
import Text.Blaze.Html (Html)
|
2016-06-06 15:48:59 +09:00
|
|
|
import Yesod.Auth (requireAuthId)
|
2016-05-14 20:36:45 +09:00
|
|
|
import Yesod.Core (defaultLayout)
|
2016-06-01 17:52:14 +09:00
|
|
|
import Yesod.Core.Handler (redirect, setMessage, lookupPostParam, notFound)
|
2016-05-14 20:36:45 +09:00
|
|
|
import Yesod.Form.Functions (runFormPost)
|
|
|
|
import Yesod.Form.Types (FormResult (..))
|
|
|
|
import Yesod.Persist.Core (runDB, getBy404)
|
|
|
|
|
|
|
|
import qualified Database.Esqueleto as E
|
2016-02-18 06:53:53 +09:00
|
|
|
|
2016-02-25 12:10:30 +09:00
|
|
|
import Vervis.Form.Project
|
2016-05-14 20:36:45 +09:00
|
|
|
import Vervis.Foundation
|
|
|
|
import Vervis.Model
|
2016-05-24 05:46:54 +09:00
|
|
|
import Vervis.Model.Ident
|
2016-05-14 20:36:45 +09:00
|
|
|
import Vervis.Model.Repo
|
|
|
|
import Vervis.Settings
|
2016-06-01 17:52:14 +09:00
|
|
|
import Vervis.Widget.Sharer
|
2016-02-18 06:53:53 +09:00
|
|
|
|
2016-05-23 21:24:14 +09:00
|
|
|
getProjectsR :: ShrIdent -> Handler Html
|
2016-02-18 06:53:53 +09:00
|
|
|
getProjectsR ident = do
|
2016-06-01 17:52:14 +09:00
|
|
|
projects <- runDB $ select $ from $ \ (sharer, project) -> do
|
|
|
|
where_ $
|
|
|
|
sharer ^. SharerIdent E.==. val ident &&.
|
|
|
|
sharer ^. SharerId E.==. project ^. ProjectSharer
|
|
|
|
orderBy [asc $ project ^. ProjectIdent]
|
|
|
|
return $ project ^. ProjectIdent
|
2016-05-14 07:11:46 +09:00
|
|
|
defaultLayout $(widgetFile "project/list")
|
2016-02-18 06:53:53 +09:00
|
|
|
|
2016-05-23 21:24:14 +09:00
|
|
|
postProjectsR :: ShrIdent -> Handler Html
|
2016-06-06 15:48:59 +09:00
|
|
|
postProjectsR shr = do
|
|
|
|
pid <- requireAuthId
|
|
|
|
Entity sid _ <- runDB $ getBy404 $ UniqueSharer shr
|
|
|
|
((result, widget), enctype) <- runFormPost $ newProjectForm pid sid
|
2016-02-25 12:10:30 +09:00
|
|
|
case result of
|
2016-06-06 15:48:59 +09:00
|
|
|
FormSuccess np -> do
|
|
|
|
runDB $ do
|
|
|
|
let project = Project
|
|
|
|
{ projectIdent = npIdent np
|
|
|
|
, projectSharer = sid
|
|
|
|
, projectName = npName np
|
|
|
|
, projectDesc = npDesc np
|
|
|
|
, projectNextTicket = 1
|
|
|
|
, projectWiki = Nothing
|
|
|
|
}
|
|
|
|
jid <- insert project
|
|
|
|
let collab = ProjectCollab
|
|
|
|
{ projectCollabProject = jid
|
|
|
|
, projectCollabPerson = pid
|
|
|
|
, projectCollabRole = npRole np
|
|
|
|
}
|
|
|
|
insert_ collab
|
2016-02-25 12:10:30 +09:00
|
|
|
setMessage "Project added."
|
2016-06-06 15:48:59 +09:00
|
|
|
redirect $ ProjectR shr (npIdent np)
|
2016-02-25 12:10:30 +09:00
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing"
|
2016-05-14 07:11:46 +09:00
|
|
|
defaultLayout $(widgetFile "project/new")
|
2016-05-14 07:07:56 +09:00
|
|
|
FormFailure _l -> do
|
2016-05-14 07:06:23 +09:00
|
|
|
setMessage "Project creation failed, see below"
|
2016-05-14 07:11:46 +09:00
|
|
|
defaultLayout $(widgetFile "project/new")
|
2016-02-25 12:10:30 +09:00
|
|
|
|
2016-05-23 21:24:14 +09:00
|
|
|
getProjectNewR :: ShrIdent -> Handler Html
|
2016-06-06 15:48:59 +09:00
|
|
|
getProjectNewR shr = do
|
|
|
|
pid <- requireAuthId
|
|
|
|
Entity sid _ <- runDB $ getBy404 $ UniqueSharer shr
|
|
|
|
((_result, widget), enctype) <- runFormPost $ newProjectForm pid sid
|
2016-05-14 07:11:46 +09:00
|
|
|
defaultLayout $(widgetFile "project/new")
|
2016-02-25 12:10:30 +09:00
|
|
|
|
2016-05-23 21:24:14 +09:00
|
|
|
getProjectR :: ShrIdent -> PrjIdent -> Handler Html
|
2016-05-14 20:36:45 +09:00
|
|
|
getProjectR shar proj = do
|
|
|
|
(project, repos) <- runDB $ do
|
2016-05-24 05:46:54 +09:00
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shar
|
2016-05-14 20:36:45 +09:00
|
|
|
Entity pid p <- getBy404 $ UniqueProject proj sid
|
|
|
|
rs <- selectList [RepoProject ==. Just pid] [Asc RepoIdent]
|
|
|
|
return (p, rs)
|
2016-05-14 07:11:46 +09:00
|
|
|
defaultLayout $(widgetFile "project/one")
|
2016-06-01 17:52:14 +09:00
|
|
|
|
2016-06-05 19:43:28 +09:00
|
|
|
putProjectR :: ShrIdent -> PrjIdent -> Handler Html
|
|
|
|
putProjectR shr prj = do
|
|
|
|
ep@(Entity jid project) <- runDB $ do
|
|
|
|
Entity sid _sharer <- getBy404 $ UniqueSharer shr
|
|
|
|
getBy404 $ UniqueProject prj sid
|
|
|
|
((result, widget), enctype) <- runFormPost $ editProjectForm ep
|
|
|
|
case result of
|
|
|
|
FormSuccess project' -> do
|
|
|
|
runDB $ replace jid project'
|
|
|
|
setMessage "Project updated."
|
|
|
|
redirect $ ProjectR shr prj
|
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing."
|
|
|
|
defaultLayout $(widgetFile "project/edit")
|
|
|
|
FormFailure _l -> do
|
|
|
|
setMessage "Project update failed, see errors below."
|
|
|
|
defaultLayout $(widgetFile "project/edit")
|
|
|
|
|
|
|
|
postProjectR :: ShrIdent -> PrjIdent -> Handler Html
|
|
|
|
postProjectR shr prj = do
|
|
|
|
mmethod <- lookupPostParam "_method"
|
|
|
|
case mmethod of
|
|
|
|
Just "PUT" -> putProjectR shr prj
|
|
|
|
_ -> notFound
|
|
|
|
|
|
|
|
getProjectEditR :: ShrIdent -> PrjIdent -> Handler Html
|
|
|
|
getProjectEditR shr prj = do
|
|
|
|
ep <- runDB $ do
|
|
|
|
Entity sid _sharer <- getBy404 $ UniqueSharer shr
|
|
|
|
getBy404 $ UniqueProject prj sid
|
|
|
|
((_result, widget), enctype) <- runFormPost $ editProjectForm ep
|
|
|
|
defaultLayout $(widgetFile "project/edit")
|
|
|
|
|
2016-06-01 17:52:14 +09:00
|
|
|
getProjectDevsR :: ShrIdent -> PrjIdent -> Handler Html
|
|
|
|
getProjectDevsR shr rp = do
|
|
|
|
devs <- runDB $ do
|
|
|
|
rid <- do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer shr
|
|
|
|
Entity r _ <- getBy404 $ UniqueProject rp s
|
|
|
|
return r
|
|
|
|
select $ from $ \ (collab, person, sharer, role) -> do
|
|
|
|
where_ $
|
|
|
|
collab ^. ProjectCollabProject E.==. val rid &&.
|
|
|
|
collab ^. ProjectCollabPerson E.==. person ^. PersonId &&.
|
|
|
|
person ^. PersonIdent E.==. sharer ^. SharerId &&.
|
|
|
|
collab ^. ProjectCollabRole E.==. role ^. ProjectRoleId
|
|
|
|
return (sharer, role ^. ProjectRoleIdent)
|
|
|
|
defaultLayout $(widgetFile "project/collab/list")
|
|
|
|
|
|
|
|
postProjectDevsR :: ShrIdent -> PrjIdent -> Handler Html
|
|
|
|
postProjectDevsR shr rp = do
|
|
|
|
(pid, rid) <- runDB $ do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer shr
|
|
|
|
Entity p _ <- getBy404 $ UniquePersonIdent s
|
|
|
|
Entity r _ <- getBy404 $ UniqueProject rp s
|
|
|
|
return (p, r)
|
|
|
|
((result, widget), enctype) <- runFormPost $ newProjectCollabForm pid rid
|
|
|
|
case result of
|
|
|
|
FormSuccess nc -> do
|
|
|
|
runDB $ do
|
|
|
|
let collab = ProjectCollab
|
|
|
|
{ projectCollabProject = rid
|
|
|
|
, projectCollabPerson = ncPerson nc
|
|
|
|
, projectCollabRole = ncRole nc
|
|
|
|
}
|
|
|
|
insert_ collab
|
|
|
|
setMessage "Collaborator added."
|
|
|
|
redirect $ ProjectDevsR shr rp
|
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing"
|
|
|
|
defaultLayout $(widgetFile "project/collab/new")
|
|
|
|
FormFailure _l -> do
|
|
|
|
setMessage "Operation failed, see errors below"
|
|
|
|
defaultLayout $(widgetFile "project/collab/new")
|
|
|
|
|
|
|
|
getProjectDevNewR :: ShrIdent -> PrjIdent -> Handler Html
|
|
|
|
getProjectDevNewR shr rp = do
|
|
|
|
(pid, rid) <- runDB $ do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer shr
|
|
|
|
Entity p _ <- getBy404 $ UniquePersonIdent s
|
|
|
|
Entity r _ <- getBy404 $ UniqueProject rp s
|
|
|
|
return (p, r)
|
|
|
|
((_result, widget), enctype) <- runFormPost $ newProjectCollabForm pid rid
|
|
|
|
defaultLayout $(widgetFile "project/collab/new")
|
|
|
|
|
|
|
|
getProjectDevR :: ShrIdent -> PrjIdent -> ShrIdent -> Handler Html
|
|
|
|
getProjectDevR shr rp dev = do
|
|
|
|
rl <- runDB $ do
|
|
|
|
rid <- do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer shr
|
|
|
|
Entity r _ <- getBy404 $ UniqueProject rp s
|
|
|
|
return r
|
|
|
|
pid <- do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer dev
|
|
|
|
Entity p _ <- getBy404 $ UniquePersonIdent s
|
|
|
|
return p
|
|
|
|
Entity _cid collab <- getBy404 $ UniqueProjectCollab rid pid
|
|
|
|
role <- getJust $ projectCollabRole collab
|
|
|
|
return $ projectRoleIdent role
|
|
|
|
defaultLayout $(widgetFile "project/collab/one")
|
|
|
|
|
|
|
|
deleteProjectDevR :: ShrIdent -> PrjIdent -> ShrIdent -> Handler Html
|
|
|
|
deleteProjectDevR shr rp dev = do
|
|
|
|
runDB $ do
|
|
|
|
rid <- do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer shr
|
|
|
|
Entity r _ <- getBy404 $ UniqueProject rp s
|
|
|
|
return r
|
|
|
|
pid <- do
|
|
|
|
Entity s _ <- getBy404 $ UniqueSharer dev
|
|
|
|
Entity p _ <- getBy404 $ UniquePersonIdent s
|
|
|
|
return p
|
|
|
|
Entity cid _collab <- getBy404 $ UniqueProjectCollab rid pid
|
|
|
|
delete cid
|
|
|
|
setMessage "Collaborator removed."
|
|
|
|
redirect $ ProjectDevsR shr rp
|
|
|
|
|
|
|
|
postProjectDevR :: ShrIdent -> PrjIdent -> ShrIdent -> Handler Html
|
|
|
|
postProjectDevR shr rp dev = do
|
|
|
|
mmethod <- lookupPostParam "_method"
|
|
|
|
case mmethod of
|
|
|
|
Just "DELETE" -> deleteProjectDevR shr rp dev
|
|
|
|
_ -> notFound
|