gitrepo.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package models
  2. import (
  3. "github.com/porter-dev/porter/internal/models/integrations"
  4. "gorm.io/gorm"
  5. )
  6. // GitRepo is an integration that can connect to a remote git repo via an auth
  7. // mechanism (currently only oauth)
  8. type GitRepo struct {
  9. gorm.Model
  10. // The project that this integration belongs to
  11. ProjectID uint `json:"project_id"`
  12. // The username/organization that this repo integration is linked to
  13. RepoEntity string `json:"repo_entity"`
  14. // The various auth mechanisms available to the integration
  15. OAuthIntegrationID uint
  16. }
  17. // GitRepoExternal is a repository to be shared over REST
  18. type GitRepoExternal struct {
  19. ID uint `json:"id"`
  20. // The project that this integration belongs to
  21. ProjectID uint `json:"project_id"`
  22. // The username/organization that this repo integration is linked to
  23. RepoEntity string `json:"repo_entity"`
  24. // The integration service for this git repo
  25. Service integrations.IntegrationService `json:"service"`
  26. }
  27. // Externalize generates an external Repo to be shared over REST
  28. func (r *GitRepo) Externalize() *GitRepoExternal {
  29. return &GitRepoExternal{
  30. ID: r.Model.ID,
  31. ProjectID: r.ProjectID,
  32. RepoEntity: r.RepoEntity,
  33. Service: integrations.Github,
  34. }
  35. }
  36. // GitActionConfig is a configuration for release's CI integration via
  37. // Github Actions
  38. type GitActionConfig struct {
  39. gorm.Model
  40. // The ID of the release that this is linked to
  41. ReleaseID uint `json:"release_id"`
  42. // The git repo in ${owner}/${repo} form
  43. GitRepo string `json:"git_repo"`
  44. // The complete image repository uri to pull from
  45. ImageRepoURI string `json:"image_repo_uri"`
  46. // The git integration id
  47. GitRepoID uint `json:"git_repo_id"`
  48. // The path to the dockerfile in the git repo
  49. DockerfilePath string `json:"dockerfile_path" form:"required"`
  50. }
  51. // GitActionConfigExternal is an external GitActionConfig to be shared over REST
  52. type GitActionConfigExternal struct {
  53. // The git repo in ${owner}/${repo} form
  54. GitRepo string `json:"git_repo"`
  55. // The complete image repository uri to pull from
  56. ImageRepoURI string `json:"image_repo_uri"`
  57. // The git integration id
  58. GitRepoID uint `json:"git_repo_id"`
  59. // The path to the dockerfile in the git repo
  60. DockerfilePath string `json:"dockerfile_path" form:"required"`
  61. }
  62. // Externalize generates an external GitActionConfig to be shared over REST
  63. func (r *GitActionConfig) Externalize() *GitActionConfigExternal {
  64. return &GitActionConfigExternal{
  65. GitRepo: r.GitRepo,
  66. ImageRepoURI: r.ImageRepoURI,
  67. GitRepoID: r.GitRepoID,
  68. DockerfilePath: r.DockerfilePath,
  69. }
  70. }