2018-06-11 13:13:19 +00:00
package teammemberships
import (
2020-07-07 21:57:52 +00:00
"errors"
2018-06-11 13:13:19 +00:00
"net/http"
2018-09-10 10:01:38 +00:00
httperror "github.com/portainer/libhttp/error"
"github.com/portainer/libhttp/request"
"github.com/portainer/libhttp/response"
2021-02-23 03:21:39 +00:00
portainer "github.com/portainer/portainer/api"
2020-07-07 21:57:52 +00:00
httperrors "github.com/portainer/portainer/api/http/errors"
2019-03-21 01:20:14 +00:00
"github.com/portainer/portainer/api/http/security"
2018-06-11 13:13:19 +00:00
)
type teamMembershipCreatePayload struct {
2021-02-23 03:21:39 +00:00
// User identifier
UserID int ` validate:"required" example:"1" `
// Team identifier
TeamID int ` validate:"required" example:"1" `
// Role for the user inside the team (1 for leader and 2 for regular member)
Role int ` validate:"required" example:"1" enums:"1,2" `
2018-06-11 13:13:19 +00:00
}
func ( payload * teamMembershipCreatePayload ) Validate ( r * http . Request ) error {
if payload . UserID == 0 {
2020-07-07 21:57:52 +00:00
return errors . New ( "Invalid UserID" )
2018-06-11 13:13:19 +00:00
}
if payload . TeamID == 0 {
2020-07-07 21:57:52 +00:00
return errors . New ( "Invalid TeamID" )
2018-06-11 13:13:19 +00:00
}
if payload . Role != 1 && payload . Role != 2 {
2020-07-07 21:57:52 +00:00
return errors . New ( "Invalid role value. Value must be one of: 1 (leader) or 2 (member)" )
2018-06-11 13:13:19 +00:00
}
return nil
}
2021-02-23 03:21:39 +00:00
// @id TeamMembershipCreate
// @summary Create a new team membership
// @description Create a new team memberships. Access is only available to administrators leaders of the associated team.
2021-10-11 23:12:08 +00:00
// @description **Access policy**: administrator
2021-02-23 03:21:39 +00:00
// @tags team_memberships
2021-11-30 02:31:16 +00:00
// @security ApiKeyAuth
2021-02-23 03:21:39 +00:00
// @security jwt
// @accept json
// @produce json
// @param body body teamMembershipCreatePayload true "Team membership details"
// @success 200 {object} portainer.TeamMembership "Success"
// @success 204 "Success"
// @failure 400 "Invalid request"
// @failure 403 "Permission denied to manage memberships"
// @failure 409 "Team membership already registered"
// @failure 500 "Server error"
// @router /team_memberships [post]
2018-06-11 13:13:19 +00:00
func ( handler * Handler ) teamMembershipCreate ( w http . ResponseWriter , r * http . Request ) * httperror . HandlerError {
var payload teamMembershipCreatePayload
err := request . DecodeAndValidateJSONPayload ( r , & payload )
if err != nil {
return & httperror . HandlerError { http . StatusBadRequest , "Invalid request payload" , err }
}
securityContext , err := security . RetrieveRestrictedRequestContext ( r )
if err != nil {
return & httperror . HandlerError { http . StatusInternalServerError , "Unable to retrieve info from request context" , err }
}
if ! security . AuthorizedTeamManagement ( portainer . TeamID ( payload . TeamID ) , securityContext ) {
2020-07-07 21:57:52 +00:00
return & httperror . HandlerError { http . StatusForbidden , "Permission denied to manage team memberships" , httperrors . ErrResourceAccessDenied }
2018-06-11 13:13:19 +00:00
}
2020-05-20 05:23:15 +00:00
memberships , err := handler . DataStore . TeamMembership ( ) . TeamMembershipsByUserID ( portainer . UserID ( payload . UserID ) )
2018-06-11 13:13:19 +00:00
if err != nil {
return & httperror . HandlerError { http . StatusInternalServerError , "Unable to retrieve team memberships from the database" , err }
}
if len ( memberships ) > 0 {
for _ , membership := range memberships {
if membership . UserID == portainer . UserID ( payload . UserID ) && membership . TeamID == portainer . TeamID ( payload . TeamID ) {
2020-07-07 21:57:52 +00:00
return & httperror . HandlerError { http . StatusConflict , "Team membership already registered" , errors . New ( "Team membership already exists for this user and team" ) }
2018-06-11 13:13:19 +00:00
}
}
}
membership := & portainer . TeamMembership {
UserID : portainer . UserID ( payload . UserID ) ,
TeamID : portainer . TeamID ( payload . TeamID ) ,
Role : portainer . MembershipRole ( payload . Role ) ,
}
2020-05-20 05:23:15 +00:00
err = handler . DataStore . TeamMembership ( ) . CreateTeamMembership ( membership )
2018-06-11 13:13:19 +00:00
if err != nil {
return & httperror . HandlerError { http . StatusInternalServerError , "Unable to persist team memberships inside the database" , err }
}
return response . JSON ( w , membership )
}