Commit 1863f47f authored by Alexandre Delanoë's avatar Alexandre Delanoë

Merge remote-tracking branch 'origin/438-dev-team-node-creator' into dev-merge

parents 1bcaa43a 713a27d1
...@@ -73,7 +73,7 @@ data Query m ...@@ -73,7 +73,7 @@ data Query m
, user_infos :: GQLUserInfo.UserInfoArgs -> m [GQLUserInfo.UserInfo] , user_infos :: GQLUserInfo.UserInfoArgs -> m [GQLUserInfo.UserInfo]
, users :: GQLUser.UserArgs -> m [GQLUser.User m] , users :: GQLUser.UserArgs -> m [GQLUser.User m]
, tree :: GQLTree.TreeArgs -> m (GQLTree.TreeFirstLevel m) , tree :: GQLTree.TreeArgs -> m (GQLTree.TreeFirstLevel m)
, team :: GQLTeam.TeamArgs -> m [GQLTeam.TeamMember] , team :: GQLTeam.TeamArgs -> m GQLTeam.Team
} deriving (Generic, GQLType) } deriving (Generic, GQLType)
data Mutation m data Mutation m
......
...@@ -20,10 +20,16 @@ import Gargantext.API.Admin.Types (HasSettings) ...@@ -20,10 +20,16 @@ import Gargantext.API.Admin.Types (HasSettings)
import Gargantext.Database.Query.Table.User (getUsersWithNodeHyperdata) import Gargantext.Database.Query.Table.User (getUsersWithNodeHyperdata)
import qualified Data.Text as T import qualified Data.Text as T
import Gargantext.Database.Schema.User (UserLight(..))
data TeamArgs = TeamArgs data TeamArgs = TeamArgs
{ team_node_id :: Int } deriving (Generic, GQLType) { team_node_id :: Int } deriving (Generic, GQLType)
data Team = Team
{ team_leader_username :: Text
, team_members :: [TeamMember]
} deriving (Generic, GQLType)
data TeamMember = TeamMember data TeamMember = TeamMember
{ username :: Text { username :: Text
, shared_folder_id :: Int , shared_folder_id :: Int
...@@ -38,23 +44,29 @@ data TeamDeleteMArgs = TeamDeleteMArgs ...@@ -38,23 +44,29 @@ data TeamDeleteMArgs = TeamDeleteMArgs
type GqlM e env = Resolver QUERY e (GargM env GargError) type GqlM e env = Resolver QUERY e (GargM env GargError)
type GqlM' e env a = ResolverM e (GargM env GargError) a type GqlM' e env a = ResolverM e (GargM env GargError) a
todo :: a
todo = undefined
resolveTeam :: (HasConnectionPool env, HasConfig env, HasMail env) => TeamArgs -> GqlM e env [TeamMember] resolveTeam :: (HasConnectionPool env, HasConfig env, HasMail env) => TeamArgs -> GqlM e env Team
resolveTeam TeamArgs { team_node_id } = dbTeam team_node_id resolveTeam TeamArgs { team_node_id } = dbTeam team_node_id
dbTeam :: (HasConnectionPool env, HasConfig env, HasMail env) => Int -> GqlM e env [TeamMember] dbTeam :: (HasConnectionPool env, HasConfig env, HasMail env) => Int -> GqlM e env Team
dbTeam nodeId = do dbTeam nodeId = do
let nId = NodeId nodeId let nId = NodeId nodeId
res <- lift $ membersOf nId res <- lift $ membersOf nId
pure $ map toTeamMember res teamNode <- lift $ getNode nId
userNodes <- lift $ getUsersWithNodeHyperdata $ uId teamNode
let username = getUsername userNodes
pure $ Team { team_leader_username = username
, team_members = map toTeamMember res
}
where where
toTeamMember :: (Text, NodeId) -> TeamMember toTeamMember :: (Text, NodeId) -> TeamMember
toTeamMember (username, fId)= TeamMember { toTeamMember (username, fId)= TeamMember {
username, username,
shared_folder_id = unNodeId fId shared_folder_id = unNodeId fId
} }
uId Node { _node_user_id } = _node_user_id
getUsername [] = panic "[resolveTeam] Team creator doesn't exist"
getUsername ((UserLight {userLight_username}, _):_) = userLight_username
-- TODO: list as argument -- TODO: list as argument
deleteTeamMembership :: (HasConnectionPool env, HasConfig env, HasMail env, HasSettings env) => TeamDeleteMArgs -> GqlM' e env [Int] deleteTeamMembership :: (HasConnectionPool env, HasConfig env, HasMail env, HasSettings env) => TeamDeleteMArgs -> GqlM' e env [Int]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment