mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 20:11:02 +00:00 
			
		
		
		
	#16205 To obtain a closer behavior to the api from github, the status (added, modified, removed) of a file should be available in addition to the filename. See github doc : https://docs.github.com/fr/rest/commits/commits?apiVersion=2022-11-28#get-a-commit
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			2.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 string `json:"name" binding:"MaxSize(100)"`
 | |
| 	// swagger:strfmt email
 | |
| 	Email string `json:"email" binding:"MaxSize(254)"`
 | |
| }
 | |
| 
 | |
| // CommitMeta contains meta information of a commit in terms of API.
 | |
| type CommitMeta struct {
 | |
| 	URL string `json:"url"`
 | |
| 	SHA string `json:"sha"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	Created time.Time `json:"created"`
 | |
| }
 | |
| 
 | |
| // CommitUser contains information of a user in the context of a commit.
 | |
| type CommitUser struct {
 | |
| 	Identity
 | |
| 	Date string `json:"date"`
 | |
| }
 | |
| 
 | |
| // RepoCommit contains information of a commit in the context of a repository.
 | |
| type RepoCommit struct {
 | |
| 	URL          string                     `json:"url"`
 | |
| 	Author       *CommitUser                `json:"author"`
 | |
| 	Committer    *CommitUser                `json:"committer"`
 | |
| 	Message      string                     `json:"message"`
 | |
| 	Tree         *CommitMeta                `json:"tree"`
 | |
| 	Verification *PayloadCommitVerification `json:"verification"`
 | |
| }
 | |
| 
 | |
| // CommitStats is statistics for a RepoCommit
 | |
| type CommitStats struct {
 | |
| 	Total     int `json:"total"`
 | |
| 	Additions int `json:"additions"`
 | |
| 	Deletions int `json:"deletions"`
 | |
| }
 | |
| 
 | |
| // Commit contains information generated from a Git commit.
 | |
| type Commit struct {
 | |
| 	*CommitMeta
 | |
| 	HTMLURL    string                 `json:"html_url"`
 | |
| 	RepoCommit *RepoCommit            `json:"commit"`
 | |
| 	Author     *User                  `json:"author"`
 | |
| 	Committer  *User                  `json:"committer"`
 | |
| 	Parents    []*CommitMeta          `json:"parents"`
 | |
| 	Files      []*CommitAffectedFiles `json:"files"`
 | |
| 	Stats      *CommitStats           `json:"stats"`
 | |
| }
 | |
| 
 | |
| // CommitDateOptions store dates for GIT_AUTHOR_DATE and GIT_COMMITTER_DATE
 | |
| type CommitDateOptions struct {
 | |
| 	// swagger:strfmt date-time
 | |
| 	Author time.Time `json:"author"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	Committer time.Time `json:"committer"`
 | |
| }
 | |
| 
 | |
| // CommitAffectedFiles store information about files affected by the commit
 | |
| type CommitAffectedFiles struct {
 | |
| 	Filename string `json:"filename"`
 | |
| 	Status   string `json:"status"`
 | |
| }
 |