stufflog graphql server
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

111 lines
3.3 KiB

  1. package resolvers
  2. // This file will be automatically regenerated based on the schema, any resolver implementations
  3. // will be copied through when generating and any unknown code will be moved to the end.
  4. import (
  5. "context"
  6. "errors"
  7. "git.aiterp.net/stufflog/server/graph/graphcore"
  8. "git.aiterp.net/stufflog/server/internal/xlerrors"
  9. "git.aiterp.net/stufflog/server/models"
  10. )
  11. func (r *mutationResolver) CreateProject(ctx context.Context, input graphcore.ProjectCreateInput) (*models.Project, error) {
  12. user := r.Auth.UserFromContext(ctx)
  13. if user == nil {
  14. return nil, xlerrors.PermissionDenied
  15. }
  16. project := &models.Project{
  17. ID: input.ID,
  18. Name: input.Name,
  19. Description: input.Description,
  20. DailyPoints: input.DailyPoints,
  21. }
  22. if !project.ValidKey() {
  23. return nil, errors.New("the project must have a valid ID (only uppercase allowed)")
  24. }
  25. if project.Name == "" || project.Description == "" {
  26. return nil, errors.New("name and description cannot be left empty")
  27. }
  28. project, err := r.Database.Projects().Insert(ctx, *project)
  29. if err != nil {
  30. return nil, err
  31. }
  32. err = r.Database.Projects().SetPermission(ctx, models.ProjectPermission{
  33. ProjectID: project.ID,
  34. UserID: user.ID,
  35. Level: models.ProjectPermissionLevelOwner,
  36. })
  37. return project, nil
  38. }
  39. func (r *mutationResolver) CreateIssue(ctx context.Context, input graphcore.IssueCreateInput) (*models.Issue, error) {
  40. user := r.Auth.UserFromContext(ctx)
  41. if user == nil {
  42. return nil, xlerrors.PermissionDenied
  43. }
  44. project, err := r.Database.Projects().Find(ctx, input.ProjectID)
  45. if err != nil {
  46. return nil, err
  47. }
  48. if perm, err := r.Auth.ProjectPermission(ctx, *project); err != nil || !perm.CanManageOwnIssue() {
  49. return nil, xlerrors.PermissionDenied
  50. }
  51. issue := &models.Issue{
  52. ProjectID: project.ID,
  53. OwnerID: user.ID,
  54. AssigneeID: "",
  55. StatusStage: input.StatusStage,
  56. StatusName: input.StatusName,
  57. Name: input.Name,
  58. Title: input.Name,
  59. Description: input.Description,
  60. }
  61. if input.Title != nil && *input.Title != "" {
  62. issue.Title = *input.Title
  63. }
  64. if input.DueTime != nil && !input.DueTime.IsZero() {
  65. issue.DueTime = *input.DueTime
  66. }
  67. if input.AssigneeID != nil && *input.AssigneeID != "" {
  68. issue.AssigneeID = *input.AssigneeID
  69. }
  70. issue, err = r.Database.Issues().Insert(ctx, *issue)
  71. if err != nil {
  72. return nil, err
  73. }
  74. return issue, nil
  75. }
  76. func (r *mutationResolver) LoginUser(ctx context.Context, input graphcore.UserLoginInput) (*models.User, error) {
  77. return r.Auth.Login(ctx, input.Username, input.Password)
  78. }
  79. func (r *mutationResolver) LogoutUser(ctx context.Context) (*models.User, error) {
  80. return r.Auth.Logout(ctx)
  81. }
  82. func (r *mutationResolver) CreateUser(ctx context.Context, input graphcore.UserCreateInput) (*models.User, error) {
  83. active := input.Active == nil || *input.Active
  84. admin := input.Admin != nil && *input.Admin
  85. return r.Auth.CreateUser(ctx, input.Username, input.Password, input.Name, active, admin)
  86. }
  87. func (r *mutationResolver) EditUser(ctx context.Context, input graphcore.UserEditInput) (*models.User, error) {
  88. return r.Auth.EditUser(ctx, input.Username, input.SetName, input.CurrentPassword, input.SetPassword)
  89. }
  90. // Mutation returns graphcore.MutationResolver implementation.
  91. func (r *Resolver) Mutation() graphcore.MutationResolver { return &mutationResolver{r} }
  92. type mutationResolver struct{ *Resolver }