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.
cfa6b4f7c8
Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com> |
2 years ago | |
---|---|---|
.. | ||
log | 2 years ago | |
.gitignore | 2 years ago | |
.goconvey | 2 years ago | |
.travis.yml | 2 years ago | |
CHANGES.md | 2 years ago | |
LICENSE | 2 years ago | |
Makefile | 2 years ago | |
README.md | 2 years ago | |
SECURITY.md | 2 years ago | |
Srcfile | 2 years ago | |
bench_test.sh | 2 years ago | |
compress.go | 2 years ago | |
compressor_cache.go | 2 years ago | |
compressor_pools.go | 2 years ago | |
compressors.go | 2 years ago | |
constants.go | 2 years ago | |
container.go | 2 years ago | |
cors_filter.go | 2 years ago | |
coverage.sh | 2 years ago | |
curly.go | 2 years ago | |
curly_route.go | 2 years ago | |
custom_verb.go | 2 years ago | |
doc.go | 2 years ago | |
entity_accessors.go | 2 years ago | |
extensions.go | 2 years ago | |
filter.go | 2 years ago | |
json.go | 2 years ago | |
jsoniter.go | 2 years ago | |
jsr311.go | 2 years ago | |
logger.go | 2 years ago | |
mime.go | 2 years ago | |
options_filter.go | 2 years ago | |
parameter.go | 2 years ago | |
path_expression.go | 2 years ago | |
path_processor.go | 2 years ago | |
request.go | 2 years ago | |
response.go | 2 years ago | |
route.go | 2 years ago | |
route_builder.go | 2 years ago | |
route_reader.go | 2 years ago | |
router.go | 2 years ago | |
service_error.go | 2 years ago | |
web_service.go | 2 years ago | |
web_service_container.go | 2 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
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 build this package using a 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.