ARO-RP/vendor/github.com/emicklei/go-restful/v3
dependabot[bot] 5aac7c6b93 Bump github.com/containerd/containerd from 1.6.18 to 1.6.26
Bumps [github.com/containerd/containerd](https://github.com/containerd/containerd) from 1.6.18 to 1.6.26.
- [Release notes](https://github.com/containerd/containerd/releases)
- [Changelog](https://github.com/containerd/containerd/blob/main/RELEASES.md)
- [Commits](https://github.com/containerd/containerd/compare/v1.6.18...v1.6.26)

---
updated-dependencies:
- dependency-name: github.com/containerd/containerd
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
2023-12-20 16:14:35 -05:00
..
log go mod vendor 2023-09-01 16:53:58 -04:00
.gitignore go mod vendor 2023-09-01 16:53:58 -04:00
.goconvey go mod vendor 2023-09-01 16:53:58 -04:00
.travis.yml go mod vendor 2023-09-01 16:53:58 -04:00
CHANGES.md Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
LICENSE go mod vendor 2023-09-01 16:53:58 -04:00
Makefile go mod vendor 2023-09-01 16:53:58 -04:00
README.md Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
SECURITY.md go mod vendor 2023-09-01 16:53:58 -04:00
Srcfile go mod vendor 2023-09-01 16:53:58 -04:00
bench_test.sh go mod vendor 2023-09-01 16:53:58 -04:00
compress.go go mod vendor 2023-09-01 16:53:58 -04:00
compressor_cache.go go mod vendor 2023-09-01 16:53:58 -04:00
compressor_pools.go go mod vendor 2023-09-01 16:53:58 -04:00
compressors.go go mod vendor 2023-09-01 16:53:58 -04:00
constants.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
container.go go mod vendor 2023-09-01 16:53:58 -04:00
cors_filter.go go mod vendor 2023-09-01 16:53:58 -04:00
coverage.sh go mod vendor 2023-09-01 16:53:58 -04:00
curly.go go mod vendor 2023-09-01 16:53:58 -04:00
curly_route.go go mod vendor 2023-09-01 16:53:58 -04:00
custom_verb.go go mod vendor 2023-09-01 16:53:58 -04:00
doc.go go mod vendor 2023-09-01 16:53:58 -04:00
entity_accessors.go go mod vendor 2023-09-01 16:53:58 -04:00
extensions.go go mod vendor 2023-09-01 16:53:58 -04:00
filter.go go mod vendor 2023-09-01 16:53:58 -04:00
filter_adapter.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
json.go go mod vendor 2023-09-01 16:53:58 -04:00
jsoniter.go go mod vendor 2023-09-01 16:53:58 -04:00
jsr311.go go mod vendor 2023-09-01 16:53:58 -04:00
logger.go go mod vendor 2023-09-01 16:53:58 -04:00
mime.go go mod vendor 2023-09-01 16:53:58 -04:00
options_filter.go go mod vendor 2023-09-01 16:53:58 -04:00
parameter.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
path_expression.go go mod vendor 2023-09-01 16:53:58 -04:00
path_processor.go go mod vendor 2023-09-01 16:53:58 -04:00
request.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
response.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
route.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
route_builder.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
route_reader.go go mod vendor 2023-09-01 16:53:58 -04:00
router.go go mod vendor 2023-09-01 16:53:58 -04:00
service_error.go go mod vendor 2023-09-01 16:53:58 -04:00
web_service.go Bump github.com/containerd/containerd from 1.6.18 to 1.6.26 2023-12-20 16:14:35 -05:00
web_service_container.go go mod vendor 2023-09-01 16:53:58 -04:00

README.md

go-restful

package for building REST-style Web Services using Google Go

Build Status Go Report Card GoDoc codecov

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")
	...
}

Full API of a UserResource

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 HttpMiddlewareHandlerToFilter function

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

Type git shortlog -s for a full list of contributors.

© 2012 - 2022, http://ernestmicklei.com. MIT License. Contributions are welcome.