2016-05-29 22:17:55 +09:00
|
|
|
{- This file is part of Vervis.
|
|
|
|
-
|
2018-07-11 17:15:19 +09:00
|
|
|
- Written in 2016, 2018 by fr33domlover <fr33domlover@riseup.net>.
|
2016-05-29 22:17:55 +09:00
|
|
|
-
|
|
|
|
- ♡ 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/>.
|
|
|
|
-}
|
|
|
|
|
|
|
|
module Vervis.Handler.Role
|
2016-06-01 16:35:22 +09:00
|
|
|
( getRepoRolesR
|
|
|
|
, postRepoRolesR
|
|
|
|
, getRepoRoleNewR
|
|
|
|
, getRepoRoleR
|
|
|
|
, deleteRepoRoleR
|
|
|
|
, postRepoRoleR
|
|
|
|
, getRepoRoleOpsR
|
|
|
|
, postRepoRoleOpsR
|
|
|
|
, getRepoRoleOpNewR
|
2016-06-01 17:52:14 +09:00
|
|
|
, getProjectRolesR
|
|
|
|
, postProjectRolesR
|
|
|
|
, getProjectRoleNewR
|
|
|
|
, getProjectRoleR
|
|
|
|
, deleteProjectRoleR
|
|
|
|
, postProjectRoleR
|
|
|
|
, getProjectRoleOpsR
|
|
|
|
, postProjectRoleOpsR
|
|
|
|
, getProjectRoleOpNewR
|
2016-05-29 22:17:55 +09:00
|
|
|
)
|
|
|
|
where
|
|
|
|
|
|
|
|
import Prelude
|
|
|
|
|
|
|
|
import Database.Persist
|
2018-07-11 17:15:19 +09:00
|
|
|
import Network.HTTP.Types (StdMethod (DELETE))
|
2016-05-29 22:17:55 +09:00
|
|
|
import Text.Blaze.Html (Html)
|
|
|
|
import Yesod.Auth (requireAuthId)
|
|
|
|
import Yesod.Core (defaultLayout, setMessage)
|
|
|
|
import Yesod.Core.Handler (lookupPostParam, notFound, redirect)
|
|
|
|
import Yesod.Form.Functions (runFormPost)
|
|
|
|
import Yesod.Form.Types (FormResult (..))
|
|
|
|
import Yesod.Persist.Core (runDB, getBy404)
|
|
|
|
|
|
|
|
import Vervis.Form.Role
|
|
|
|
import Vervis.Foundation
|
|
|
|
import Vervis.Model
|
2016-06-07 04:41:22 +09:00
|
|
|
import Vervis.Model.Ident (ShrIdent, RlIdent, rl2text)
|
2016-07-02 18:45:29 +09:00
|
|
|
import Vervis.Role
|
2016-05-29 22:17:55 +09:00
|
|
|
import Vervis.Settings (widgetFile)
|
2018-07-11 17:15:19 +09:00
|
|
|
import Vervis.Widget (buttonW)
|
2016-07-02 18:45:29 +09:00
|
|
|
import Vervis.Widget.Role
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getRepoRolesR :: ShrIdent -> Handler Html
|
|
|
|
getRepoRolesR shr = do
|
2016-07-02 18:57:52 +09:00
|
|
|
--roles <- runDB $ do
|
|
|
|
-- Entity sid _ <- getBy404 $ UniqueSharer shr
|
|
|
|
-- selectList [RepoRoleSharer ==. sid] []
|
|
|
|
graph <- runDB $ do
|
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shr
|
|
|
|
getRepoRoleGraph sid
|
|
|
|
defaultLayout $(widgetFile "repo/role/graph")
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
postRepoRolesR :: ShrIdent -> Handler Html
|
|
|
|
postRepoRolesR shr = do
|
|
|
|
sid <- fmap entityKey $ runDB $ getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
((result, widget), enctype) <- runFormPost $ newRepoRoleForm sid
|
2016-05-29 22:17:55 +09:00
|
|
|
case result of
|
2016-06-01 16:35:22 +09:00
|
|
|
FormSuccess nrr -> do
|
2016-05-29 22:17:55 +09:00
|
|
|
runDB $ do
|
2016-06-01 16:35:22 +09:00
|
|
|
let role = RepoRole
|
|
|
|
{ repoRoleIdent = nrrIdent nrr
|
2016-06-07 02:29:54 +09:00
|
|
|
, repoRoleSharer = sid
|
2016-06-01 16:35:22 +09:00
|
|
|
, repoRoleDesc = nrrDesc nrr
|
2016-05-29 22:17:55 +09:00
|
|
|
}
|
|
|
|
insert_ role
|
2016-06-07 04:41:22 +09:00
|
|
|
redirect $ RepoRolesR shr
|
2016-05-29 22:17:55 +09:00
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing"
|
2016-06-01 16:35:22 +09:00
|
|
|
defaultLayout $(widgetFile "repo/role/new")
|
2016-05-29 22:17:55 +09:00
|
|
|
FormFailure _l -> do
|
|
|
|
setMessage "Invalid input, see errors below"
|
2016-06-01 16:35:22 +09:00
|
|
|
defaultLayout $(widgetFile "repo/role/new")
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getRepoRoleNewR :: ShrIdent -> Handler Html
|
|
|
|
getRepoRoleNewR shr = do
|
|
|
|
sid <- fmap entityKey $ runDB $ getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
((_result, widget), enctype) <- runFormPost $ newRepoRoleForm sid
|
2016-06-01 16:35:22 +09:00
|
|
|
defaultLayout $(widgetFile "repo/role/new")
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getRepoRoleR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
getRepoRoleR shr rl = do
|
|
|
|
Entity _rid role <- runDB $ do
|
|
|
|
Entity sid _ <- getBy404 $ UniqueSharer shr
|
|
|
|
getBy404 $ UniqueRepoRole sid rl
|
2016-06-01 16:35:22 +09:00
|
|
|
defaultLayout $(widgetFile "repo/role/one")
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
deleteRepoRoleR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
deleteRepoRoleR shr rl = do
|
2016-05-29 22:17:55 +09:00
|
|
|
runDB $ do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
Entity rid _r <- getBy404 $ UniqueRepoRole sid rl
|
2016-05-29 22:17:55 +09:00
|
|
|
delete rid
|
|
|
|
setMessage "Role deleted."
|
2016-06-07 04:41:22 +09:00
|
|
|
redirect $ RepoRolesR shr
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
postRepoRoleR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
postRepoRoleR shr rl = do
|
2016-05-29 22:17:55 +09:00
|
|
|
mmethod <- lookupPostParam "_method"
|
|
|
|
case mmethod of
|
2016-06-07 04:41:22 +09:00
|
|
|
Just "DELETE" -> deleteRepoRoleR shr rl
|
2016-05-29 22:17:55 +09:00
|
|
|
_ -> notFound
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getRepoRoleOpsR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
getRepoRoleOpsR shr rl = do
|
2016-05-29 22:17:55 +09:00
|
|
|
ops <- runDB $ do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
Entity rid _r <- getBy404 $ UniqueRepoRole sid rl
|
2016-06-01 16:35:22 +09:00
|
|
|
as <- selectList [RepoAccessRole ==. rid] []
|
|
|
|
return $ map (repoAccessOp . entityVal) as
|
|
|
|
defaultLayout $(widgetFile "repo/role/op/list")
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
postRepoRoleOpsR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
postRepoRoleOpsR shr rl = do
|
2016-06-07 02:29:54 +09:00
|
|
|
let getrid = do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _ <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
fmap entityKey $ getBy404 $ UniqueRepoRole sid rl
|
2016-06-01 16:35:22 +09:00
|
|
|
((result, widget), enctype) <- runFormPost $ newRepoRoleOpForm getrid
|
2016-05-29 22:17:55 +09:00
|
|
|
case result of
|
|
|
|
FormSuccess op -> do
|
|
|
|
runDB $ do
|
|
|
|
rid <- getrid
|
2016-06-01 16:35:22 +09:00
|
|
|
let access = RepoAccess
|
|
|
|
{ repoAccessRole = rid
|
|
|
|
, repoAccessOp = op
|
2016-05-29 22:17:55 +09:00
|
|
|
}
|
|
|
|
insert_ access
|
2016-06-07 04:41:22 +09:00
|
|
|
redirect $ RepoRoleOpsR shr rl
|
2016-05-29 22:17:55 +09:00
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing"
|
2016-06-01 16:35:22 +09:00
|
|
|
defaultLayout $(widgetFile "repo/role/op/new")
|
2016-05-29 22:17:55 +09:00
|
|
|
FormFailure _l -> do
|
|
|
|
setMessage "Invalid input, see errors below"
|
2016-06-01 16:35:22 +09:00
|
|
|
defaultLayout $(widgetFile "repo/role/op/new")
|
2016-05-29 22:17:55 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getRepoRoleOpNewR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
getRepoRoleOpNewR shr rl = do
|
2016-06-07 02:29:54 +09:00
|
|
|
let getrid = do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _ <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
fmap entityKey $ getBy404 $ UniqueRepoRole sid rl
|
2016-06-01 16:35:22 +09:00
|
|
|
((_result, widget), enctype) <- runFormPost $ newRepoRoleOpForm getrid
|
|
|
|
defaultLayout $(widgetFile "repo/role/op/new")
|
2016-06-01 17:52:14 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getProjectRolesR :: ShrIdent -> Handler Html
|
|
|
|
getProjectRolesR shr = do
|
2016-07-02 18:45:29 +09:00
|
|
|
--roles <- runDB $ do
|
|
|
|
-- Entity sid _ <- getBy404 $ UniqueSharer shr
|
|
|
|
-- selectList [ProjectRoleSharer ==. sid] []
|
|
|
|
graph <- runDB $ do
|
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shr
|
|
|
|
getProjectRoleGraph sid
|
|
|
|
defaultLayout $(widgetFile "project/role/graph")
|
2016-06-01 17:52:14 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
postProjectRolesR :: ShrIdent -> Handler Html
|
|
|
|
postProjectRolesR shr = do
|
|
|
|
sid <- fmap entityKey $ runDB $ getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
((result, widget), enctype) <- runFormPost $ newProjectRoleForm sid
|
2016-06-01 17:52:14 +09:00
|
|
|
case result of
|
|
|
|
FormSuccess npr -> do
|
|
|
|
runDB $ do
|
|
|
|
let role = ProjectRole
|
|
|
|
{ projectRoleIdent = nprIdent npr
|
2016-06-07 02:29:54 +09:00
|
|
|
, projectRoleSharer = sid
|
2016-06-01 17:52:14 +09:00
|
|
|
, projectRoleDesc = nprDesc npr
|
|
|
|
}
|
|
|
|
insert_ role
|
2016-06-07 04:41:22 +09:00
|
|
|
redirect $ ProjectRolesR shr
|
2016-06-01 17:52:14 +09:00
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing"
|
|
|
|
defaultLayout $(widgetFile "project/role/new")
|
|
|
|
FormFailure _l -> do
|
|
|
|
setMessage "Invalid input, see errors below"
|
|
|
|
defaultLayout $(widgetFile "project/role/new")
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getProjectRoleNewR :: ShrIdent -> Handler Html
|
|
|
|
getProjectRoleNewR shr = do
|
|
|
|
sid <- fmap entityKey $ runDB $ getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
((_result, widget), enctype) <- runFormPost $ newProjectRoleForm sid
|
2016-06-01 17:52:14 +09:00
|
|
|
defaultLayout $(widgetFile "project/role/new")
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getProjectRoleR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
getProjectRoleR shr rl = do
|
2016-06-07 02:29:54 +09:00
|
|
|
Entity _rid role <- runDB $ do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _ <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
getBy404 $ UniqueProjectRole sid rl
|
2016-06-01 17:52:14 +09:00
|
|
|
defaultLayout $(widgetFile "project/role/one")
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
deleteProjectRoleR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
deleteProjectRoleR shr rl = do
|
2016-06-01 17:52:14 +09:00
|
|
|
runDB $ do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
Entity rid _r <- getBy404 $ UniqueProjectRole sid rl
|
2016-06-01 17:52:14 +09:00
|
|
|
delete rid
|
|
|
|
setMessage "Role deleted."
|
2016-06-07 04:41:22 +09:00
|
|
|
redirect $ ProjectRolesR shr
|
2016-06-01 17:52:14 +09:00
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
postProjectRoleR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
postProjectRoleR shr rl = do
|
2016-06-01 17:52:14 +09:00
|
|
|
mmethod <- lookupPostParam "_method"
|
|
|
|
case mmethod of
|
2016-06-07 04:41:22 +09:00
|
|
|
Just "DELETE" -> deleteProjectRoleR shr rl
|
2016-06-01 17:52:14 +09:00
|
|
|
_ -> notFound
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getProjectRoleOpsR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
getProjectRoleOpsR shr rl = do
|
2016-06-01 17:52:14 +09:00
|
|
|
ops <- runDB $ do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _s <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
Entity rid _r <- getBy404 $ UniqueProjectRole sid rl
|
2016-06-01 17:52:14 +09:00
|
|
|
as <- selectList [ProjectAccessRole ==. rid] []
|
|
|
|
return $ map (projectAccessOp . entityVal) as
|
|
|
|
defaultLayout $(widgetFile "project/role/op/list")
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
postProjectRoleOpsR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
postProjectRoleOpsR shr rl = do
|
2016-06-07 02:29:54 +09:00
|
|
|
let getrid = do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _ <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
fmap entityKey $ getBy404 $ UniqueProjectRole sid rl
|
2016-06-01 17:52:14 +09:00
|
|
|
((result, widget), enctype) <- runFormPost $ newProjectRoleOpForm getrid
|
|
|
|
case result of
|
|
|
|
FormSuccess op -> do
|
|
|
|
runDB $ do
|
|
|
|
rid <- getrid
|
|
|
|
let access = ProjectAccess
|
|
|
|
{ projectAccessRole = rid
|
|
|
|
, projectAccessOp = op
|
|
|
|
}
|
|
|
|
insert_ access
|
2016-06-07 04:41:22 +09:00
|
|
|
redirect $ ProjectRoleOpsR shr rl
|
2016-06-01 17:52:14 +09:00
|
|
|
FormMissing -> do
|
|
|
|
setMessage "Field(s) missing"
|
|
|
|
defaultLayout $(widgetFile "project/role/op/new")
|
|
|
|
FormFailure _l -> do
|
|
|
|
setMessage "Invalid input, see errors below"
|
|
|
|
defaultLayout $(widgetFile "project/role/op/new")
|
|
|
|
|
2016-06-07 04:41:22 +09:00
|
|
|
getProjectRoleOpNewR :: ShrIdent -> RlIdent -> Handler Html
|
|
|
|
getProjectRoleOpNewR shr rl = do
|
2016-06-07 02:29:54 +09:00
|
|
|
let getrid = do
|
2016-06-07 04:41:22 +09:00
|
|
|
Entity sid _ <- getBy404 $ UniqueSharer shr
|
2016-06-07 02:29:54 +09:00
|
|
|
fmap entityKey $ getBy404 $ UniqueProjectRole sid rl
|
2016-06-01 17:52:14 +09:00
|
|
|
((_result, widget), enctype) <- runFormPost $ newProjectRoleOpForm getrid
|
|
|
|
defaultLayout $(widgetFile "project/role/op/new")
|