Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/goroute/route
Go Route - Simple yet powerful HTTP request multiplexer
https://github.com/goroute/route
go golang http middleware router
Last synced: 2 months ago
JSON representation
Go Route - Simple yet powerful HTTP request multiplexer
- Host: GitHub
- URL: https://github.com/goroute/route
- Owner: goroute
- License: mit
- Created: 2019-07-06T18:47:38.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-12-23T20:20:48.000Z (about 5 years ago)
- Last Synced: 2024-06-19T01:11:56.951Z (7 months ago)
- Topics: go, golang, http, middleware, router
- Language: Go
- Homepage: https://goroute.github.io
- Size: 288 KB
- Stars: 9
- Watchers: 4
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go-extra - route - Simple yet powerful HTTP request multiplexer|8|2|1|2019-07-06T18:47:38Z|2019-12-23T20:20:48Z| (Web Frameworks / Routers)
README
[![Build Status](https://travis-ci.com/goroute/route.svg?branch=master)](https://travis-ci.com/goroute/route)
[![codecov](https://codecov.io/gh/goroute/route/branch/master/graph/badge.svg)](https://codecov.io/gh/goroute/route)
[![GoDoc](https://godoc.org/github.com/goroute/route?status.svg)](http://godoc.org/github.com/goroute/route)
[![Go Report Card](https://goreportcard.com/badge/github.com/goroute/route)](https://goreportcard.com/report/github.com/goroute/route)## Few main features
* Minimal core.
* No external runtime dependencies. Custom middlewares which requires 3th party dependecies are places in separates repositories under goroute org.
* HTTP Routing.
* Middlewares support.
* Global error handling.## Getting Started
### Prerequisites
You need to have at least go 1.11 installed on you local machine.
### Installing
Install go route package with go get
```
go get -u github.com/goroute/route
```Start your first server. Create main.go file and add:
```go
package mainimport (
"net/http"
"log"
"github.com/goroute/route"
)type helloResponse struct {
Title string `json:"title"`
}func main() {
mux := route.NewServeMux()
mux.Use(func(c route.Context, next route.HandlerFunc) error {
log.Println("Hello, Middleware!")
return next(c)
})
mux.GET("/", func(c route.Context) error {
return c.JSON(http.StatusOK, &helloResponse{Title:"Hello, JSON!"})
})
log.Fatal(http.ListenAndServe(":9000", mux))
}```
Run it
```
go run main.go
```## More examples
See [examples](https://github.com/goroute/route/tree/master/examples)
## Built With
* [Go](https://www.golang.org/)
## Contributing
Please read [CONTRIBUTING.md](https://github.com/goroute/route/CONTRIBUTING.md) for details on our code of conduct, and the process for submitting pull requests to us.
## Versioning
We use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](https://github.com/goroute/route/tags).
## License
This project is licensed under the MIT License - see the [LICENSE.md](LICENSE) file for details
## Acknowledgments
* This project is largely inspired by [echo](https://echo.labstack.com/). Parts of the code are adopted from echo. See NOTICE.