diff options
| author | 2026-03-07 21:15:54 +0800 | |
|---|---|---|
| committer | 2026-03-07 21:16:32 +0800 | |
| commit | b82515530f10dfebbf99dca501890570f3466910 (patch) | |
| tree | 9574dc49fa7239f7f0c131471f4a6708fd7041d5 /receivepack/internal/service/quarantine_objects.go | |
| parent | receivepack: Set permissions properly (diff) | |
| signature | No signature | |
receivepack: Add hooks
Diffstat (limited to 'receivepack/internal/service/quarantine_objects.go')
| -rw-r--r-- | receivepack/internal/service/quarantine_objects.go | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/receivepack/internal/service/quarantine_objects.go b/receivepack/internal/service/quarantine_objects.go new file mode 100644 index 00000000..0c03be51 --- /dev/null +++ b/receivepack/internal/service/quarantine_objects.go @@ -0,0 +1,50 @@ +package service + +import ( + "os" + + "codeberg.org/lindenii/furgit/objectstore" + objectmix "codeberg.org/lindenii/furgit/objectstore/mix" + "codeberg.org/lindenii/furgit/objectstore/memory" + "codeberg.org/lindenii/furgit/objectstore/loose" + "codeberg.org/lindenii/furgit/objectstore/packed" +) + +func (service *Service) openQuarantinedObjects(quarantineName string) (objectstore.Store, error) { + if quarantineName == "" { + return memory.New(service.opts.Algorithm), nil + } + + looseRoot, err := service.opts.ObjectsRoot.OpenRoot(quarantineName) + if err != nil { + return nil, err + } + + looseStore, err := loose.New(looseRoot, service.opts.Algorithm) + if err != nil { + _ = looseRoot.Close() + + return nil, err + } + + packRoot, err := looseRoot.OpenRoot("pack") + if err == nil { + packedStore, packedErr := packed.New(packRoot, service.opts.Algorithm) + if packedErr != nil { + _ = packRoot.Close() + _ = looseStore.Close() + + return nil, packedErr + } + + return objectmix.New(looseStore, packedStore), nil + } + + if !os.IsNotExist(err) { + _ = looseStore.Close() + + return nil, err + } + + return looseStore, nil +} |
