2016-11-07 16:53:13 +03:00
// Copyright 2014 The Gogs Authors. All rights reserved.
2019-03-22 18:38:49 +03:00
// Copyright 2019 The Gitea Authors. All rights reserved.
2016-11-07 16:53:13 +03:00
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2019-05-11 13:21:34 +03:00
package structs
2019-03-22 18:38:49 +03:00
// FileOptions options for all file APIs
type FileOptions struct {
2019-05-30 20:57:55 +03:00
// message (optional) for the commit of this file. if not supplied, a default message will be used
2019-06-29 18:19:24 +03:00
Message string ` json:"message" `
2019-05-30 20:57:55 +03:00
// branch (optional) to base this file from. if not given, the default branch is used
2019-08-05 23:39:39 +03:00
BranchName string ` json:"branch" binding:"GitRefName;MaxSize(100)" `
2019-05-30 20:57:55 +03:00
// new_branch (optional) will make a new branch from `branch` before creating the file
2019-08-05 23:39:39 +03:00
NewBranchName string ` json:"new_branch" binding:"GitRefName;MaxSize(100)" `
2019-05-30 20:57:55 +03:00
// `author` and `committer` are optional (if only one is given, it will be used for the other, otherwise the authenticated user will be used)
2019-12-24 05:33:52 +03:00
Author Identity ` json:"author" `
Committer Identity ` json:"committer" `
Dates CommitDateOptions ` json:"dates" `
2021-01-29 11:57:45 +03:00
// Add a Signed-off-by trailer by the committer at the end of the commit log message.
Signoff bool ` json:"signoff" `
2019-03-22 18:38:49 +03:00
}
// CreateFileOptions options for creating files
2019-05-30 20:57:55 +03:00
// Note: `author` and `committer` are optional (if only one is given, it will be used for the other, otherwise the authenticated user will be used)
2019-03-22 18:38:49 +03:00
type CreateFileOptions struct {
FileOptions
2019-05-30 20:57:55 +03:00
// content must be base64 encoded
// required: true
2019-03-22 18:38:49 +03:00
Content string ` json:"content" `
}
// DeleteFileOptions options for deleting files (used for other File structs below)
2019-05-30 20:57:55 +03:00
// Note: `author` and `committer` are optional (if only one is given, it will be used for the other, otherwise the authenticated user will be used)
2019-03-22 18:38:49 +03:00
type DeleteFileOptions struct {
FileOptions
2019-05-30 20:57:55 +03:00
// sha is the SHA for the file that already exists
// required: true
2019-03-22 18:38:49 +03:00
SHA string ` json:"sha" binding:"Required" `
}
// UpdateFileOptions options for updating files
2019-05-30 20:57:55 +03:00
// Note: `author` and `committer` are optional (if only one is given, it will be used for the other, otherwise the authenticated user will be used)
2019-03-22 18:38:49 +03:00
type UpdateFileOptions struct {
DeleteFileOptions
2019-05-30 20:57:55 +03:00
// content must be base64 encoded
// required: true
Content string ` json:"content" `
// from_path (optional) is the path of the original file which will be moved/renamed to the path in the URL
2019-03-22 18:38:49 +03:00
FromPath string ` json:"from_path" binding:"MaxSize(500)" `
}
// FileLinksResponse contains the links for a repo's file
type FileLinksResponse struct {
2019-06-29 23:51:10 +03:00
Self * string ` json:"self" `
GitURL * string ` json:"git" `
HTMLURL * string ` json:"html" `
2019-03-22 18:38:49 +03:00
}
2019-06-29 23:51:10 +03:00
// ContentsResponse contains information about a repo's entry's (dir, file, symlink, submodule) metadata and content
type ContentsResponse struct {
Name string ` json:"name" `
Path string ` json:"path" `
SHA string ` json:"sha" `
// `type` will be `file`, `dir`, `symlink`, or `submodule`
Type string ` json:"type" `
Size int64 ` json:"size" `
// `encoding` is populated when `type` is `file`, otherwise null
Encoding * string ` json:"encoding" `
// `content` is populated when `type` is `file`, otherwise null
Content * string ` json:"content" `
// `target` is populated when `type` is `symlink`, otherwise null
Target * string ` json:"target" `
URL * string ` json:"url" `
HTMLURL * string ` json:"html_url" `
GitURL * string ` json:"git_url" `
DownloadURL * string ` json:"download_url" `
// `submodule_git_url` is populated when `type` is `submodule`, otherwise null
SubmoduleGitURL * string ` json:"submodule_git_url" `
Links * FileLinksResponse ` json:"_links" `
2019-03-22 18:38:49 +03:00
}
// FileCommitResponse contains information generated from a Git commit for a repo's file.
type FileCommitResponse struct {
CommitMeta
HTMLURL string ` json:"html_url" `
Author * CommitUser ` json:"author" `
Committer * CommitUser ` json:"committer" `
Parents [ ] * CommitMeta ` json:"parents" `
Message string ` json:"message" `
Tree * CommitMeta ` json:"tree" `
}
// FileResponse contains information about a repo's file
type FileResponse struct {
2019-06-29 23:51:10 +03:00
Content * ContentsResponse ` json:"content" `
2019-03-22 18:38:49 +03:00
Commit * FileCommitResponse ` json:"commit" `
Verification * PayloadCommitVerification ` json:"verification" `
}
// FileDeleteResponse contains information about a repo's file that was deleted
type FileDeleteResponse struct {
Content interface { } ` json:"content" ` // to be set to nil
Commit * FileCommitResponse ` json:"commit" `
Verification * PayloadCommitVerification ` json:"verification" `
}