Awesome
<img src="logo.png"> <p align="center"> <a href="https://app.travis-ci.com/fulldump/golax"><img src="https://app.travis-ci.com/fulldump/golax.svg?branch=master"></a> <a href="https://goreportcard.com/report/github.com/fulldump/golax"><img src="https://goreportcard.com/badge/github.com/fulldump/golax"></a> <a href="https://godoc.org/github.com/fulldump/golax"><img src="https://godoc.org/github.com/fulldump/golax?status.svg" alt="GoDoc"></a> <a href="https://codeclimate.com/github/fulldump/golax/maintainability"><img src="https://api.codeclimate.com/v1/badges/798baff13203d5a4abad/maintainability" /></a> </p>Golax is the official go implementation for the Lax framework.
<!-- MarkdownTOC autolink=true bracket=round depth=4 -->- About Lax
- Getting started
- Routing example
- Performance
- How interceptor works
- Handling parameters
- Support for Google custom methods
- Sample use cases
Related docs:
About Lax
Lax wants to be the best "user experience" for developers making REST APIs.
The design principles for Lax are:
- The lowest language overhead
- Extremely fast to develop
- Very easy to read and trace.
Getting started
my_api := golax.NewApi()
my_api.Root.
Interceptor(golax.InterceptorError).
Interceptor(myLogingInterceptor)
my_api.Root.Node("hello").
Method("GET", func(c *golax.Context) {
// At this point, Root interceptors has been already executed
fmt.Fprintln(c.Response, "Hello world!")
})
my_api.Serve()
Routing example
Routing is based on nodes.
<p align="center"> <img src="doc/figure_4_routing_example.png"> </p>There are three types: static
, regex
and parameter
.
- static: Only matches with the url part if it is exactly the same.
- regex: Surrounded by
(
and)
, if the regex match. - parameter: Surrounded by
{
and}
, always matches.
Performance
The performance compared with the most popular alternative is very similar (actually golax performs slightly better) however code readability and maintainability is far better with golax implementation.
<p align="center"> <img src="doc/figure_3_performance.png"> </p>Tests has been executed in a Intel(R) Core(TM) i5-3210M CPU @ 2.50GHz
.
Learn more about this https://github.com/fulldump/golax-performance.
How interceptor works
If I want to handle a GET /users/1234/stats
request, all interceptors in nodes from <root>
to .../stats
are executed:
To abort the execution, call to c.Error(404, "Resource not found")
:
Handling parameters
my_api := golax.NewApi()
my_api.Root.
Node("users").
Node("{user_id}").
Method("GET", func (c *golax.Context) {
fmt.Fprintln(c.Response, "You are looking for user " + c.Parameter)
})
my_api.Serve()
It is also possible get all parameters:
func (c *golax.Context) {
fmt.Fprintln(c.Response, "All parameters:", c.Parameters)
}
Support for Google custom methods
According to Google's API design guidelines to map RPC services to REST HTTP, it describes custom methods as extra operations that can not be easyly mapped to HTTP verbs. More info about custom methods
For example, this URL has a custom method :activate
:
https://my.service.com/v1/users/31231231231:activate
Golax support custom methods as operations:
my_api.Root.
Node("v1").
Node("users").
Node("{user_id}").
Operation("activate").
Method("POST", func(c *golax.Context) {
user_id := c.Parameters["{user_id}"]"
fmt.Fprintln(c.Response, "Here is custom method ':activate' for user "+user_id)
})
Sample use cases
TODO: put here some examples to cover cool things:
- fluent implementation
- node cycling
- readability
- node preference
- sample logging interceptor
- sample auth interceptor
- sample api errors