project.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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. // ReadProject gets a projects specified by a unique id
  35. func (repo *ProjectRepository) ReadProject(id uint) (*models.Project, error) {
  36. project := &models.Project{}
  37. if err := repo.db.Preload("Roles").Where("id = ?", id).First(&project).Error; err != nil {
  38. return nil, err
  39. }
  40. return project, nil
  41. }
  42. // ListProjectsByUserID lists projects where a user has an associated role
  43. func (repo *ProjectRepository) ListProjectsByUserID(userID uint) ([]*models.Project, error) {
  44. projects := make([]*models.Project, 0)
  45. subQuery := repo.db.Model(&models.Role{}).Where("user_id = ?", userID).Select("project_id")
  46. if err := repo.db.Preload("Roles").Model(&models.Project{}).Where("id IN (?)", subQuery).Find(&projects).Error; err != nil {
  47. return nil, err
  48. }
  49. return projects, nil
  50. }
  51. // DeleteProject deletes a project (marking deleted in the db)
  52. func (repo *ProjectRepository) DeleteProject(project *models.Project) (*models.Project, error) {
  53. if err := repo.db.Delete(&project).Error; err != nil {
  54. return nil, err
  55. }
  56. return project, nil
  57. }