2016-11-03 23:16:01 +01:00
// Copyright 2015 The Gogs Authors. All rights reserved.
2019-04-19 14:17:27 +02:00
// Copyright 2019 The Gitea Authors. All rights reserved.
2022-11-27 13:20:29 -05:00
// SPDX-License-Identifier: MIT
2016-11-03 23:16:01 +01:00
package git
import (
"encoding/hex"
"fmt"
2020-04-08 04:54:46 +02:00
"regexp"
2016-11-03 23:16:01 +01:00
"strings"
)
2016-12-22 17:30:52 +08:00
// EmptySHA defines empty git SHA
const EmptySHA = "0000000000000000000000000000000000000000"
2016-11-03 23:16:01 +01:00
2020-05-29 22:14:00 +01:00
// EmptyTreeSHA is the SHA of an empty tree
const EmptyTreeSHA = "4b825dc642cb6eb9a060e54bf8d69288fbee4904"
2022-12-27 21:12:49 +08:00
// SHAFullLength is the full length of a git SHA
const SHAFullLength = 40
2020-04-08 04:54:46 +02:00
// SHAPattern can be used to determine if a string is an valid sha
2022-09-04 11:47:56 +01:00
var shaPattern = regexp . MustCompile ( ` ^[0-9a-f] { 4,40}$ ` )
// IsValidSHAPattern will check if the provided string matches the SHA Pattern
func IsValidSHAPattern ( sha string ) bool {
return shaPattern . MatchString ( sha )
}
2020-04-08 04:54:46 +02:00
2016-12-22 17:30:52 +08:00
// MustID always creates a new SHA1 from a [20]byte array with no validation of input.
func MustID ( b [ ] byte ) SHA1 {
var id SHA1
2018-05-01 17:04:36 +10:00
copy ( id [ : ] , b )
2016-11-03 23:16:01 +01:00
return id
}
2016-12-22 17:30:52 +08:00
// NewID creates a new SHA1 from a [20]byte array.
func NewID ( b [ ] byte ) ( SHA1 , error ) {
2016-11-03 23:16:01 +01:00
if len ( b ) != 20 {
2016-12-22 17:30:52 +08:00
return SHA1 { } , fmt . Errorf ( "Length must be 20: %v" , b )
2016-11-03 23:16:01 +01:00
}
return MustID ( b ) , nil
}
// MustIDFromString always creates a new sha from a ID with no validation of input.
2016-12-22 17:30:52 +08:00
func MustIDFromString ( s string ) SHA1 {
2016-11-03 23:16:01 +01:00
b , _ := hex . DecodeString ( s )
return MustID ( b )
}
2016-12-22 17:30:52 +08:00
// NewIDFromString creates a new SHA1 from a ID string of length 40.
func NewIDFromString ( s string ) ( SHA1 , error ) {
var id SHA1
2016-11-03 23:16:01 +01:00
s = strings . TrimSpace ( s )
2022-12-27 21:12:49 +08:00
if len ( s ) != SHAFullLength {
2016-11-03 23:16:01 +01:00
return id , fmt . Errorf ( "Length must be 40: %s" , s )
}
b , err := hex . DecodeString ( s )
if err != nil {
return id , err
}
return NewID ( b )
}