Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/go-andiamo/chioas
Go package for defining Chi apis (with OpenAPI generated specs)
https://github.com/go-andiamo/chioas
api chi go golang oas openapi swagger swagger-ui
Last synced: 3 months ago
JSON representation
Go package for defining Chi apis (with OpenAPI generated specs)
- Host: GitHub
- URL: https://github.com/go-andiamo/chioas
- Owner: go-andiamo
- License: apache-2.0
- Created: 2023-07-02T12:49:48.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-07-01T18:16:55.000Z (7 months ago)
- Last Synced: 2024-10-31T10:51:29.522Z (3 months ago)
- Topics: api, chi, go, golang, oas, openapi, swagger, swagger-ui
- Language: Go
- Homepage:
- Size: 1.68 MB
- Stars: 23
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: security.go
Awesome Lists containing this project
README
# CHIOAS
[![GoDoc](https://godoc.org/github.com/go-andiamo/chioas?status.svg)](https://pkg.go.dev/github.com/go-andiamo/chioas)
[![Latest Version](https://img.shields.io/github/v/tag/go-andiamo/chioas.svg?sort=semver&style=flat&label=version&color=blue)](https://github.com/go-andiamo/chioas/releases)
[![Go Report Card](https://goreportcard.com/badge/github.com/go-andiamo/chioas)](https://goreportcard.com/report/github.com/go-andiamo/chioas)*Chioas* is an add-on for the popular [Chi router](https://github.com/go-chi/chi)
> pronounce *Chioas* however you like...
>
> but I can't help feeling that it looks a little like "chaos" - the chaos of undocumented APIs that it tries to solve!### What it does
*Chioas* does three things:
* Defines your API as a single (or modular) struct and then builds the Chi routes accordingly
* Produces an OpenApi spec (OAS) of that definition
* Optionally serves an interactive API docs web-page (as part of your service)### Advantages
With your actual API and OpenAPI spec (OAS) being specified in _**one**_ place there's no chance of them becoming out of sync! (eliminating having to manually update spec yaml/json to match API or vice versa)You can even keep your request/response OAS schemas in sync with your request/response structs!
See [petstore example](https://github.com/go-andiamo/chioas/tree/main/_examples/petstore)### Already have an OAS spec?
No problem, use `chioas.FromJson()` or `chioas.FromYaml()` to read the spec definition.
All you'll need to do is add `x-handler` tags to each method in the spec.See [From example](https://github.com/go-andiamo/chioas/tree/main/_examples/from)
### Choice of UI styles
*Chioas* supports two different styles of API docs UI:
1. Redoc (see [Redocly.redoc](https://github.com/Redocly/redoc) and [Redoc-try](https://github.com/wll8/redoc-try))
2. Swagger (see [swagger-ui](https://github.com/swagger-api/swagger-ui))
3. Rapidoc (see [rapidoc](https://github.com/rapi-doc/RapiDoc))Set the desired style using `DocOptions.UIStyle` (the default is `Redoc`).
Notes:
* statics for `Redoc` are served from CDNs
* statics for `Swagger` are all served directly from *Chioas*
* statics for `Rapidoc` are all served directly from *Chioas**Chioas* also supports serving multiple styles of UI on different docs paths (see `DocOptions.AlternateUIDocs` and [example](https://github.com/go-andiamo/chioas/tree/main/_examples/multi_ui))
### Added Bonus Features
Chioas comes with many bonus features that help in building complete APIs and specs...
* Highly extensible - e.g. if there are parts of the OAS spec that are not directly supported by Chioas, then they can be added using the `Additional` field on each part
* Optionally check that OAS refs (`$ref`) are valid _(see `DocOptions.CheckRefs`)_
* Optional typed handlers - see [typed README](https://github.com/go-andiamo/chioas/blob/main/typed/README.md)
* Optional automatically added `HEAD` methods for `GET` methods _(see `Definition.AutoHeadMethods`)_
* Optional automatically added `OPTIONS` methods - with `Allow` header populated with actual allowed methods _(see `Definition.AutoOptionsMethods` and `Path.AutoOptionsMethod`)_
* Optional automatically added Chi `MethodNotAllowed` handler to each path - with `Allow` header populated with actual allowed methods _(see `Definition.AutoMethodNotAllowed`)_## Installation
To install chioas, use go get:go get github.com/go-andiamo/chioas
To update chioas to the latest version, run:
go get -u github.com/go-andiamo/chioas
## Basic Example
```go
package mainimport (
"github.com/go-andiamo/chioas"
"github.com/go-chi/chi/v5"
"net/http"
)func main() {
router := chi.NewRouter()
if err := myApi.SetupRoutes(router, myApi); err != nil {
panic(err)
}
_ = http.ListenAndServe(":8080", router)
}var myApi = chioas.Definition{
AutoHeadMethods: true,
DocOptions: chioas.DocOptions{
ServeDocs: true,
HideHeadMethods: true,
},
Paths: chioas.Paths{
"/foos": {
Methods: chioas.Methods{
http.MethodGet: {
Handler: getFoos,
Responses: chioas.Responses{
http.StatusOK: {
Description: "List of foos",
IsArray: true,
SchemaRef: "foo",
},
},
},
http.MethodPost: {
Handler: postFoos,
Request: &chioas.Request{
Description: "Foo to create",
SchemaRef: "foo",
},
Responses: chioas.Responses{
http.StatusCreated: {
Description: "New foo",
SchemaRef: "foo",
},
},
},
http.MethodHead: {
Handler: getFoos,
},
},
Paths: chioas.Paths{
"/{fooId}": {
Methods: chioas.Methods{
http.MethodGet: {
Handler: getFoo,
Responses: chioas.Responses{
http.StatusOK: {
Description: "The foo",
SchemaRef: "foo",
},
},
},
http.MethodDelete: {
Handler: deleteFoo,
},
},
},
},
},
},
Components: &chioas.Components{
Schemas: chioas.Schemas{
{
Name: "foo",
RequiredProperties: []string{"name", "address"},
Properties: chioas.Properties{
{
Name: "name",
Type: "string",
},
{
Name: "address",
Type: "string",
},
},
},
},
},
}func getFoos(writer http.ResponseWriter, request *http.Request) {
}func postFoos(writer http.ResponseWriter, request *http.Request) {
}func getFoo(writer http.ResponseWriter, request *http.Request) {
}func deleteFoo(writer http.ResponseWriter, request *http.Request) {
}
```
Run and then check out http://localhost:8080/docs !Or simply generate the OpenAPI spec...
```go
package mainimport (
"net/http""github.com/go-andiamo/chioas"
)func main() {
data, _ := myApi.AsYaml()
println(string(data))
}var myApi = chioas.Definition{
AutoHeadMethods: true,
DocOptions: chioas.DocOptions{
ServeDocs: true,
HideHeadMethods: true,
},
Paths: chioas.Paths{
"/foos": {
Methods: chioas.Methods{
http.MethodGet: {
Handler: getFoos,
Responses: chioas.Responses{
http.StatusOK: {
Description: "List of foos",
IsArray: true,
SchemaRef: "foo",
},
},
},
http.MethodPost: {
Handler: postFoos,
Request: &chioas.Request{
Description: "Foo to create",
SchemaRef: "foo",
},
Responses: chioas.Responses{
http.StatusCreated: {
Description: "New foo",
SchemaRef: "foo",
},
},
},
http.MethodHead: {
Handler: getFoos,
},
},
Paths: chioas.Paths{
"/{fooId}": {
Methods: chioas.Methods{
http.MethodGet: {
Handler: getFoo,
Responses: chioas.Responses{
http.StatusOK: {
Description: "The foo",
SchemaRef: "foo",
},
},
},
http.MethodDelete: {
Handler: deleteFoo,
},
},
},
},
},
},
Components: &chioas.Components{
Schemas: chioas.Schemas{
{
Name: "foo",
RequiredProperties: []string{"name", "address"},
Properties: chioas.Properties{
{
Name: "name",
Type: "string",
},
{
Name: "address",
Type: "string",
},
},
},
},
},
}func getFoos(writer http.ResponseWriter, request *http.Request) {
}func postFoos(writer http.ResponseWriter, request *http.Request) {
}func getFoo(writer http.ResponseWriter, request *http.Request) {
}func deleteFoo(writer http.ResponseWriter, request *http.Request) {
}
```
[try on go-playground](https://go.dev/play/p/0zaWsmsw2FD)