mirror of
				https://github.com/adnanh/webhook.git
				synced 2025-10-26 11:10:58 +00:00 
			
		
		
		
	added support for incoming-payload-content-type
This commit is contained in:
		
							parent
							
								
									a49364ae93
								
							
						
					
					
						commit
						f84edae99d
					
				
					 2 changed files with 5 additions and 0 deletions
				
			
		|  | @ -383,6 +383,7 @@ type Hook struct { | ||||||
| 	JSONStringParameters                []Argument      `json:"parse-parameters-as-json,omitempty"` | 	JSONStringParameters                []Argument      `json:"parse-parameters-as-json,omitempty"` | ||||||
| 	TriggerRule                         *Rules          `json:"trigger-rule,omitempty"` | 	TriggerRule                         *Rules          `json:"trigger-rule,omitempty"` | ||||||
| 	TriggerRuleMismatchHttpResponseCode int             `json:"trigger-rule-mismatch-http-response-code,omitempty"` | 	TriggerRuleMismatchHttpResponseCode int             `json:"trigger-rule-mismatch-http-response-code,omitempty"` | ||||||
|  | 	IncomingPayloadContentType          string          `json:"incoming-payload-content-type,omitempty"`	 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // ParseJSONParameters decodes specified arguments to JSON objects and replaces the | // ParseJSONParameters decodes specified arguments to JSON objects and replaces the | ||||||
|  |  | ||||||
|  | @ -228,7 +228,11 @@ func hookHandler(w http.ResponseWriter, r *http.Request) { | ||||||
| 		// parse body | 		// parse body | ||||||
| 		var payload map[string]interface{} | 		var payload map[string]interface{} | ||||||
| 
 | 
 | ||||||
|  | 		// set contentType to IncomingPayloadContentType or header value | ||||||
| 		contentType := r.Header.Get("Content-Type") | 		contentType := r.Header.Get("Content-Type") | ||||||
|  | 		if len(matchedHook.IncomingPayloadContentType) != 0 { | ||||||
|  | 			contentType = matchedHook.IncomingPayloadContentType | ||||||
|  | 		} | ||||||
| 
 | 
 | ||||||
| 		if strings.Contains(contentType, "json") { | 		if strings.Contains(contentType, "json") { | ||||||
| 			decoder := json.NewDecoder(strings.NewReader(string(body))) | 			decoder := json.NewDecoder(strings.NewReader(string(body))) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue