2016-11-07 16:53:13 +03:00
// Copyright 2014 The Gogs Authors. All rights reserved.
2022-11-27 21:20:29 +03:00
// SPDX-License-Identifier: MIT
2016-11-07 16:53:13 +03:00
2019-05-11 13:21:34 +03:00
package structs
2016-11-07 16:53:13 +03:00
import (
2020-09-09 21:29:10 +03:00
"strings"
2016-11-07 16:53:13 +03:00
"time"
)
2017-11-13 10:02:25 +03:00
// Permission represents a set of permissions
2016-11-07 16:53:13 +03:00
type Permission struct {
2023-06-22 16:08:08 +03:00
Admin bool ` json:"admin" ` // Admin indicates if the user is an administrator of the repository.
Push bool ` json:"push" ` // Push indicates if the user can push code to the repository.
Pull bool ` json:"pull" ` // Pull indicates if the user can pull code from the repository.
2016-11-07 16:53:13 +03:00
}
2019-10-02 12:30:41 +03:00
// InternalTracker represents settings for internal tracker
// swagger:model
type InternalTracker struct {
// Enable time tracking (Built-in issue tracker)
EnableTimeTracker bool ` json:"enable_time_tracker" `
// Let only contributors track time (Built-in issue tracker)
AllowOnlyContributorsToTrackTime bool ` json:"allow_only_contributors_to_track_time" `
// Enable dependencies for issues and pull requests (Built-in issue tracker)
EnableIssueDependencies bool ` json:"enable_issue_dependencies" `
}
// ExternalTracker represents settings for external tracker
// swagger:model
type ExternalTracker struct {
// URL of external issue tracker.
ExternalTrackerURL string ` json:"external_tracker_url" `
// External Issue Tracker URL Format. Use the placeholders {user}, {repo} and {index} for the username, repository name and issue index.
ExternalTrackerFormat string ` json:"external_tracker_format" `
2022-10-07 15:49:30 +03:00
// External Issue Tracker Number Format, either `numeric`, `alphanumeric`, or `regexp`
2019-10-02 12:30:41 +03:00
ExternalTrackerStyle string ` json:"external_tracker_style" `
2022-10-07 15:49:30 +03:00
// External Issue Tracker issue regular expression
ExternalTrackerRegexpPattern string ` json:"external_tracker_regexp_pattern" `
2019-10-02 12:30:41 +03:00
}
// ExternalWiki represents setting for external wiki
// swagger:model
type ExternalWiki struct {
// URL of external wiki.
ExternalWikiURL string ` json:"external_wiki_url" `
}
2017-11-13 10:02:25 +03:00
// Repository represents a repository
2016-11-07 16:53:13 +03:00
type Repository struct {
ID int64 ` json:"id" `
Owner * User ` json:"owner" `
Name string ` json:"name" `
FullName string ` json:"full_name" `
Description string ` json:"description" `
2017-05-05 05:55:54 +03:00
Empty bool ` json:"empty" `
2016-11-07 16:53:13 +03:00
Private bool ` json:"private" `
Fork bool ` json:"fork" `
2019-11-11 18:15:29 +03:00
Template bool ` json:"template" `
2017-05-12 06:09:26 +03:00
Parent * Repository ` json:"parent" `
2017-02-23 02:53:33 +03:00
Mirror bool ` json:"mirror" `
2017-05-05 05:55:54 +03:00
Size int ` json:"size" `
2022-01-25 09:33:40 +03:00
Language string ` json:"language" `
LanguagesURL string ` json:"languages_url" `
2016-11-07 16:53:13 +03:00
HTMLURL string ` json:"html_url" `
2023-09-24 22:02:47 +03:00
URL string ` json:"url" `
2023-02-06 21:09:18 +03:00
Link string ` json:"link" `
2016-11-07 16:53:13 +03:00
SSHURL string ` json:"ssh_url" `
CloneURL string ` json:"clone_url" `
2019-07-08 05:14:12 +03:00
OriginalURL string ` json:"original_url" `
2016-11-07 16:53:13 +03:00
Website string ` json:"website" `
Stars int ` json:"stars_count" `
Forks int ` json:"forks_count" `
Watchers int ` json:"watchers_count" `
OpenIssues int ` json:"open_issues_count" `
2019-11-29 18:14:24 +03:00
OpenPulls int ` json:"open_pr_counter" `
2019-11-30 22:28:47 +03:00
Releases int ` json:"release_counter" `
2016-11-07 16:53:13 +03:00
DefaultBranch string ` json:"default_branch" `
2018-10-29 01:03:02 +03:00
Archived bool ` json:"archived" `
2017-11-13 10:02:25 +03:00
// swagger:strfmt date-time
2018-03-06 04:22:16 +03:00
Created time . Time ` json:"created_at" `
2017-11-13 10:02:25 +03:00
// swagger:strfmt date-time
2022-07-15 11:00:01 +03:00
Updated time . Time ` json:"updated_at" `
2023-04-26 17:46:26 +03:00
ArchivedAt time . Time ` json:"archived_at" `
2022-07-15 11:00:01 +03:00
Permissions * Permission ` json:"permissions,omitempty" `
HasIssues bool ` json:"has_issues" `
InternalTracker * InternalTracker ` json:"internal_tracker,omitempty" `
ExternalTracker * ExternalTracker ` json:"external_tracker,omitempty" `
HasWiki bool ` json:"has_wiki" `
ExternalWiki * ExternalWiki ` json:"external_wiki,omitempty" `
HasPullRequests bool ` json:"has_pull_requests" `
HasProjects bool ` json:"has_projects" `
2024-03-04 05:56:52 +03:00
ProjectsMode string ` json:"projects_mode" `
2023-03-16 20:30:42 +03:00
HasReleases bool ` json:"has_releases" `
HasPackages bool ` json:"has_packages" `
HasActions bool ` json:"has_actions" `
2022-07-15 11:00:01 +03:00
IgnoreWhitespaceConflicts bool ` json:"ignore_whitespace_conflicts" `
AllowMerge bool ` json:"allow_merge_commits" `
AllowRebase bool ` json:"allow_rebase" `
AllowRebaseMerge bool ` json:"allow_rebase_explicit" `
AllowSquash bool ` json:"allow_squash_merge" `
2024-02-13 01:37:23 +03:00
AllowFastForwardOnly bool ` json:"allow_fast_forward_only_merge" `
2022-07-15 11:00:01 +03:00
AllowRebaseUpdate bool ` json:"allow_rebase_update" `
DefaultDeleteBranchAfterMerge bool ` json:"default_delete_branch_after_merge" `
DefaultMergeStyle string ` json:"default_merge_style" `
2023-02-13 09:09:52 +03:00
DefaultAllowMaintainerEdit bool ` json:"default_allow_maintainer_edit" `
2022-07-15 11:00:01 +03:00
AvatarURL string ` json:"avatar_url" `
Internal bool ` json:"internal" `
MirrorInterval string ` json:"mirror_interval" `
2024-01-19 19:05:02 +03:00
// ObjectFormatName of the underlying git repository
// enum: sha1,sha256
ObjectFormatName string ` json:"object_format_name" `
2022-01-18 16:18:30 +03:00
// swagger:strfmt date-time
MirrorUpdated time . Time ` json:"mirror_updated,omitempty" `
RepoTransfer * RepoTransfer ` json:"repo_transfer" `
2024-05-28 13:03:54 +03:00
Topics [ ] string ` json:"topics" `
2024-10-01 22:25:08 +03:00
Licenses [ ] string ` json:"licenses" `
2016-11-07 16:53:13 +03:00
}
2016-11-29 11:09:17 +03:00
// CreateRepoOption options when creating repository
2017-11-13 10:02:25 +03:00
// swagger:model
2016-11-07 16:53:13 +03:00
type CreateRepoOption struct {
2017-05-02 16:35:59 +03:00
// Name of the repository to create
//
2017-11-13 10:02:25 +03:00
// required: true
2017-05-02 16:35:59 +03:00
// unique: true
Name string ` json:"name" binding:"Required;AlphaDashDot;MaxSize(100)" `
// Description of the repository to create
2022-09-16 10:19:16 +03:00
Description string ` json:"description" binding:"MaxSize(2048)" `
2017-11-13 10:02:25 +03:00
// Whether the repository is private
2017-05-02 16:35:59 +03:00
Private bool ` json:"private" `
2021-01-18 23:00:50 +03:00
// Label-Set to use
2019-09-08 11:28:40 +03:00
IssueLabels string ` json:"issue_labels" `
2022-01-10 12:32:37 +03:00
// Whether the repository should be auto-initialized?
2017-05-02 16:35:59 +03:00
AutoInit bool ` json:"auto_init" `
2020-09-25 08:18:37 +03:00
// Whether the repository is template
Template bool ` json:"template" `
2017-05-02 16:35:59 +03:00
// Gitignores to use
Gitignores string ` json:"gitignores" `
// License to use
License string ` json:"license" `
// Readme of the repository to create
Readme string ` json:"readme" `
2020-03-26 22:14:51 +03:00
// DefaultBranch of the repository (used when initializes and in template)
DefaultBranch string ` json:"default_branch" binding:"GitRefName;MaxSize(100)" `
2020-09-19 19:44:55 +03:00
// TrustModel of the repository
// enum: default,collaborator,committer,collaboratorcommitter
TrustModel string ` json:"trust_model" `
2024-01-19 19:05:02 +03:00
// ObjectFormatName of the underlying git repository
// enum: sha1,sha256
ObjectFormatName string ` json:"object_format_name" binding:"MaxSize(6)" `
2016-11-07 16:53:13 +03:00
}
2019-05-11 13:21:34 +03:00
// EditRepoOption options when editing a repository's properties
// swagger:model
type EditRepoOption struct {
2019-05-30 18:09:05 +03:00
// name of the repository
2019-05-11 13:21:34 +03:00
// unique: true
2019-05-30 18:09:05 +03:00
Name * string ` json:"name,omitempty" binding:"OmitEmpty;AlphaDashDot;MaxSize(100);" `
// a short description of the repository.
2022-09-16 10:19:16 +03:00
Description * string ` json:"description,omitempty" binding:"MaxSize(2048)" `
2019-05-30 18:09:05 +03:00
// a URL with more information about the repository.
2022-09-16 10:19:16 +03:00
Website * string ` json:"website,omitempty" binding:"MaxSize(1024)" `
2019-05-30 18:09:05 +03:00
// either `true` to make the repository private or `false` to make it public.
// Note: you will get a 422 error if the organization restricts changing repository visibility to organization
2019-05-11 13:21:34 +03:00
// owners and a non-owner tries to change the value of private.
Private * bool ` json:"private,omitempty" `
2019-11-11 18:15:29 +03:00
// either `true` to make this repository a template or `false` to make it a normal repository
Template * bool ` json:"template,omitempty" `
2019-05-30 18:09:05 +03:00
// either `true` to enable issues for this repository or `false` to disable them.
HasIssues * bool ` json:"has_issues,omitempty" `
2022-09-28 01:23:58 +03:00
// set this structure to configure internal issue tracker
2019-10-02 12:30:41 +03:00
InternalTracker * InternalTracker ` json:"internal_tracker,omitempty" `
2022-09-28 01:23:58 +03:00
// set this structure to use external issue tracker
2019-10-02 12:30:41 +03:00
ExternalTracker * ExternalTracker ` json:"external_tracker,omitempty" `
2019-05-30 18:09:05 +03:00
// either `true` to enable the wiki for this repository or `false` to disable it.
HasWiki * bool ` json:"has_wiki,omitempty" `
2022-09-28 01:23:58 +03:00
// set this structure to use external wiki instead of internal
2019-10-02 12:30:41 +03:00
ExternalWiki * ExternalWiki ` json:"external_wiki,omitempty" `
2019-05-30 18:09:05 +03:00
// sets the default branch for this repository.
2019-05-11 13:21:34 +03:00
DefaultBranch * string ` json:"default_branch,omitempty" `
2019-05-30 18:09:05 +03:00
// either `true` to allow pull requests, or `false` to prevent pull request.
HasPullRequests * bool ` json:"has_pull_requests,omitempty" `
2020-08-17 06:07:38 +03:00
// either `true` to enable project unit, or `false` to disable them.
HasProjects * bool ` json:"has_projects,omitempty" `
2024-03-04 05:56:52 +03:00
// `repo` to only allow repo-level projects, `owner` to only allow owner projects, `all` to allow both.
ProjectsMode * string ` json:"projects_mode,omitempty" binding:"In(repo,owner,all)" `
2023-03-16 20:30:42 +03:00
// either `true` to enable releases unit, or `false` to disable them.
HasReleases * bool ` json:"has_releases,omitempty" `
// either `true` to enable packages unit, or `false` to disable them.
HasPackages * bool ` json:"has_packages,omitempty" `
// either `true` to enable actions unit, or `false` to disable them.
HasActions * bool ` json:"has_actions,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to ignore whitespace for conflicts, or `false` to not ignore whitespace.
2019-05-30 18:09:05 +03:00
IgnoreWhitespaceConflicts * bool ` json:"ignore_whitespace_conflicts,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to allow merging pull requests with a merge commit, or `false` to prevent merging pull requests with merge commits.
2019-05-11 13:21:34 +03:00
AllowMerge * bool ` json:"allow_merge_commits,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to allow rebase-merging pull requests, or `false` to prevent rebase-merging.
2019-05-11 13:21:34 +03:00
AllowRebase * bool ` json:"allow_rebase,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to allow rebase with explicit merge commits (--no-ff), or `false` to prevent rebase with explicit merge commits.
2019-05-11 13:21:34 +03:00
AllowRebaseMerge * bool ` json:"allow_rebase_explicit,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to allow squash-merging pull requests, or `false` to prevent squash-merging.
2019-05-30 18:09:05 +03:00
AllowSquash * bool ` json:"allow_squash_merge,omitempty" `
2024-02-13 01:37:23 +03:00
// either `true` to allow fast-forward-only merging pull requests, or `false` to prevent fast-forward-only merging.
AllowFastForwardOnly * bool ` json:"allow_fast_forward_only_merge,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to allow mark pr as merged manually, or `false` to prevent it.
2021-03-04 06:41:23 +03:00
AllowManualMerge * bool ` json:"allow_manual_merge,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to enable AutodetectManualMerge, or `false` to prevent it. Note: In some special cases, misjudgments can occur.
2021-03-04 06:41:23 +03:00
AutodetectManualMerge * bool ` json:"autodetect_manual_merge,omitempty" `
2022-09-28 01:23:58 +03:00
// either `true` to allow updating pull request branch by rebase, or `false` to prevent it.
2022-03-04 11:30:49 +03:00
AllowRebaseUpdate * bool ` json:"allow_rebase_update,omitempty" `
2021-07-13 02:26:25 +03:00
// set to `true` to delete pr branch after merge by default
DefaultDeleteBranchAfterMerge * bool ` json:"default_delete_branch_after_merge,omitempty" `
2024-02-13 01:37:23 +03:00
// set to a merge style to be used by this repository: "merge", "rebase", "rebase-merge", "squash", or "fast-forward-only".
2021-03-27 17:55:40 +03:00
DefaultMergeStyle * string ` json:"default_merge_style,omitempty" `
2023-02-13 09:09:52 +03:00
// set to `true` to allow edits from maintainers by default
DefaultAllowMaintainerEdit * bool ` json:"default_allow_maintainer_edit,omitempty" `
2019-05-30 18:09:05 +03:00
// set to `true` to archive this repository.
2019-05-11 13:21:34 +03:00
Archived * bool ` json:"archived,omitempty" `
2021-01-03 02:47:47 +03:00
// set to a string like `8h30m0s` to set the mirror interval time
MirrorInterval * string ` json:"mirror_interval,omitempty" `
2024-05-17 19:07:41 +03:00
// enable prune - remove obsolete remote-tracking references when mirroring
2022-04-20 11:20:53 +03:00
EnablePrune * bool ` json:"enable_prune,omitempty" `
2016-11-07 16:53:13 +03:00
}
2021-07-05 18:29:08 +03:00
// GenerateRepoOption options when creating repository using a template
// swagger:model
type GenerateRepoOption struct {
// The organization or person who will own the new repository
//
// required: true
Owner string ` json:"owner" `
// Name of the repository to create
//
// required: true
// unique: true
Name string ` json:"name" binding:"Required;AlphaDashDot;MaxSize(100)" `
2022-03-27 05:56:28 +03:00
// Default branch of the new repository
DefaultBranch string ` json:"default_branch" `
2021-07-05 18:29:08 +03:00
// Description of the repository to create
2022-09-16 10:19:16 +03:00
Description string ` json:"description" binding:"MaxSize(2048)" `
2021-07-05 18:29:08 +03:00
// Whether the repository is private
Private bool ` json:"private" `
// include git content of default branch in template repo
GitContent bool ` json:"git_content" `
// include topics in template repo
Topics bool ` json:"topics" `
// include git hooks in template repo
GitHooks bool ` json:"git_hooks" `
// include webhooks in template repo
Webhooks bool ` json:"webhooks" `
// include avatar of the template repo
Avatar bool ` json:"avatar" `
// include labels in template repo
Labels bool ` json:"labels" `
2023-07-21 07:32:47 +03:00
// include protected branches in template repo
ProtectedBranch bool ` json:"protected_branch" `
2021-07-05 18:29:08 +03:00
}
2020-05-29 21:16:20 +03:00
// CreateBranchRepoOption options when creating a branch in a repository
// swagger:model
type CreateBranchRepoOption struct {
// Name of the branch to create
//
// required: true
// unique: true
BranchName string ` json:"new_branch_name" binding:"Required;GitRefName;MaxSize(100)" `
2023-05-09 13:22:32 +03:00
// Deprecated: true
2020-05-29 21:16:20 +03:00
// Name of the old branch to create from
//
// unique: true
OldBranchName string ` json:"old_branch_name" binding:"GitRefName;MaxSize(100)" `
2023-05-09 13:22:32 +03:00
// Name of the old branch/tag/commit to create from
//
// unique: true
OldRefName string ` json:"old_ref_name" binding:"GitRefName;MaxSize(100)" `
2020-05-29 21:16:20 +03:00
}
2020-01-31 18:49:04 +03:00
// TransferRepoOption options when transfer a repository's ownership
// swagger:model
type TransferRepoOption struct {
// required: true
NewOwner string ` json:"new_owner" `
// ID of the team or teams to add to the repository. Teams can only be added to organization-owned repositories.
TeamIDs * [ ] int64 ` json:"team_ids" `
}
2019-10-14 09:10:42 +03:00
// GitServiceType represents a git service
type GitServiceType int
// enumerate all GitServiceType
const (
2024-09-11 02:49:42 +03:00
NotMigrated GitServiceType = iota // 0 not migrated from external sites
PlainGitService // 1 plain git service
GithubService // 2 github.com
GiteaService // 3 gitea service
GitlabService // 4 gitlab service
GogsService // 5 gogs service
OneDevService // 6 onedev service
GitBucketService // 7 gitbucket service
CodebaseService // 8 codebase service
CodeCommitService // 9 codecommit service
2019-10-14 09:10:42 +03:00
)
// Name represents the service type's name
// WARNNING: the name have to be equal to that on goth's library
func ( gt GitServiceType ) Name ( ) string {
2020-09-09 21:29:10 +03:00
return strings . ToLower ( gt . Title ( ) )
2019-10-14 09:10:42 +03:00
}
2020-08-28 04:36:37 +03:00
// Title represents the service type's proper title
func ( gt GitServiceType ) Title ( ) string {
switch gt {
case GithubService :
return "GitHub"
case GiteaService :
return "Gitea"
case GitlabService :
return "GitLab"
case GogsService :
return "Gogs"
2021-08-22 01:47:45 +03:00
case OneDevService :
return "OneDev"
2021-11-14 22:11:10 +03:00
case GitBucketService :
return "GitBucket"
2021-12-03 01:24:02 +03:00
case CodebaseService :
return "Codebase"
2024-09-11 02:49:42 +03:00
case CodeCommitService :
return "CodeCommit"
2020-08-28 04:36:37 +03:00
case PlainGitService :
return "Git"
}
return ""
}
2020-09-11 01:29:19 +03:00
// MigrateRepoOptions options for migrating repository's
// this is used to interact with api v1
type MigrateRepoOptions struct {
// required: true
CloneAddr string ` json:"clone_addr" binding:"Required" `
// deprecated (only for backwards compatibility)
RepoOwnerID int64 ` json:"uid" `
// Name of User or Organisation who will own Repo after migration
RepoOwner string ` json:"repo_owner" `
// required: true
RepoName string ` json:"repo_name" binding:"Required;AlphaDashDot;MaxSize(100)" `
2023-07-20 20:28:38 +03:00
// enum: git,github,gitea,gitlab,gogs,onedev,gitbucket,codebase
2020-09-11 01:29:19 +03:00
Service string ` json:"service" `
AuthUsername string ` json:"auth_username" `
AuthPassword string ` json:"auth_password" `
AuthToken string ` json:"auth_token" `
2021-01-03 02:47:47 +03:00
Mirror bool ` json:"mirror" `
2021-04-09 01:25:57 +03:00
LFS bool ` json:"lfs" `
LFSEndpoint string ` json:"lfs_endpoint" `
2021-01-03 02:47:47 +03:00
Private bool ` json:"private" `
2022-09-16 10:19:16 +03:00
Description string ` json:"description" binding:"MaxSize(2048)" `
2021-01-03 02:47:47 +03:00
Wiki bool ` json:"wiki" `
Milestones bool ` json:"milestones" `
Labels bool ` json:"labels" `
Issues bool ` json:"issues" `
PullRequests bool ` json:"pull_requests" `
Releases bool ` json:"releases" `
MirrorInterval string ` json:"mirror_interval" `
2024-09-11 02:49:42 +03:00
AWSAccessKeyID string ` json:"aws_access_key_id" `
AWSSecretAccessKey string ` json:"aws_secret_access_key" `
2020-09-11 01:29:19 +03:00
}
2020-08-28 04:36:37 +03:00
// TokenAuth represents whether a service type supports token-based auth
func ( gt GitServiceType ) TokenAuth ( ) bool {
switch gt {
case GithubService , GiteaService , GitlabService :
return true
}
return false
}
2022-01-20 20:46:10 +03:00
// SupportedFullGitService represents all git services supported to migrate issues/labels/prs and etc.
// TODO: add to this list after new git service added
var SupportedFullGitService = [ ] GitServiceType {
GithubService ,
GitlabService ,
GiteaService ,
GogsService ,
OneDevService ,
GitBucketService ,
CodebaseService ,
2024-09-11 02:49:42 +03:00
CodeCommitService ,
2022-01-20 20:46:10 +03:00
}
2021-12-24 07:26:52 +03:00
// RepoTransfer represents a pending repo transfer
type RepoTransfer struct {
Doer * User ` json:"doer" `
Recipient * User ` json:"recipient" `
Teams [ ] * Team ` json:"teams" `
}
2023-05-25 16:17:19 +03:00
// NewIssuePinsAllowed represents an API response that says if new Issue Pins are allowed
type NewIssuePinsAllowed struct {
Issues bool ` json:"issues" `
PullRequests bool ` json:"pull_requests" `
}
2023-06-30 02:22:55 +03:00
// UpdateRepoAvatarUserOption options when updating the repo avatar
type UpdateRepoAvatarOption struct {
// image must be base64 encoded
Image string ` json:"image" binding:"Required" `
}