project.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package gorm
  2. import (
  3. "github.com/porter-dev/porter/internal/models"
  4. "github.com/porter-dev/porter/internal/repository"
  5. "gorm.io/gorm"
  6. )
  7. // ProjectRepository uses gorm.DB for querying the database
  8. type ProjectRepository struct {
  9. db *gorm.DB
  10. }
  11. // NewProjectRepository returns a ProjectRepository which uses
  12. // gorm.DB for querying the database
  13. func NewProjectRepository(db *gorm.DB) repository.ProjectRepository {
  14. return &ProjectRepository{db}
  15. }
  16. // CreateProject creates a new project
  17. func (repo *ProjectRepository) CreateProject(project *models.Project) (*models.Project, error) {
  18. if err := repo.db.Create(project).Error; err != nil {
  19. return nil, err
  20. }
  21. return project, nil
  22. }
  23. // CreateProjectRole appends a role to the existing array of roles
  24. func (repo *ProjectRepository) CreateProjectRole(project *models.Project, role *models.Role) (*models.Role, error) {
  25. assoc := repo.db.Model(&project).Association("Roles")
  26. if assoc.Error != nil {
  27. return nil, assoc.Error
  28. }
  29. if err := assoc.Append(role); err != nil {
  30. return nil, err
  31. }
  32. return role, nil
  33. }
  34. func (repo *ProjectRepository) UpdateProjectRole(projID uint, role *models.Role) (*models.Role, error) {
  35. foundRole := &models.Role{}
  36. if err := repo.db.Where("project_id = ? AND user_id = ?", projID, role.UserID).First(&foundRole).Error; err != nil {
  37. return nil, err
  38. }
  39. role.ID = foundRole.ID
  40. if err := repo.db.Save(&role).Error; err != nil {
  41. return nil, err
  42. }
  43. return role, nil
  44. }
  45. // ReadProject gets a projects specified by a unique id
  46. func (repo *ProjectRepository) ReadProject(id uint) (*models.Project, error) {
  47. project := &models.Project{}
  48. if err := repo.db.Preload("Roles").Where("id = ?", id).First(&project).Error; err != nil {
  49. return nil, err
  50. }
  51. return project, nil
  52. }
  53. // ReadProject gets a projects specified by a unique id
  54. func (repo *ProjectRepository) ReadProjectRole(projID, userID uint) (*models.Role, error) {
  55. // find the role
  56. role := &models.Role{}
  57. if err := repo.db.Where("project_id = ? AND user_id = ?", projID, userID).First(&role).Error; err != nil {
  58. return nil, err
  59. }
  60. return role, nil
  61. }
  62. // ListProjectsByUserID lists projects where a user has an associated role
  63. func (repo *ProjectRepository) ListProjectsByUserID(userID uint) ([]*models.Project, error) {
  64. projects := make([]*models.Project, 0)
  65. subQuery := repo.db.Model(&models.Role{}).Where("user_id = ?", userID).Select("project_id")
  66. if err := repo.db.Preload("Roles").Model(&models.Project{}).Where("id IN (?)", subQuery).Find(&projects).Error; err != nil {
  67. return nil, err
  68. }
  69. return projects, nil
  70. }
  71. // ReadProject gets a projects specified by a unique id
  72. func (repo *ProjectRepository) ListProjectRoles(projID uint) ([]models.Role, error) {
  73. project := &models.Project{}
  74. if err := repo.db.Preload("Roles").Where("id = ?", projID).First(&project).Error; err != nil {
  75. return nil, err
  76. }
  77. return project.Roles, nil
  78. }
  79. // DeleteProject deletes a project (marking deleted in the db)
  80. func (repo *ProjectRepository) DeleteProject(project *models.Project) (*models.Project, error) {
  81. if err := repo.db.Delete(&project).Error; err != nil {
  82. return nil, err
  83. }
  84. return project, nil
  85. }
  86. func (repo *ProjectRepository) DeleteProjectRole(projID, userID uint) (*models.Role, error) {
  87. // find the role
  88. role := &models.Role{}
  89. if err := repo.db.Where("project_id = ? AND user_id = ?", projID, userID).First(&role).Error; err != nil {
  90. return nil, err
  91. }
  92. if err := repo.db.Delete(&role).Error; err != nil {
  93. return nil, err
  94. }
  95. return role, nil
  96. }