mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 12:53:43 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			100 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// 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"`
 | 
						|
}
 |