mirror of
				https://github.com/gin-gonic/gin.git
				synced 2025-10-25 19:32:19 +08:00 
			
		
		
		
	* feat(context): add BindQuery func, only parse/bind the query string params. * docs(readme): add BindQuery section. * docs(readme): fix import. * docs(readme): separate import
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2014 Manu Martinez-Almeida.  All rights reserved.
 | |
| // Use of this source code is governed by a MIT style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package binding
 | |
| 
 | |
| import "net/http"
 | |
| 
 | |
| const (
 | |
| 	MIMEJSON              = "application/json"
 | |
| 	MIMEHTML              = "text/html"
 | |
| 	MIMEXML               = "application/xml"
 | |
| 	MIMEXML2              = "text/xml"
 | |
| 	MIMEPlain             = "text/plain"
 | |
| 	MIMEPOSTForm          = "application/x-www-form-urlencoded"
 | |
| 	MIMEMultipartPOSTForm = "multipart/form-data"
 | |
| 	MIMEPROTOBUF          = "application/x-protobuf"
 | |
| 	MIMEMSGPACK           = "application/x-msgpack"
 | |
| 	MIMEMSGPACK2          = "application/msgpack"
 | |
| )
 | |
| 
 | |
| type Binding interface {
 | |
| 	Name() string
 | |
| 	Bind(*http.Request, interface{}) error
 | |
| }
 | |
| 
 | |
| type StructValidator interface {
 | |
| 	// ValidateStruct can receive any kind of type and it should never panic, even if the configuration is not right.
 | |
| 	// If the received type is not a struct, any validation should be skipped and nil must be returned.
 | |
| 	// If the received type is a struct or pointer to a struct, the validation should be performed.
 | |
| 	// If the struct is not valid or the validation itself fails, a descriptive error should be returned.
 | |
| 	// Otherwise nil must be returned.
 | |
| 	ValidateStruct(interface{}) error
 | |
| }
 | |
| 
 | |
| var Validator StructValidator = &defaultValidator{}
 | |
| 
 | |
| var (
 | |
| 	JSON          = jsonBinding{}
 | |
| 	XML           = xmlBinding{}
 | |
| 	Form          = formBinding{}
 | |
| 	Query         = queryBinding{}
 | |
| 	FormPost      = formPostBinding{}
 | |
| 	FormMultipart = formMultipartBinding{}
 | |
| 	ProtoBuf      = protobufBinding{}
 | |
| 	MsgPack       = msgpackBinding{}
 | |
| )
 | |
| 
 | |
| func Default(method, contentType string) Binding {
 | |
| 	if method == "GET" {
 | |
| 		return Form
 | |
| 	}
 | |
| 
 | |
| 	switch contentType {
 | |
| 	case MIMEJSON:
 | |
| 		return JSON
 | |
| 	case MIMEXML, MIMEXML2:
 | |
| 		return XML
 | |
| 	case MIMEPROTOBUF:
 | |
| 		return ProtoBuf
 | |
| 	case MIMEMSGPACK, MIMEMSGPACK2:
 | |
| 		return MsgPack
 | |
| 	default: //case MIMEPOSTForm, MIMEMultipartPOSTForm:
 | |
| 		return Form
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func validate(obj interface{}) error {
 | |
| 	if Validator == nil {
 | |
| 		return nil
 | |
| 	}
 | |
| 	return Validator.ValidateStruct(obj)
 | |
| }
 |