aboutsummaryrefslogtreecommitdiff
path: root/refstore/files/update_validate.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-23 03:25:44 +0000
committerGravatar Runxi Yu2026-03-23 03:27:52 +0000
commit4a796e64ac576d6a3e3f2fe6174c4aa476ea0c5c (patch)
tree44d72a20076ceab0981d0b553693d26ca36cc0be /refstore/files/update_validate.go
parentreceivepack: Lifecycle/ownership docs (diff)
signatureNo signature
refstore: Improve interfaces, errors, and make batch work v0.1.92
Diffstat (limited to 'refstore/files/update_validate.go')
-rw-r--r--refstore/files/update_validate.go66
1 files changed, 66 insertions, 0 deletions
diff --git a/refstore/files/update_validate.go b/refstore/files/update_validate.go
new file mode 100644
index 00000000..9449fda5
--- /dev/null
+++ b/refstore/files/update_validate.go
@@ -0,0 +1,66 @@
+package files
+
+import (
+ "fmt"
+ "strings"
+
+ "codeberg.org/lindenii/furgit/objectid"
+ "codeberg.org/lindenii/furgit/ref/refname"
+ "codeberg.org/lindenii/furgit/refstore"
+)
+
+func (executor *refUpdateExecutor) validateQueuedUpdate(op queuedUpdate) error {
+ if op.name == "" {
+ return wrapUpdateError(op.name, &refstore.InvalidNameError{Err: fmt.Errorf("empty reference name")})
+ }
+
+ switch op.kind {
+ case updateCreate, updateReplace:
+ err := refname.ValidateUpdateName(op.name, true)
+ if err != nil {
+ return wrapUpdateError(op.name, &refstore.InvalidNameError{Err: err})
+ }
+
+ if op.newID.Size() == 0 {
+ return wrapUpdateError(op.name, &refstore.InvalidValueError{Err: objectid.ErrInvalidAlgorithm})
+ }
+ case updateDelete, updateVerify:
+ err := refname.ValidateUpdateName(op.name, false)
+ if err != nil {
+ return wrapUpdateError(op.name, &refstore.InvalidNameError{Err: err})
+ }
+
+ if op.oldID.Size() == 0 {
+ return wrapUpdateError(op.name, &refstore.InvalidValueError{Err: objectid.ErrInvalidAlgorithm})
+ }
+ case updateCreateSymbolic, updateReplaceSymbolic:
+ err := refname.ValidateUpdateName(op.name, true)
+ if err != nil {
+ return wrapUpdateError(op.name, &refstore.InvalidNameError{Err: err})
+ }
+
+ if strings.TrimSpace(op.newTarget) == "" {
+ return wrapUpdateError(op.name, &refstore.InvalidValueError{Err: fmt.Errorf("empty symbolic target")})
+ }
+
+ err = refname.ValidateSymbolicTarget(op.name, strings.TrimSpace(op.newTarget))
+ if err != nil {
+ return wrapUpdateError(op.name, &refstore.InvalidValueError{Err: err})
+ }
+ case updateDeleteSymbolic, updateVerifySymbolic:
+ err := refname.ValidateUpdateName(op.name, false)
+ if err != nil {
+ return wrapUpdateError(op.name, &refstore.InvalidNameError{Err: err})
+ }
+ default:
+ return fmt.Errorf("refstore/files: unsupported update operation %d", op.kind)
+ }
+
+ if op.kind == updateReplaceSymbolic || op.kind == updateDeleteSymbolic || op.kind == updateVerifySymbolic {
+ if strings.TrimSpace(op.oldTarget) == "" {
+ return wrapUpdateError(op.name, &refstore.InvalidValueError{Err: fmt.Errorf("empty symbolic old target")})
+ }
+ }
+
+ return nil
+}