hook: get push options and pass them #352

merged
opened by ptr.pet targeting master from [deleted fork]: push-options
Changed files
+16 -1
hook
+10
hook/hook.go
··· 36 36 Usage: "endpoint for the internal API", 37 37 Value: "http://localhost:5444", 38 38 }, 39 + &cli.StringSliceFlag{ 40 + Name: "push-option", 41 + Usage: "any push option from git", 42 + }, 39 43 }, 40 44 Commands: []*cli.Command{ 41 45 { ··· 52 56 userDid := cmd.String("user-did") 53 57 userHandle := cmd.String("user-handle") 54 58 endpoint := cmd.String("internal-api") 59 + pushOptions := cmd.StringSlice("push-option") 55 60 56 61 payloadReader := bufio.NewReader(os.Stdin) 57 62 payload, _ := payloadReader.ReadString('\n') ··· 67 72 req.Header.Set("X-Git-Dir", gitDir) 68 73 req.Header.Set("X-Git-User-Did", userDid) 69 74 req.Header.Set("X-Git-User-Handle", userHandle) 75 + if pushOptions != nil { 76 + for _, option := range pushOptions { 77 + req.Header.Add("X-Git-Push-Option", option) 78 + } 79 + } 70 80 71 81 resp, err := client.Do(req) 72 82 if err != nil {
+6 -1
hook/setup.go
··· 133 133 134 134 hookContent := fmt.Sprintf(`#!/usr/bin/env bash 135 135 # AUTO GENERATED BY KNOT, DO NOT MODIFY 136 - %s hook -git-dir "$GIT_DIR" -user-did "$GIT_USER_DID" -user-handle "$GIT_USER_HANDLE" -internal-api "%s" post-recieve 136 + push_options=() 137 + for ((i=0; i<GIT_PUSH_OPTION_COUNT; i++)); do 138 + option_var="GIT_PUSH_OPTION_$i" 139 + push_options+=(-push-option "${!option_var}") 140 + done 141 + %s hook -git-dir "$GIT_DIR" -user-did "$GIT_USER_DID" -user-handle "$GIT_USER_HANDLE" -internal-api "%s" "${push_options[@]}" post-recieve 137 142 `, executablePath, config.internalApi) 138 143 139 144 return os.WriteFile(hookPath, []byte(hookContent), 0755)