You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			|  9541457c54 Signed-off-by: Justin Chadwell <me@jedevc.com> | 3 years ago | |
|---|---|---|
| .. | ||
| log | 3 years ago | |
| .gitignore | 3 years ago | |
| .goconvey | 3 years ago | |
| .travis.yml | 3 years ago | |
| CHANGES.md | 3 years ago | |
| LICENSE | 3 years ago | |
| Makefile | 3 years ago | |
| README.md | 3 years ago | |
| SECURITY.md | 3 years ago | |
| Srcfile | 3 years ago | |
| bench_test.sh | 3 years ago | |
| compress.go | 3 years ago | |
| compressor_cache.go | 3 years ago | |
| compressor_pools.go | 3 years ago | |
| compressors.go | 3 years ago | |
| constants.go | 3 years ago | |
| container.go | 3 years ago | |
| cors_filter.go | 3 years ago | |
| coverage.sh | 3 years ago | |
| curly.go | 3 years ago | |
| curly_route.go | 3 years ago | |
| custom_verb.go | 3 years ago | |
| doc.go | 3 years ago | |
| entity_accessors.go | 3 years ago | |
| extensions.go | 3 years ago | |
| filter.go | 3 years ago | |
| filter_adapter.go | 3 years ago | |
| json.go | 3 years ago | |
| jsoniter.go | 3 years ago | |
| jsr311.go | 3 years ago | |
| logger.go | 3 years ago | |
| mime.go | 3 years ago | |
| options_filter.go | 3 years ago | |
| parameter.go | 3 years ago | |
| path_expression.go | 3 years ago | |
| path_processor.go | 3 years ago | |
| request.go | 3 years ago | |
| response.go | 3 years ago | |
| route.go | 3 years ago | |
| route_builder.go | 3 years ago | |
| route_reader.go | 3 years ago | |
| router.go | 3 years ago | |
| service_error.go | 3 years ago | |
| web_service.go | 3 years ago | |
| web_service_container.go | 3 years ago | |
		
			
				
				README.md
			
		
		
			
			
		
	
	go-restful
package for building REST-style Web Services using Google Go
REST asks developers to use HTTP methods explicitly and in a way that's consistent with the protocol definition. This basic REST design principle establishes a one-to-one mapping between create, read, update, and delete (CRUD) operations and HTTP methods. According to this mapping:
- GET = Retrieve a representation of a resource
- POST = Create if you are sending content to the server to create a subordinate of the specified resource collection, using some server-side algorithm.
- PUT = Create if you are sending the full content of the specified resource (URI).
- PUT = Update if you are updating the full content of the specified resource.
- DELETE = Delete if you are requesting the server to delete the resource
- PATCH = Update partial content of a resource
- OPTIONS = Get information about the communication options for the request URI
Usage
Without Go Modules
All versions up to v2.*.* (on the master) are not supporting Go modules.
import (
	restful "github.com/emicklei/go-restful"
)
Using Go Modules
As of version v3.0.0 (on the v3 branch), this package supports Go modules.
import (
	restful "github.com/emicklei/go-restful/v3"
)
Example
ws := new(restful.WebService)
ws.
	Path("/users").
	Consumes(restful.MIME_XML, restful.MIME_JSON).
	Produces(restful.MIME_JSON, restful.MIME_XML)
ws.Route(ws.GET("/{user-id}").To(u.findUser).
	Doc("get a user").
	Param(ws.PathParameter("user-id", "identifier of the user").DataType("string")).
	Writes(User{}))		
...
	
func (u UserResource) findUser(request *restful.Request, response *restful.Response) {
	id := request.PathParameter("user-id")
	...
}
Features
- Routes for request → function mapping with path parameter (e.g. {id} but also prefix_{var} and {var}_suffix) support
- Configurable router:
- (default) Fast routing algorithm that allows static elements, google custom method, regular expressions and dynamic parameters in the URL path (e.g. /resource/name:customVerb, /meetings/{id} or /static/{subpath:*})
- Routing algorithm after JSR311 that is implemented using (but does not accept) regular expressions
 
- Request API for reading structs from JSON/XML and accessing parameters (path,query,header)
- Response API for writing structs to JSON/XML and setting headers
- Customizable encoding using EntityReaderWriter registration
- Filters for intercepting the request → response flow on Service or Route level
- Request-scoped variables using attributes
- Containers for WebServices on different HTTP endpoints
- Content encoding (gzip,deflate) of request and response payloads
- Automatic responses on OPTIONS (using a filter)
- Automatic CORS request handling (using a filter)
- API declaration for Swagger UI (go-restful-openapi, see go-restful-swagger12)
- Panic recovery to produce HTTP 500, customizable using RecoverHandler(...)
- Route errors produce HTTP 404/405/406/415 errors, customizable using ServiceErrorHandler(...)
- Configurable (trace) logging
- Customizable gzip/deflate readers and writers using CompressorProvider registration
- Inject your own http.Handler using the HttpMiddlewareHandlerToFilterfunction
How to customize
There are several hooks to customize the behavior of the go-restful package.
- Router algorithm
- Panic recovery
- JSON decoder
- Trace logging
- Compression
- Encoders for other serializers
- Use jsoniter by building this package using a build tag, e.g. go build -tags=jsoniter .
Resources
- Example programs
- Example posted on blog
- Design explained on blog
- sourcegraph
- showcase: Zazkia - tcp proxy for testing resiliency
- showcase: Mora - MongoDB REST Api server
Type git shortlog -s for a full list of contributors.
© 2012 - 2022, http://ernestmicklei.com. MIT License. Contributions are welcome.
