Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ynwd/fastrex
Express inspired web framework for Go. Fast and simple. Google cloud function ready.
https://github.com/ynwd/fastrex
cloud-functions express fastify golang serverless
Last synced: about 2 months ago
JSON representation
Express inspired web framework for Go. Fast and simple. Google cloud function ready.
- Host: GitHub
- URL: https://github.com/ynwd/fastrex
- Owner: ynwd
- Created: 2021-06-11T07:28:18.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-11-05T04:13:51.000Z (about 3 years ago)
- Last Synced: 2023-07-11T20:15:41.140Z (over 1 year ago)
- Topics: cloud-functions, express, fastify, golang, serverless
- Language: Go
- Homepage:
- Size: 209 KB
- Stars: 5
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Fastrex
[![][build]](https://github.com/fastrodev/fastrex/actions/workflows/build.yml) [![Coverage Status][cov]](https://coveralls.io/github/fastrodev/fastrex?branch=main) [![][reference]](https://pkg.go.dev/github.com/fastrodev/fastrex?tab=doc)Fast and simple web application framework for Go inspired by the most popular node.js web framework: Express.js. It implements `ServeHTTP` interface so you can use express style routing. It also wraps and extends the net/http `Request` and `ResponseWriter` into an easy to read and use function signature.
* [Get started](#get-started)
* [Middleware](#middleware)
* [Module](#module)
* [Template](#template)
* [Serverless](#serverless)
* [Benchmarks](#benchmarks)## Get Started
Init folder and install:
```
mkdir app && cd app
go mod init app
go get github.com/fastrodev/fastrex
```
Create main.go file:
```go
package mainimport "github.com/fastrodev/fastrex"
func handler(req fastrex.Request, res fastrex.Response) {
res.Send("root")
}func main() {
app := fastrex.New()
app.Get("/", handler)
err := app.Listen(9000)
if err != nil {
panic(err)
}
}```
Run webapp locally:
```
go run main.go
```## Middleware
You can access `Request` and `Response` field and function before the handler process the incoming request.
### App Middleware
```go
package mainimport "github.com/fastrodev/fastrex"
func handler(req fastrex.Request, res fastrex.Response) {
res.Send("root")
}func appMiddleware(req fastrex.Request, res fastrex.Response, next fastrex.Next) {
if req.URL.Path == "/" {
res.Send("appMiddleware")
return
}next(req, res)
}func main() {
app := fastrex.New()
app.Use(appMiddleware)
app.Get("/", handler)
err := app.Listen(9000)
if err != nil {
panic(err)
}
}```
### Route Middleware
```go
package mainimport "github.com/fastrodev/fastrex"
func handler(req fastrex.Request, res fastrex.Response) {
res.Send("root")
}func routeMiddleware(req fastrex.Request, res fastrex.Response, next fastrex.Next) {
if req.URL.Path == "/" {
res.Send("appMiddleware")
return
}
}func main() {
app := fastrex.New()
app.Get("/", handler, routeMiddleware)
err := app.Listen(9000)
if err != nil {
panic(err)
}
}```
## Module
You can group static files, paths, routes, middlewares, and handlers into a module.
```go
package mainimport "github.com/fastrodev/fastrex"
func moduleMiddleware(req fastrex.Request, res fastrex.Response, next fastrex.Next) {
if req.URL.Path == "/api/user" {
res.Send("userMiddleware")
return
}
next(req, res)
}func handler(req fastrex.Request, res fastrex.Response) {
res.Send("userModule")
}func module(app fastrex.App) fastrex.App {
app.Use(moduleMiddleware)
app.Get("/user", handler)
return app
}func main() {
app := fastrex.New()
app.Register(module, "/api")
err := app.Listen(9000)
if err != nil {
panic(err)
}
}```
## Template
You can render html by create HTML template at `template` folder.
```html
{{.Title}}{{.Name}}
```
Then you add them to app with `Template` function.And finally, call `Render` function from handler.
```go
package mainimport "github.com/fastrodev/fastrex"
func handler(req fastrex.Request, res fastrex.Response) {
data := struct {
Title string
Name string
}{
"hallo",
"world",
}
err := res.Render(data)
if err != nil {
panic(err)
}
}func main() {
app := fastrex.New()
app.Template("template/app.html")
app.Get("/", handler)
err := app.Listen(9000)
if err != nil {
panic(err)
}
}```
## ServerlessYou can deploy your codes to [google cloud function](https://cloud.google.com/functions). With this approach, you don't call the `Listen` function again. You must create a new function as the entry point for standard net/http `Request` and` ResponseWriter`.
```go
package serverlessimport (
"net/http""github.com/fastrodev/fastrex"
)func handler(req fastrex.Request, res fastrex.Response) {
res.Json(`{"message":"hello"}`)
}func createApp() fastrex.App {
app := fastrex.New()
app.Get("/", handler)
return app
}func Main(w http.ResponseWriter, r *http.Request) {
createApp().Serverless(true).ServeHTTP(w, r)
}```
How to deploy:
```
gcloud functions deploy Main --runtime go116 --trigger-http --allow-unauthenticated
```
Demo and full example: [`https://github.com/fastrodev/serverless`](https://github.com/fastrodev/serverless)## Benchmarks
|Module|Requests/sec|Transfer/sec|
|--|--:|--:|
|Fastrex|95249.11|10.99MB|
|Go std|88700.49|10.83MB|
|Node std|50696.05|6.48MB|
|Express|9006.68|2.05MB|Benchmarks repository: [`https://github.com/fastrodev/benchmarks`](https://github.com/fastrodev/benchmarks)
## Contributing
We appreciate your help! The main purpose of this repository is to improve performance and readability, making it faster and easier to use.[build]: https://github.com/fastrodev/fastrex/actions/workflows/build.yml/badge.svg
[reference]: https://img.shields.io/badge/go.dev-reference-007d9c?logo=go&logoColor=white "reference"
[cov]: https://coveralls.io/repos/github/fastrodev/fastrex/badge.svg?branch=main