// AddOrUpdateMembership adds the user as member to the organization. The authenticated user must be an organization owner. // If the user is not yet a member of the organization, the membership will be pending until the user accepts the invitation. Otherwise, if // the user is already a member of the organization, this method will update the role of the member within the organization. // // PUT /orgs/:org/memberships/:username // func (c *OrganizationsController) AddOrUpdateMembership(ctx *gin.Context) { var json bindings.AddUpdateMembership err := ctx.Bind(&json) if err != nil { helpers.JSONResponseValidationFailed(ctx, err) return } org := getOrganizationFromContext(ctx) orgService, err := services.NewOrganizationService(org, getCurrentUser(ctx)) if err != nil { if c.WriteTrace { c.Logger.Printf("Failed to create OrganizationService for org: %v", org) } helpers.JSONResponseInternalServerError(ctx, err) return } // retrieves the user that was found based on username parameter user := getUserFromContext(ctx) member, err := orgService.AddOrUpdateMembership(user, json) if err != nil { if err == services.ErrNotAnOrganizationOwner { helpers.JSONForbidden(ctx, err.Error()) } else { helpers.JSONResponseInternalServerError(ctx, err) } return } helpers.JSONResponseObject(ctx, presenters.MemberPresenter(member)) }
// EditMyOrganizationMembership edit your organization membership for the authenticated user // // PATCH /user/memberships/orgs/:org // func (c *UsersController) EditMyOrganizationMembership(ctx *gin.Context) { var json bindings.EditMyMembership err := ctx.Bind(&json) if err != nil { helpers.JSONResponseValidationFailed(ctx, err) } user := getCurrentUser(ctx) accountService, err := services.NewAccountService(user) if err != nil { if c.WriteTrace { c.Logger.Printf("Failed to create AccountService for user: %v", user) } helpers.JSONResponseInternalServerError(ctx, err) return } org := getOrganizationFromContext(ctx) member, err := accountService.EditMyMembership(org.ID, json) if err != nil { if err == ErrNotFound { helpers.JSONErrorf(ctx, http.StatusNotFound, "No membership found for this organization") return } helpers.JSONResponseInternalServerError(ctx, err) return } helpers.JSONResponseObject(ctx, presenters.MemberPresenter(member)) }
// EditOrganization modifes an organization record // // PATCH /orgs/:org // func (c *OrganizationsController) EditOrganization(ctx *gin.Context) { var json bindings.UpdateOrganization err := ctx.Bind(&json) if err != nil { helpers.JSONResponseValidationFailed(ctx, err) return } org := getOrganizationFromContext(ctx) orgService, err := services.NewOrganizationService(org, getCurrentUser(ctx)) if err != nil { if c.WriteTrace { c.Logger.Printf("Failed to create OrganizationService for org: %v", org) } helpers.JSONResponseInternalServerError(ctx, err) return } org, err = orgService.UpdateOrganization(json) if err != nil { helpers.JSONResponseInternalServerError(ctx, err) return } helpers.JSONResponseObject(ctx, presenters.OrganizationPresenter(org)) }
// ListPublicConversations returns the list of all public conversations // // GET /conversations // func (c *ConversationsController) ListPublicConversations(ctx *gin.Context) { conversations, err := services.ListPublicConversations(nil) if err != nil { helpers.JSONResponseInternalServerError(ctx, err) return } helpers.JSONResponseObject(ctx, presenters.ConversationCollectionPresenter(conversations)) }
// ListUserOrganizations lists all organizations for a specific user // // GET /users/:username/orgs // func (c *UsersController) ListUserOrganizations(ctx *gin.Context) { user := getCurrentUser(ctx) userService, err := services.NewUserService(user) if err != nil { if c.WriteTrace { c.Logger.Printf("Failed to create UserService for user: %v", user) } helpers.JSONResponseInternalServerError(ctx, err) return } orgs, err := userService.ListOrganizations() if err != nil { helpers.JSONResponseInternalServerError(ctx, err) return } helpers.JSONResponseObject(ctx, presenters.OrganizationCollectionPresenter(orgs)) }
// RegisterNewUser creates a new user account // // POST /users // func (c *UsersController) RegisterNewUser(ctx *gin.Context) { var json bindings.RegisterNewUser err := ctx.Bind(&json) if err != nil { helpers.JSONResponseValidationFailed(ctx, err) return } user, err := services.RegisterNewUser(json) if err != nil { if err == services.ErrNamespaceAlreadyExists { helpers.JSONErrorf(ctx, http.StatusBadRequest, "Username already exists") } else { helpers.JSONResponseInternalServerError(ctx, err) } return } helpers.JSONResponseObject(ctx, presenters.UserPresenter(user)) }
// CreateOrganization creates a new Organization and makes the current authenticated user the owner // // POST /orgs // func (c *OrganizationsController) CreateOrganization(ctx *gin.Context) { var json bindings.CreateOrganization err := ctx.Bind(&json) if err != nil { helpers.JSONResponseValidationFailed(ctx, err) return } // creates the organization and set the current user as part of Owners Team org, err := services.CreateOrganization(json, getCurrentUser(ctx)) if err != nil { if err == services.ErrNamespaceAlreadyExists { helpers.JSONErrorf(ctx, http.StatusBadRequest, "Organization name already exists") } else { helpers.JSONResponseInternalServerError(ctx, err) } return } helpers.JSONResponseObject(ctx, presenters.OrganizationPresenter(org)) }
// GetConversation returns a specific conversation // // GET /conversations/:id // func (c *ConversationsController) GetConversation(ctx *gin.Context) { ctxConversation := getConversationFromContext(ctx) conversationService, err := services.NewConversationService(ctxConversation, getCurrentUser(ctx)) if err != nil { if c.WriteTrace { c.Logger.Printf("Failed to create ConversationService for org: %v", ctxConversation) } helpers.JSONResponseInternalServerError(ctx, err) return } conversation, err := conversationService.GetConversation() if err != nil { helpers.JSONResponseInternalServerError(ctx, err) return } helpers.JSONResponseObject(ctx, presenters.ConversationPresenter(conversation)) }
// ListMyOrganizationMemberships list your organization memberships for the authenticated users // // GET /user/memberships/orgs // func (c *UsersController) ListMyOrganizationMemberships(ctx *gin.Context) { user := getCurrentUser(ctx) accountService, err := services.NewAccountService(user) if err != nil { if c.WriteTrace { c.Logger.Printf("Failed to create AccountService for user: %v", user) } helpers.JSONResponseInternalServerError(ctx, err) return } members, err := accountService.ListMyMemberships() if err != nil { helpers.JSONResponseInternalServerError(ctx, err) return } helpers.JSONResponseObject(ctx, presenters.MemberCollectionPresenter(members)) }
// GetOrganization returns an organization record // // GET /orgs/:org // func (c *OrganizationsController) GetOrganization(ctx *gin.Context) { org := getOrganizationFromContext(ctx) helpers.JSONResponseObject(ctx, presenters.OrganizationPresenter(org)) }
// UpdateMe updates the authenticated user // // PATCH /user // func (c *UsersController) UpdateMe(ctx *gin.Context) { user := getCurrentUser(ctx) //TODO: fix me helpers.JSONResponseObject(ctx, presenters.UserPresenter(user)) }
// GetMe gets the authenticated user // // GET /user // func (c *UsersController) GetMe(ctx *gin.Context) { user := getCurrentUser(ctx) helpers.JSONResponseObject(ctx, presenters.UserPresenter(user)) }