kubernetes/vendor/github.com/emicklei/go-restful
Michael Rubin fdf43b12d4 Removing unreferenced code github/com/emicklei
The code in pkg github.com/emicklei/examples/ is not referenced in kubernetes
codebase. Somehow it was mirrored in the vendor directory in a previous
PR #25365.

This causes problems for godeps which will then include the reference to this
code in the Godeps.json file (among other packages that are not in the vendors
directory).

Removing the directory and its contents fixes the fissue and we believe the
current godeps process should prevent it from re-occurring.
2016-05-23 14:05:09 -07:00
..
log Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
swagger Update vendor dir and Godeps.json with new Godep 2016-05-11 17:02:50 -07:00
.gitignore Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
bench_test.sh Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
CHANGES.md Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
compress.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
compressor_cache.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
compressor_pools.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
compressors.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
constants.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
container.go update the go-restful dependency. 2016-05-16 13:14:34 -07:00
cors_filter.go update the go-restful dependency. 2016-05-16 13:14:34 -07:00
coverage.sh Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
curly_route.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
curly.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
doc.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
entity_accessors.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
filter.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
install.sh Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
jsr311.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
LICENSE Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
logger.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
mime.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
options_filter.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
parameter.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
path_expression.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
README.md Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
request.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
response.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
route_builder.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
route.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
router.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
service_error.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
Srcfile Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
web_service_container.go Move deps from _workspace/ to vendor/ 2016-05-08 20:30:21 -07:00
web_service.go update the go-restful dependency. 2016-05-16 13:14:34 -07:00

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

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}) support
  • Configurable router:
    • Routing algorithm after JSR311 that is implemented using (but doest not accept) regular expressions (See RouterJSR311 which is used by default)
    • Fast routing algorithm that allows static elements, regular expressions and dynamic parameters in the URL path (e.g. /meetings/{id} or /static/{subpath:*}, See CurlyRouter)
  • Request API for reading structs from JSON/XML and accesing parameters (path,query,header)
  • Response API for writing structs to JSON/XML and setting headers
  • 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 (see swagger package)
  • 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 encoding using EntityReaderWriter registration
  • Customizable gzip/deflate readers and writers using CompressorProvider registration

Resources

Build Status

(c) 2012 - 2015, http://ernestmicklei.com. MIT License

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