2016-11-07 21:53:13 +08:00
// Copyright 2014 The Gogs Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2019-05-11 18:21:34 +08:00
package structs
2016-11-07 21:53:13 +08:00
import (
"time"
)
2017-11-13 15:02:25 +08:00
// Permission represents a set of permissions
2016-11-07 21:53:13 +08:00
type Permission struct {
Admin bool ` json:"admin" `
Push bool ` json:"push" `
Pull bool ` json:"pull" `
}
2017-11-13 15:02:25 +08:00
// Repository represents a repository
2016-11-07 21:53:13 +08: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 10:55:54 +08:00
Empty bool ` json:"empty" `
2016-11-07 21:53:13 +08:00
Private bool ` json:"private" `
Fork bool ` json:"fork" `
2017-05-12 11:09:26 +08:00
Parent * Repository ` json:"parent" `
2017-02-23 07:53:33 +08:00
Mirror bool ` json:"mirror" `
2017-05-05 10:55:54 +08:00
Size int ` json:"size" `
2016-11-07 21:53:13 +08:00
HTMLURL string ` json:"html_url" `
SSHURL string ` json:"ssh_url" `
CloneURL string ` json:"clone_url" `
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" `
DefaultBranch string ` json:"default_branch" `
2018-10-29 06:03:02 +08:00
Archived bool ` json:"archived" `
2017-11-13 15:02:25 +08:00
// swagger:strfmt date-time
2018-03-06 09:22:16 +08:00
Created time . Time ` json:"created_at" `
2017-11-13 15:02:25 +08:00
// swagger:strfmt date-time
2018-03-06 09:22:16 +08:00
Updated time . Time ` json:"updated_at" `
Permissions * Permission ` json:"permissions,omitempty" `
2019-05-30 10:22:26 +08:00
AvatarURL string ` json:"avatar_url" `
2016-11-07 21:53:13 +08:00
}
2016-11-29 16:09:17 +08:00
// CreateRepoOption options when creating repository
2017-11-13 15:02:25 +08:00
// swagger:model
2016-11-07 21:53:13 +08:00
type CreateRepoOption struct {
2017-05-02 21:35:59 +08:00
// Name of the repository to create
//
2017-11-13 15:02:25 +08:00
// required: true
2017-05-02 21:35:59 +08:00
// unique: true
Name string ` json:"name" binding:"Required;AlphaDashDot;MaxSize(100)" `
// Description of the repository to create
2016-11-07 21:53:13 +08:00
Description string ` json:"description" binding:"MaxSize(255)" `
2017-11-13 15:02:25 +08:00
// Whether the repository is private
2017-05-02 21:35:59 +08:00
Private bool ` json:"private" `
2017-11-13 15:02:25 +08:00
// Whether the repository should be auto-intialized?
2017-05-02 21:35:59 +08:00
AutoInit bool ` json:"auto_init" `
// Gitignores to use
Gitignores string ` json:"gitignores" `
// License to use
License string ` json:"license" `
// Readme of the repository to create
Readme string ` json:"readme" `
2016-11-07 21:53:13 +08:00
}
2019-05-11 18:21:34 +08:00
// EditRepoOption options when editing a repository's properties
// swagger:model
type EditRepoOption struct {
// Name of the repository
//
// required: true
// unique: true
Name * string ` json:"name" binding:"Required;AlphaDashDot;MaxSize(100)" `
// A short description of the repository.
Description * string ` json:"description,omitempty" binding:"MaxSize(255)" `
// A URL with more information about the repository.
Website * string ` json:"website,omitempty" binding:"MaxSize(255)" `
// 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
// owners and a non-owner tries to change the value of private.
Private * bool ` json:"private,omitempty" `
// Either `true` to enable issues for this repository or `false` to disable them.
EnableIssues * bool ` json:"enable_issues,omitempty" `
// Either `true` to enable the wiki for this repository or `false` to disable it.
EnableWiki * bool ` json:"enable_wiki,omitempty" `
// Updates the default branch for this repository.
DefaultBranch * string ` json:"default_branch,omitempty" `
// Either `true` to allow pull requests, or `false` to prevent pull request.
EnablePullRequests * bool ` json:"enable_pull_requests,omitempty" `
// Either `true` to ignore whitepace for conflicts, or `false` to not ignore whitespace. `enabled_pull_requests` must be `true`.
IgnoreWhitespaceConflicts * bool ` json:"ignore_whitespace,omitempty" `
// Either `true` to allow merging pull requests with a merge commit, or `false` to prevent merging pull requests with merge commits. `enabled_pull_requests` must be `true`.
AllowMerge * bool ` json:"allow_merge_commits,omitempty" `
// Either `true` to allow rebase-merging pull requests, or `false` to prevent rebase-merging. `enabled_pull_requests` must be `true`.
AllowRebase * bool ` json:"allow_rebase,omitempty" `
// Either `true` to allow rebase with explicit merge commits (--no-ff), or `false` to prevent rebase with explicit merge commits. `enabled_pull_requests` must be `true`.
AllowRebaseMerge * bool ` json:"allow_rebase_explicit,omitempty" `
// Either `true` to allow squash-merging pull requests, or `false` to prevent squash-merging. `enabled_pull_requests` must be `true`.
AllowSquashMerge * bool ` json:"allow_squash_merge,omitempty" `
// `true` to archive this repository. Note: You cannot unarchive repositories through the API.
Archived * bool ` json:"archived,omitempty" `
2016-11-07 21:53:13 +08:00
}
2017-11-13 15:02:25 +08:00
// MigrateRepoOption options for migrating a repository from an external service
2016-11-07 21:53:13 +08:00
type MigrateRepoOption struct {
2017-11-13 15:02:25 +08:00
// required: true
2018-03-06 09:22:16 +08:00
CloneAddr string ` json:"clone_addr" binding:"Required" `
2016-11-07 21:53:13 +08:00
AuthUsername string ` json:"auth_username" `
AuthPassword string ` json:"auth_password" `
2017-11-13 15:02:25 +08:00
// required: true
2017-08-21 19:13:47 +08:00
UID int ` json:"uid" binding:"Required" `
2017-11-13 15:02:25 +08:00
// required: true
2018-03-06 09:22:16 +08:00
RepoName string ` json:"repo_name" binding:"Required" `
Mirror bool ` json:"mirror" `
Private bool ` json:"private" `
2017-08-21 19:13:47 +08:00
Description string ` json:"description" `
2016-11-07 21:53:13 +08:00
}