knotserver: internal: extract push options from the headers, and implement skipping ci if skip-ci or ci-skip is passed #350

closed
opened by ptr.pet targeting master from ptr.pet/core: push-options
Changed files
+19 -2
knotserver
+19 -2
knotserver/internal.go
···
return
}
+
type PushOptions struct {
+
skipCi bool
+
}
+
func (h *InternalHandle) PostReceiveHook(w http.ResponseWriter, r *http.Request) {
l := h.l.With("handler", "PostReceiveHook")
···
// non-fatal
}
+
// extract any push options
+
pushOptionsRaw := r.Header.Values("X-Git-Push-Option")
+
pushOptions := PushOptions{}
+
for _, option := range pushOptionsRaw {
+
if option == "skip-ci" || option == "ci-skip" {
+
pushOptions.skipCi = true
+
}
+
}
+
for _, line := range lines {
err := h.insertRefUpdate(line, gitUserDid, repoDid, repoName)
if err != nil {
···
// non-fatal
}
-
err = h.triggerPipeline(line, gitUserDid, repoDid, repoName)
+
err = h.triggerPipeline(line, gitUserDid, repoDid, repoName, pushOptions)
if err != nil {
l.Error("failed to trigger pipeline", "err", err, "line", line, "did", gitUserDid, "repo", gitRelativeDir)
// non-fatal
···
return h.db.InsertEvent(event, h.n)
}
-
func (h *InternalHandle) triggerPipeline(line git.PostReceiveLine, gitUserDid, repoDid, repoName string) error {
+
func (h *InternalHandle) triggerPipeline(line git.PostReceiveLine, gitUserDid, repoDid, repoName string, pushOptions PushOptions) error {
+
if pushOptions.skipCi {
+
return nil
+
}
+
didSlashRepo, err := securejoin.SecureJoin(repoDid, repoName)
if err != nil {
return err