Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/onrik/gaws
OpenAPI doc generator for Golang
https://github.com/onrik/gaws
golang openapi openapi3 swagger swagger2
Last synced: 2 months ago
JSON representation
OpenAPI doc generator for Golang
- Host: GitHub
- URL: https://github.com/onrik/gaws
- Owner: onrik
- License: mit
- Created: 2022-07-19T06:25:23.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-30T10:14:04.000Z (3 months ago)
- Last Synced: 2024-10-30T11:24:21.803Z (3 months ago)
- Topics: golang, openapi, openapi3, swagger, swagger2
- Language: Go
- Homepage:
- Size: 48.8 KB
- Stars: 4
- Watchers: 2
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Gaws
OpenAPI (swagger) docs generator for Golang.
## Examples
```golang
package usersimport (
"net/http"
"time"
)type Group struct {
Name string `json:"name"`
}type User struct {
_ struct{} `json:"-" openapiDesc:"User"` // Description for enitre struct
ID uint `json:"id"`
Name string `json:"name" openapiExt:"x-ext-key:ext-value"` // Passing openapi extensions to spec as is
Email string `json:"email" openapiDesc:"User's email"` // Description for current field
IsAdmin bool `json:"is_admin"`
Groups []Group `json:"groups"`
CreatedAt time.Time `json:"created_at"`
Status string `json:"status" openapiEnum:"new,confirmed,deleted"` // Enum for current field values
}type createUserRequest struct {
Email string `json:"email"`
Name string `json:"name"`
Password1 string `json:"password1"`
Password2 string `json:"password2"`
IsAdmin bool `json:"is_admin"`
Groups []string `json:"groups"`
}type updateUserRequest struct {
Email *string `json:"email,omitempty"`
Name *string `json:"name,omitempty"`
Password *string `json:"password,omitempty"`
IsAdmin *bool `json:"is_admin,omitempty"`
Groups *[]string `json:"groups,omitempty"`
}/*
Users returns users list
@openapi GET /api/v1/users
@openapiParam q in=query, type=string, example=John
@openapiResponse 200 application/json {"users": []User}
*/
func Users(w http.ResponseWriter, r *http.Request) {
}/*
CreateUser creates user
@openapi POST /api/v1/users
@openapiRequest application/json createUserRequest
@openapiResponse 400 application/json {"message": "email=email;name=required"}
@openapiResponse 200 application/json {"user": User}
*/
func CreateUser(w http.ResponseWriter, r *http.Request) {
}/*
UpdateUser updates user
@openapi POST /api/v1/users/{id}
@openapiParam id in=path, type=int, example=56
@openapiRequest application/json updateUserRequest
@openapiResponse 404 application/json {"message": "Not Found"}
@openapiResponse 200 application/json {"user": User}
*/
func UpdateUser(w http.ResponseWriter, r *http.Request) {
}/*
DeleteUser delete user
@openapi DELETE /api/v1/users/{id}
@openapiParam id in=path, type=int, example=56
@openapiResponse 404 application/json {"message": "Not Found"}
@openapiResponse 200 application/json {}
*/
func DeleteUser(w http.ResponseWriter, r *http.Request) {
}```