mirror of https://github.com/go-gitea/gitea.git
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.
99 lines
3.2 KiB
99 lines
3.2 KiB
// Copyright 2018 The Gogs Authors. All rights reserved. |
|
// Copyright 2019 The Gitea Authors. All rights reserved. |
|
// SPDX-License-Identifier: MIT |
|
|
|
package structs |
|
|
|
import ( |
|
"time" |
|
) |
|
|
|
// Identity for a person's identity like an author or committer |
|
type Identity struct { |
|
// Name is the person's name |
|
Name string `json:"name" binding:"MaxSize(100)"` |
|
// swagger:strfmt email |
|
// Email is the person's email address |
|
Email string `json:"email" binding:"MaxSize(254)"` |
|
} |
|
|
|
// CommitMeta contains meta information of a commit in terms of API. |
|
type CommitMeta struct { |
|
// URL is the API URL for the commit |
|
URL string `json:"url"` |
|
// SHA is the commit SHA hash |
|
SHA string `json:"sha"` |
|
// swagger:strfmt date-time |
|
// Created is the time when the commit was created |
|
Created time.Time `json:"created"` |
|
} |
|
|
|
// CommitUser contains information of a user in the context of a commit. |
|
type CommitUser struct { |
|
Identity |
|
// Date is the commit date in string format |
|
Date string `json:"date"` |
|
} |
|
|
|
// RepoCommit contains information of a commit in the context of a repository. |
|
type RepoCommit struct { |
|
// URL is the API URL for the commit |
|
URL string `json:"url"` |
|
// Author contains the commit author information |
|
Author *CommitUser `json:"author"` |
|
// Committer contains the commit committer information |
|
Committer *CommitUser `json:"committer"` |
|
// Message is the commit message |
|
Message string `json:"message"` |
|
// Tree contains the tree information for the commit |
|
Tree *CommitMeta `json:"tree"` |
|
// Verification contains commit signature verification information |
|
Verification *PayloadCommitVerification `json:"verification"` |
|
} |
|
|
|
// CommitStats is statistics for a RepoCommit |
|
type CommitStats struct { |
|
// Total is the total number of lines changed |
|
Total int `json:"total"` |
|
// Additions is the number of lines added |
|
Additions int `json:"additions"` |
|
// Deletions is the number of lines deleted |
|
Deletions int `json:"deletions"` |
|
} |
|
|
|
// Commit contains information generated from a Git commit. |
|
type Commit struct { |
|
*CommitMeta |
|
// HTMLURL is the web URL for viewing the commit |
|
HTMLURL string `json:"html_url"` |
|
// RepoCommit contains the commit information |
|
RepoCommit *RepoCommit `json:"commit"` |
|
// Author is the GitHub/Gitea user who authored the commit |
|
Author *User `json:"author"` |
|
// Committer is the GitHub/Gitea user who committed the commit |
|
Committer *User `json:"committer"` |
|
// Parents contains the parent commit information |
|
Parents []*CommitMeta `json:"parents"` |
|
// Files contains information about files affected by the commit |
|
Files []*CommitAffectedFiles `json:"files"` |
|
// Stats contains statistics about the commit changes |
|
Stats *CommitStats `json:"stats"` |
|
} |
|
|
|
// CommitDateOptions store dates for GIT_AUTHOR_DATE and GIT_COMMITTER_DATE |
|
type CommitDateOptions struct { |
|
// swagger:strfmt date-time |
|
// Author is the author date for the commit |
|
Author time.Time `json:"author"` |
|
// swagger:strfmt date-time |
|
// Committer is the committer date for the commit |
|
Committer time.Time `json:"committer"` |
|
} |
|
|
|
// CommitAffectedFiles store information about files affected by the commit |
|
type CommitAffectedFiles struct { |
|
// Filename is the path of the affected file |
|
Filename string `json:"filename"` |
|
// Status indicates how the file was affected (added, modified, deleted) |
|
Status string `json:"status"` |
|
}
|
|
|