diff options
Diffstat (limited to 'receivepack/receivepack.go')
| -rw-r--r-- | receivepack/receivepack.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/receivepack/receivepack.go b/receivepack/receivepack.go index 5a70715d..eb518935 100644 --- a/receivepack/receivepack.go +++ b/receivepack/receivepack.go @@ -74,6 +74,7 @@ func ReceivePack( PromotedObjectPermissions: translatePromotedObjectPermissions( opts.PromotedObjectPermissions, ), + Hook: translateHook(opts.Hook), }) result, err := svc.Execute(ctx, serviceReq) @@ -106,3 +107,41 @@ func translatePromotedObjectPermissions( FileMode: perms.FileMode, } } + +func translateHook(hook Hook) service.Hook { + if hook == nil { + return nil + } + + return func(ctx context.Context, req service.HookRequest) ([]service.UpdateDecision, error) { + translatedUpdates := make([]RefUpdate, 0, len(req.Updates)) + for _, update := range req.Updates { + translatedUpdates = append(translatedUpdates, RefUpdate{ + Name: update.Name, + OldID: update.OldID, + NewID: update.NewID, + }) + } + + decisions, err := hook(ctx, HookRequest{ + Refs: req.Refs, + ExistingObjects: req.ExistingObjects, + QuarantinedObjects: req.QuarantinedObjects, + Updates: translatedUpdates, + PushOptions: append([]string(nil), req.PushOptions...), + }) + if err != nil { + return nil, err + } + + out := make([]service.UpdateDecision, 0, len(decisions)) + for _, decision := range decisions { + out = append(out, service.UpdateDecision{ + Accept: decision.Accept, + Message: decision.Message, + }) + } + + return out, nil + } +} |
