2023-12-13 22:02:00 +01:00
|
|
|
// Copyright 2023 The Gitea Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
|
|
|
package git
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/sha1"
|
|
|
|
"regexp"
|
|
|
|
)
|
|
|
|
|
|
|
|
// sha1Pattern can be used to determine if a string is an valid sha
|
|
|
|
var sha1Pattern = regexp.MustCompile(`^[0-9a-f]{4,40}$`)
|
|
|
|
|
|
|
|
type ObjectFormat interface {
|
2023-12-17 12:56:08 +01:00
|
|
|
// Name returns the name of the object format
|
|
|
|
Name() string
|
|
|
|
// EmptyObjectID creates a new empty ObjectID from an object format hash name
|
|
|
|
EmptyObjectID() ObjectID
|
2023-12-13 22:02:00 +01:00
|
|
|
// EmptyTree is the hash of an empty tree
|
|
|
|
EmptyTree() ObjectID
|
|
|
|
// FullLength is the length of the hash's hex string
|
|
|
|
FullLength() int
|
|
|
|
|
|
|
|
IsValid(input string) bool
|
|
|
|
MustID(b []byte) ObjectID
|
|
|
|
MustIDFromString(s string) ObjectID
|
|
|
|
NewID(b []byte) (ObjectID, error)
|
|
|
|
NewIDFromString(s string) (ObjectID, error)
|
|
|
|
|
|
|
|
NewHasher() HasherInterface
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
type Sha1ObjectFormatImpl struct{}
|
2023-12-13 22:02:00 +01:00
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
var (
|
|
|
|
emptyObjectID = &Sha1Hash{}
|
|
|
|
emptyTree = &Sha1Hash{
|
2023-12-13 22:02:00 +01:00
|
|
|
0x4b, 0x82, 0x5d, 0xc6, 0x42, 0xcb, 0x6e, 0xb9, 0xa0, 0x60,
|
|
|
|
0xe5, 0x4b, 0xf8, 0xd6, 0x92, 0x88, 0xfb, 0xee, 0x49, 0x04,
|
|
|
|
}
|
2023-12-17 12:56:08 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func (Sha1ObjectFormatImpl) Name() string { return "sha1" }
|
|
|
|
func (Sha1ObjectFormatImpl) EmptyObjectID() ObjectID {
|
|
|
|
return emptyObjectID
|
|
|
|
}
|
|
|
|
|
|
|
|
func (Sha1ObjectFormatImpl) EmptyTree() ObjectID {
|
|
|
|
return emptyTree
|
2023-12-13 22:02:00 +01:00
|
|
|
}
|
2023-12-17 12:56:08 +01:00
|
|
|
func (Sha1ObjectFormatImpl) FullLength() int { return 40 }
|
|
|
|
func (Sha1ObjectFormatImpl) IsValid(input string) bool {
|
2023-12-13 22:02:00 +01:00
|
|
|
return sha1Pattern.MatchString(input)
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func (Sha1ObjectFormatImpl) MustID(b []byte) ObjectID {
|
2023-12-13 22:02:00 +01:00
|
|
|
var id Sha1Hash
|
|
|
|
copy(id[0:20], b)
|
|
|
|
return &id
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func (h Sha1ObjectFormatImpl) MustIDFromString(s string) ObjectID {
|
2023-12-13 22:02:00 +01:00
|
|
|
return MustIDFromString(h, s)
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func (h Sha1ObjectFormatImpl) NewID(b []byte) (ObjectID, error) {
|
2023-12-13 22:02:00 +01:00
|
|
|
return IDFromRaw(h, b)
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func (h Sha1ObjectFormatImpl) NewIDFromString(s string) (ObjectID, error) {
|
2023-12-13 22:02:00 +01:00
|
|
|
return genericIDFromString(h, s)
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func (h Sha1ObjectFormatImpl) NewHasher() HasherInterface {
|
2023-12-13 22:02:00 +01:00
|
|
|
return &Sha1Hasher{sha1.New()}
|
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
var Sha1ObjectFormat ObjectFormat = Sha1ObjectFormatImpl{}
|
2023-12-13 22:02:00 +01:00
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
var SupportedObjectFormats = []ObjectFormat{
|
|
|
|
Sha1ObjectFormat,
|
|
|
|
// TODO: add sha256
|
2023-12-13 22:02:00 +01:00
|
|
|
}
|
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func ObjectFormatFromName(name string) ObjectFormat {
|
|
|
|
for _, objectFormat := range SupportedObjectFormats {
|
|
|
|
if name == objectFormat.Name() {
|
|
|
|
return objectFormat
|
|
|
|
}
|
2023-12-13 22:02:00 +01:00
|
|
|
}
|
2023-12-17 12:56:08 +01:00
|
|
|
return nil
|
|
|
|
}
|
2023-12-13 22:02:00 +01:00
|
|
|
|
2023-12-17 12:56:08 +01:00
|
|
|
func IsValidObjectFormat(name string) bool {
|
|
|
|
return ObjectFormatFromName(name) != nil
|
2023-12-13 22:02:00 +01:00
|
|
|
}
|