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.

271 lines
11 KiB

Template Repositories (#8768) * Start work on templates Signed-off-by: jolheiser <john.olheiser@gmail.com> * Continue work Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix IsTemplate vs IsGenerated Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix tabs vs spaces * Tabs vs Spaces * Add templates to API & start adding tests Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix integration tests Signed-off-by: jolheiser <john.olheiser@gmail.com> * Remove unused User Signed-off-by: jolheiser <john.olheiser@gmail.com> * Move template tests to existing repos Signed-off-by: jolheiser <john.olheiser@gmail.com> * Minor re-check updates and cleanup Signed-off-by: jolheiser <john.olheiser@gmail.com> * make fmt Signed-off-by: jolheiser <john.olheiser@gmail.com> * Test cleanup Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix optionalbool Signed-off-by: jolheiser <john.olheiser@gmail.com> * make fmt Signed-off-by: jolheiser <john.olheiser@gmail.com> * Test fixes and icon change Signed-off-by: jolheiser <john.olheiser@gmail.com> * Add new user and repo for tests Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix tests (finally) Signed-off-by: jolheiser <john.olheiser@gmail.com> * Update meta repo with env variables Signed-off-by: jolheiser <john.olheiser@gmail.com> * Move generation to create page Combine with repo create template Modify API search to prioritize owner for repo Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix tests and coverage Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix swagger and JS lint Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix API searching for own private repos Signed-off-by: jolheiser <john.olheiser@gmail.com> * Change wording Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix repo search test. User had a private repo that didn't show up Signed-off-by: jolheiser <john.olheiser@gmail.com> * Another search test fix Signed-off-by: jolheiser <john.olheiser@gmail.com> * Clarify git content Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * Feedback updates Signed-off-by: jolheiser <john.olheiser@gmail.com> * Add topics WIP Signed-off-by: jolheiser <john.olheiser@gmail.com> * Finish adding topics Signed-off-by: jolheiser <john.olheiser@gmail.com> * Update locale Signed-off-by: jolheiser <john.olheiser@gmail.com>
4 years ago
Add Attachment API (#3478) * Add Attachment API * repos/:owner/:repo/releases (add attachments) * repos/:owner/:repo/releases/:id (add attachments) * repos/:owner/:repo/releases/:id/attachments * repos/:owner/:repo/releases/:id/attachments/:attachment_id Signed-off-by: Jonas Franz <info@jonasfranz.de> * Add unit tests for new attachment functions Fix comments Signed-off-by: Jonas Franz <info@jonasfranz.software> * fix lint * Update vendor.json Signed-off-by: Jonas Franz <info@jonasfranz.software> * remove version of sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix unit tests Add missing license header Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add CreateReleaseAttachment Add EditReleaseAttachment Add DeleteReleaseAttachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add filename query parameter for choosing another name for an attachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix order of imports Signed-off-by: Jonas Franz <info@jonasfranz.software> * Restricting updatable attachment columns Signed-off-by: Jonas Franz <info@jonasfranz.software> * gofmt Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update go-sdk Replace Attachments with Assets Signed-off-by: Jonas Franz <info@jonasfranz.de> * Update go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.de> * Updating go-sdk and regenerating swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add missing file of go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Change origin of code.gitea.io/sdk to code.gitea.io/sdk Update code.gitea.io/sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update updateAttachment
6 years ago
Template Repositories (#8768) * Start work on templates Signed-off-by: jolheiser <john.olheiser@gmail.com> * Continue work Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix IsTemplate vs IsGenerated Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix tabs vs spaces * Tabs vs Spaces * Add templates to API & start adding tests Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix integration tests Signed-off-by: jolheiser <john.olheiser@gmail.com> * Remove unused User Signed-off-by: jolheiser <john.olheiser@gmail.com> * Move template tests to existing repos Signed-off-by: jolheiser <john.olheiser@gmail.com> * Minor re-check updates and cleanup Signed-off-by: jolheiser <john.olheiser@gmail.com> * make fmt Signed-off-by: jolheiser <john.olheiser@gmail.com> * Test cleanup Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix optionalbool Signed-off-by: jolheiser <john.olheiser@gmail.com> * make fmt Signed-off-by: jolheiser <john.olheiser@gmail.com> * Test fixes and icon change Signed-off-by: jolheiser <john.olheiser@gmail.com> * Add new user and repo for tests Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix tests (finally) Signed-off-by: jolheiser <john.olheiser@gmail.com> * Update meta repo with env variables Signed-off-by: jolheiser <john.olheiser@gmail.com> * Move generation to create page Combine with repo create template Modify API search to prioritize owner for repo Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix tests and coverage Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix swagger and JS lint Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix API searching for own private repos Signed-off-by: jolheiser <john.olheiser@gmail.com> * Change wording Signed-off-by: jolheiser <john.olheiser@gmail.com> * Fix repo search test. User had a private repo that didn't show up Signed-off-by: jolheiser <john.olheiser@gmail.com> * Another search test fix Signed-off-by: jolheiser <john.olheiser@gmail.com> * Clarify git content Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * Feedback updates Signed-off-by: jolheiser <john.olheiser@gmail.com> * Add topics WIP Signed-off-by: jolheiser <john.olheiser@gmail.com> * Finish adding topics Signed-off-by: jolheiser <john.olheiser@gmail.com> * Update locale Signed-off-by: jolheiser <john.olheiser@gmail.com>
4 years ago
Add support for migrating from Gitlab (#9084) * First stab at a Gitlab migrations interface. * Modify JS to show migration for Gitlab * Properly strip out #gitlab tag from repo name * Working Gitlab migrations! Still need to figure out how to hide tokens/etc from showing up in opts.CloneAddr * Try #2 at trying to hide credentials. CloneAddr was being used as OriginalURL. Now passing OriginalURL through from the form and saving it. * Add go-gitlab dependency * Vendor go-gitlab * Use gitlab.BasicAuthClient Correct CloneURL. This should be functioning! Previous commits fixed "Migrated from" from including the migration credentials. * Replaced repoPath with repoID globally. RepoID is grabbed in NewGitlabDownloader * Logging touchup * Properly set private repo status. Properly set milestone deadline time. Consistently use Gitlab username for 'Name'. * Add go-gitlab vendor cache * Fix PR migrations: - Count of issues is kept to set a non-conflicting PR.ID - Bool is used to tell whether to fetch Issue or PR comments * Ensure merged PRs are closed and set with the proper time * Remove copyright and some commented code * Rip out '#gitlab' based self-hosted Gitlab support * Hide given credentials for migrated repos. CloneAddr was being saved as OriginalURL. Now passing OriginalURL through from the form and saving it in it's place * Use asset.URL directly, no point in parsing. Opened PRs should fall through to false. * Fix importing Milestones. Allow importing using Personal Tokens or anonymous access. * Fix Gitlab Milestone migration if DueDate isn't set * Empty Milestone due dates properly return nil, not zero time * Add GITLAB_READ_TOKEN to drone unit-test step * Add working gitlab_test.go. A Personal Access Token, given in env variable GITLAB_READ_TOKEN is required to run the test. * Fix linting issues * Add modified JS files * Remove pre-build JS files * Only merged PRs are marged as merged/closed * Test topics * Skip test if gitlab is inaccessible * Grab personal token from username, not password. Matches Github migration implementation * Add SetContext() to GitlabDownloader. * Checking Updated field in Issues. * Actually fetch Issue Updated time from Gitlab * Add Gitlab migration GetReviews() stub * Fix Patch and Clone URLs * check Updated too * fix mod * make vendor with go1.14 Co-authored-by: techknowlogick <techknowlogick@gitea.io> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: Lauris BH <lauris@nix.lv> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
4 years ago
Add Attachment API (#3478) * Add Attachment API * repos/:owner/:repo/releases (add attachments) * repos/:owner/:repo/releases/:id (add attachments) * repos/:owner/:repo/releases/:id/attachments * repos/:owner/:repo/releases/:id/attachments/:attachment_id Signed-off-by: Jonas Franz <info@jonasfranz.de> * Add unit tests for new attachment functions Fix comments Signed-off-by: Jonas Franz <info@jonasfranz.software> * fix lint * Update vendor.json Signed-off-by: Jonas Franz <info@jonasfranz.software> * remove version of sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix unit tests Add missing license header Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add CreateReleaseAttachment Add EditReleaseAttachment Add DeleteReleaseAttachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add filename query parameter for choosing another name for an attachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix order of imports Signed-off-by: Jonas Franz <info@jonasfranz.software> * Restricting updatable attachment columns Signed-off-by: Jonas Franz <info@jonasfranz.software> * gofmt Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update go-sdk Replace Attachments with Assets Signed-off-by: Jonas Franz <info@jonasfranz.de> * Update go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.de> * Updating go-sdk and regenerating swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add missing file of go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Change origin of code.gitea.io/sdk to code.gitea.io/sdk Update code.gitea.io/sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update updateAttachment
6 years ago
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package structs
  5. import (
  6. "strings"
  7. "time"
  8. )
  9. // Permission represents a set of permissions
  10. type Permission struct {
  11. Admin bool `json:"admin"`
  12. Push bool `json:"push"`
  13. Pull bool `json:"pull"`
  14. }
  15. // InternalTracker represents settings for internal tracker
  16. // swagger:model
  17. type InternalTracker struct {
  18. // Enable time tracking (Built-in issue tracker)
  19. EnableTimeTracker bool `json:"enable_time_tracker"`
  20. // Let only contributors track time (Built-in issue tracker)
  21. AllowOnlyContributorsToTrackTime bool `json:"allow_only_contributors_to_track_time"`
  22. // Enable dependencies for issues and pull requests (Built-in issue tracker)
  23. EnableIssueDependencies bool `json:"enable_issue_dependencies"`
  24. }
  25. // ExternalTracker represents settings for external tracker
  26. // swagger:model
  27. type ExternalTracker struct {
  28. // URL of external issue tracker.
  29. ExternalTrackerURL string `json:"external_tracker_url"`
  30. // External Issue Tracker URL Format. Use the placeholders {user}, {repo} and {index} for the username, repository name and issue index.
  31. ExternalTrackerFormat string `json:"external_tracker_format"`
  32. // External Issue Tracker Number Format, either `numeric` or `alphanumeric`
  33. ExternalTrackerStyle string `json:"external_tracker_style"`
  34. }
  35. // ExternalWiki represents setting for external wiki
  36. // swagger:model
  37. type ExternalWiki struct {
  38. // URL of external wiki.
  39. ExternalWikiURL string `json:"external_wiki_url"`
  40. }
  41. // Repository represents a repository
  42. type Repository struct {
  43. ID int64 `json:"id"`
  44. Owner *User `json:"owner"`
  45. Name string `json:"name"`
  46. FullName string `json:"full_name"`
  47. Description string `json:"description"`
  48. Empty bool `json:"empty"`
  49. Private bool `json:"private"`
  50. Fork bool `json:"fork"`
  51. Template bool `json:"template"`
  52. Parent *Repository `json:"parent"`
  53. Mirror bool `json:"mirror"`
  54. Size int `json:"size"`
  55. HTMLURL string `json:"html_url"`
  56. SSHURL string `json:"ssh_url"`
  57. CloneURL string `json:"clone_url"`
  58. OriginalURL string `json:"original_url"`
  59. Website string `json:"website"`
  60. Stars int `json:"stars_count"`
  61. Forks int `json:"forks_count"`
  62. Watchers int `json:"watchers_count"`
  63. OpenIssues int `json:"open_issues_count"`
  64. OpenPulls int `json:"open_pr_counter"`
  65. Releases int `json:"release_counter"`
  66. DefaultBranch string `json:"default_branch"`
  67. Archived bool `json:"archived"`
  68. // swagger:strfmt date-time
  69. Created time.Time `json:"created_at"`
  70. // swagger:strfmt date-time
  71. Updated time.Time `json:"updated_at"`
  72. Permissions *Permission `json:"permissions,omitempty"`
  73. HasIssues bool `json:"has_issues"`
  74. InternalTracker *InternalTracker `json:"internal_tracker,omitempty"`
  75. ExternalTracker *ExternalTracker `json:"external_tracker,omitempty"`
  76. HasWiki bool `json:"has_wiki"`
  77. ExternalWiki *ExternalWiki `json:"external_wiki,omitempty"`
  78. HasPullRequests bool `json:"has_pull_requests"`
  79. HasProjects bool `json:"has_projects"`
  80. IgnoreWhitespaceConflicts bool `json:"ignore_whitespace_conflicts"`
  81. AllowMerge bool `json:"allow_merge_commits"`
  82. AllowRebase bool `json:"allow_rebase"`
  83. AllowRebaseMerge bool `json:"allow_rebase_explicit"`
  84. AllowSquash bool `json:"allow_squash_merge"`
  85. AvatarURL string `json:"avatar_url"`
  86. Internal bool `json:"internal"`
  87. }
  88. // CreateRepoOption options when creating repository
  89. // swagger:model
  90. type CreateRepoOption struct {
  91. // Name of the repository to create
  92. //
  93. // required: true
  94. // unique: true
  95. Name string `json:"name" binding:"Required;AlphaDashDot;MaxSize(100)"`
  96. // Description of the repository to create
  97. Description string `json:"description" binding:"MaxSize(255)"`
  98. // Whether the repository is private
  99. Private bool `json:"private"`
  100. // Issue Label set to use
  101. IssueLabels string `json:"issue_labels"`
  102. // Whether the repository should be auto-intialized?
  103. AutoInit bool `json:"auto_init"`
  104. // Gitignores to use
  105. Gitignores string `json:"gitignores"`
  106. // License to use
  107. License string `json:"license"`
  108. // Readme of the repository to create
  109. Readme string `json:"readme"`
  110. // DefaultBranch of the repository (used when initializes and in template)
  111. DefaultBranch string `json:"default_branch" binding:"GitRefName;MaxSize(100)"`
  112. }
  113. // EditRepoOption options when editing a repository's properties
  114. // swagger:model
  115. type EditRepoOption struct {
  116. // name of the repository
  117. // unique: true
  118. Name *string `json:"name,omitempty" binding:"OmitEmpty;AlphaDashDot;MaxSize(100);"`
  119. // a short description of the repository.
  120. Description *string `json:"description,omitempty" binding:"MaxSize(255)"`
  121. // a URL with more information about the repository.
  122. Website *string `json:"website,omitempty" binding:"MaxSize(255)"`
  123. // either `true` to make the repository private or `false` to make it public.
  124. // Note: you will get a 422 error if the organization restricts changing repository visibility to organization
  125. // owners and a non-owner tries to change the value of private.
  126. Private *bool `json:"private,omitempty"`
  127. // either `true` to make this repository a template or `false` to make it a normal repository
  128. Template *bool `json:"template,omitempty"`
  129. // either `true` to enable issues for this repository or `false` to disable them.
  130. HasIssues *bool `json:"has_issues,omitempty"`
  131. // set this structure to configure internal issue tracker (requires has_issues)
  132. InternalTracker *InternalTracker `json:"internal_tracker,omitempty"`
  133. // set this structure to use external issue tracker (requires has_issues)
  134. ExternalTracker *ExternalTracker `json:"external_tracker,omitempty"`
  135. // either `true` to enable the wiki for this repository or `false` to disable it.
  136. HasWiki *bool `json:"has_wiki,omitempty"`
  137. // set this structure to use external wiki instead of internal (requires has_wiki)
  138. ExternalWiki *ExternalWiki `json:"external_wiki,omitempty"`
  139. // sets the default branch for this repository.
  140. DefaultBranch *string `json:"default_branch,omitempty"`
  141. // either `true` to allow pull requests, or `false` to prevent pull request.
  142. HasPullRequests *bool `json:"has_pull_requests,omitempty"`
  143. // either `true` to enable project unit, or `false` to disable them.
  144. HasProjects *bool `json:"has_projects,omitempty"`
  145. // either `true` to ignore whitespace for conflicts, or `false` to not ignore whitespace. `has_pull_requests` must be `true`.
  146. IgnoreWhitespaceConflicts *bool `json:"ignore_whitespace_conflicts,omitempty"`
  147. // either `true` to allow merging pull requests with a merge commit, or `false` to prevent merging pull requests with merge commits. `has_pull_requests` must be `true`.
  148. AllowMerge *bool `json:"allow_merge_commits,omitempty"`
  149. // either `true` to allow rebase-merging pull requests, or `false` to prevent rebase-merging. `has_pull_requests` must be `true`.
  150. AllowRebase *bool `json:"allow_rebase,omitempty"`
  151. // either `true` to allow rebase with explicit merge commits (--no-ff), or `false` to prevent rebase with explicit merge commits. `has_pull_requests` must be `true`.
  152. AllowRebaseMerge *bool `json:"allow_rebase_explicit,omitempty"`
  153. // either `true` to allow squash-merging pull requests, or `false` to prevent squash-merging. `has_pull_requests` must be `true`.
  154. AllowSquash *bool `json:"allow_squash_merge,omitempty"`
  155. // set to `true` to archive this repository.
  156. Archived *bool `json:"archived,omitempty"`
  157. }
  158. // CreateBranchRepoOption options when creating a branch in a repository
  159. // swagger:model
  160. type CreateBranchRepoOption struct {
  161. // Name of the branch to create
  162. //
  163. // required: true
  164. // unique: true
  165. BranchName string `json:"new_branch_name" binding:"Required;GitRefName;MaxSize(100)"`
  166. // Name of the old branch to create from
  167. //
  168. // unique: true
  169. OldBranchName string `json:"old_branch_name" binding:"GitRefName;MaxSize(100)"`
  170. }
  171. // TransferRepoOption options when transfer a repository's ownership
  172. // swagger:model
  173. type TransferRepoOption struct {
  174. // required: true
  175. NewOwner string `json:"new_owner"`
  176. // ID of the team or teams to add to the repository. Teams can only be added to organization-owned repositories.
  177. TeamIDs *[]int64 `json:"team_ids"`
  178. }
  179. // GitServiceType represents a git service
  180. type GitServiceType int
  181. // enumerate all GitServiceType
  182. const (
  183. NotMigrated GitServiceType = iota // 0 not migrated from external sites
  184. PlainGitService // 1 plain git service
  185. GithubService // 2 github.com
  186. GiteaService // 3 gitea service
  187. GitlabService // 4 gitlab service
  188. GogsService // 5 gogs service
  189. )
  190. // Name represents the service type's name
  191. // WARNNING: the name have to be equal to that on goth's library
  192. func (gt GitServiceType) Name() string {
  193. return strings.ToLower(gt.Title())
  194. }
  195. // Title represents the service type's proper title
  196. func (gt GitServiceType) Title() string {
  197. switch gt {
  198. case GithubService:
  199. return "GitHub"
  200. case GiteaService:
  201. return "Gitea"
  202. case GitlabService:
  203. return "GitLab"
  204. case GogsService:
  205. return "Gogs"
  206. case PlainGitService:
  207. return "Git"
  208. }
  209. return ""
  210. }
  211. // TokenAuth represents whether a service type supports token-based auth
  212. func (gt GitServiceType) TokenAuth() bool {
  213. switch gt {
  214. case GithubService, GiteaService, GitlabService:
  215. return true
  216. }
  217. return false
  218. }
  219. var (
  220. // SupportedFullGitService represents all git services supported to migrate issues/labels/prs and etc.
  221. // TODO: add to this list after new git service added
  222. SupportedFullGitService = []GitServiceType{
  223. GithubService,
  224. GitlabService,
  225. }
  226. )
  227. // MigrateRepoOption options for migrating a repository from an external service
  228. type MigrateRepoOption struct {
  229. // required: true
  230. CloneAddr string `json:"clone_addr" binding:"Required"`
  231. AuthUsername string `json:"auth_username"`
  232. AuthPassword string `json:"auth_password"`
  233. AuthToken string `json:"auth_token"`
  234. // required: true
  235. UID int `json:"uid" binding:"Required"`
  236. // required: true
  237. RepoName string `json:"repo_name" binding:"Required"`
  238. Mirror bool `json:"mirror"`
  239. Private bool `json:"private"`
  240. Description string `json:"description"`
  241. OriginalURL string
  242. GitServiceType GitServiceType
  243. Wiki bool
  244. Issues bool
  245. Milestones bool
  246. Labels bool
  247. Releases bool
  248. Comments bool
  249. PullRequests bool
  250. MigrateToRepoID int64
  251. }