mirror of
				https://github.com/adnanh/webhook.git
				synced 2025-10-26 11:10:58 +00:00 
			
		
		
		
	Fix environment and argument passing
Two issues are addressed in this commit: 1. Instead of only sending the predefined environment arguments, this commit appends the arguments to the existing OS environment. Fixes #53. 2. If an argument is not found in the payload, allow the command to run and pass in an empty string as a placeholder. Fixes #54. Additionally, I replaced `hook.ErrInvalidPayloadSignature` with a new `SignatureError` type so that we can embed the signature in the error.
This commit is contained in:
		
							parent
							
								
									a7aa7f2327
								
							
						
					
					
						commit
						d2e315d9c6
					
				
					 5 changed files with 97 additions and 17 deletions
				
			
		
							
								
								
									
										17
									
								
								hook/hook.go
									
										
									
									
									
								
							
							
						
						
									
										17
									
								
								hook/hook.go
									
										
									
									
									
								
							|  | @ -5,7 +5,6 @@ import ( | |||
| 	"crypto/sha1" | ||||
| 	"encoding/hex" | ||||
| 	"encoding/json" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"io/ioutil" | ||||
| 	"reflect" | ||||
|  | @ -31,8 +30,17 @@ const ( | |||
| 	EnvNamespace string = "HOOK_" | ||||
| ) | ||||
| 
 | ||||
| // ErrInvalidPayloadSignature describes an invalid payload signature. | ||||
| var ErrInvalidPayloadSignature = errors.New("invalid payload signature") | ||||
| // SignatureError describes an invalid payload signature passed to Hook. | ||||
| type SignatureError struct { | ||||
| 	Signature string | ||||
| } | ||||
| 
 | ||||
| func (e *SignatureError) Error() string { | ||||
| 	if e == nil { | ||||
| 		return "<nil>" | ||||
| 	} | ||||
| 	return fmt.Sprintf("invalid payload signature %s", e.Signature) | ||||
| } | ||||
| 
 | ||||
| // ArgumentError describes an invalid argument passed to Hook. | ||||
| type ArgumentError struct { | ||||
|  | @ -84,7 +92,7 @@ func CheckPayloadSignature(payload []byte, secret string, signature string) (str | |||
| 	expectedMAC := hex.EncodeToString(mac.Sum(nil)) | ||||
| 
 | ||||
| 	if !hmac.Equal([]byte(signature), []byte(expectedMAC)) { | ||||
| 		err = ErrInvalidPayloadSignature | ||||
| 		return expectedMAC, &SignatureError{expectedMAC} | ||||
| 	} | ||||
| 	return expectedMAC, err | ||||
| } | ||||
|  | @ -302,6 +310,7 @@ func (h *Hook) ExtractCommandArguments(headers, query, payload *map[string]inter | |||
| 		if arg, ok := h.PassArgumentsToCommand[i].Get(headers, query, payload); ok { | ||||
| 			args = append(args, arg) | ||||
| 		} else { | ||||
| 			args = append(args, "") | ||||
| 			return args, &ArgumentError{h.PassArgumentsToCommand[i]} | ||||
| 		} | ||||
| 	} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue