Merge pull request 'Document the API using OpenAPI' (#127) from rswag-documentation into main
Reviewed-on: #127
This commit is contained in:
commit
21d3aa5f4b
3
.gitignore
vendored
3
.gitignore
vendored
@ -33,3 +33,6 @@
|
|||||||
|
|
||||||
# Ignore master key for decrypting credentials and more.
|
# Ignore master key for decrypting credentials and more.
|
||||||
/config/master.key
|
/config/master.key
|
||||||
|
|
||||||
|
# Ignore swagger generated documentation
|
||||||
|
swagger/v1/swagger.yaml
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# syntax = docker/dockerfile:1
|
# syntax = docker/dockerfile:1
|
||||||
|
|
||||||
# Make sure RUBY_VERSION matches the Ruby version in .ruby-version and Gemfile
|
# Make sure RUBY_VERSION matches the Ruby version in .ruby-version and Gemfile
|
||||||
ARG RUBY_VERSION=3.3.5
|
ARG RUBY_VERSION=3.3.6
|
||||||
FROM registry.docker.com/library/ruby:$RUBY_VERSION-slim as base
|
FROM registry.docker.com/library/ruby:$RUBY_VERSION-slim as base
|
||||||
|
|
||||||
# Rails app lives here
|
# Rails app lives here
|
||||||
|
1
Gemfile
1
Gemfile
@ -28,6 +28,7 @@ group :development, :test do
|
|||||||
gem 'license_finder'
|
gem 'license_finder'
|
||||||
gem 'pry'
|
gem 'pry'
|
||||||
gem 'rspec-rails', '~> 7.1.0'
|
gem 'rspec-rails', '~> 7.1.0'
|
||||||
|
gem 'rswag'
|
||||||
gem 'shoulda-matchers', '~> 6.0'
|
gem 'shoulda-matchers', '~> 6.0'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
21
Gemfile.lock
21
Gemfile.lock
@ -72,6 +72,8 @@ GEM
|
|||||||
securerandom (>= 0.3)
|
securerandom (>= 0.3)
|
||||||
tzinfo (~> 2.0, >= 2.0.5)
|
tzinfo (~> 2.0, >= 2.0.5)
|
||||||
uri (>= 0.13.1)
|
uri (>= 0.13.1)
|
||||||
|
addressable (2.8.7)
|
||||||
|
public_suffix (>= 2.0.2, < 7.0)
|
||||||
annotaterb (4.13.0)
|
annotaterb (4.13.0)
|
||||||
ast (2.4.2)
|
ast (2.4.2)
|
||||||
babel-source (5.8.35)
|
babel-source (5.8.35)
|
||||||
@ -127,6 +129,8 @@ GEM
|
|||||||
actionview (>= 5.0.0)
|
actionview (>= 5.0.0)
|
||||||
activesupport (>= 5.0.0)
|
activesupport (>= 5.0.0)
|
||||||
json (2.7.5)
|
json (2.7.5)
|
||||||
|
json-schema (5.0.1)
|
||||||
|
addressable (~> 2.8)
|
||||||
jsonapi-deserializable (0.2.0)
|
jsonapi-deserializable (0.2.0)
|
||||||
jsonapi-parser (0.1.1)
|
jsonapi-parser (0.1.1)
|
||||||
jsonapi-rails (0.4.1)
|
jsonapi-rails (0.4.1)
|
||||||
@ -195,6 +199,7 @@ GEM
|
|||||||
method_source (~> 1.0)
|
method_source (~> 1.0)
|
||||||
psych (5.2.0)
|
psych (5.2.0)
|
||||||
stringio
|
stringio
|
||||||
|
public_suffix (6.0.1)
|
||||||
puma (6.4.3)
|
puma (6.4.3)
|
||||||
nio4r (~> 2.0)
|
nio4r (~> 2.0)
|
||||||
raabro (1.4.0)
|
raabro (1.4.0)
|
||||||
@ -272,6 +277,21 @@ GEM
|
|||||||
rspec-mocks (~> 3.13)
|
rspec-mocks (~> 3.13)
|
||||||
rspec-support (~> 3.13)
|
rspec-support (~> 3.13)
|
||||||
rspec-support (3.13.1)
|
rspec-support (3.13.1)
|
||||||
|
rswag (2.16.0)
|
||||||
|
rswag-api (= 2.16.0)
|
||||||
|
rswag-specs (= 2.16.0)
|
||||||
|
rswag-ui (= 2.16.0)
|
||||||
|
rswag-api (2.16.0)
|
||||||
|
activesupport (>= 5.2, < 8.1)
|
||||||
|
railties (>= 5.2, < 8.1)
|
||||||
|
rswag-specs (2.16.0)
|
||||||
|
activesupport (>= 5.2, < 8.1)
|
||||||
|
json-schema (>= 2.2, < 6.0)
|
||||||
|
railties (>= 5.2, < 8.1)
|
||||||
|
rspec-core (>= 2.14)
|
||||||
|
rswag-ui (2.16.0)
|
||||||
|
actionpack (>= 5.2, < 8.1)
|
||||||
|
railties (>= 5.2, < 8.1)
|
||||||
rubocop (1.68.0)
|
rubocop (1.68.0)
|
||||||
json (~> 2.3)
|
json (~> 2.3)
|
||||||
language_server-protocol (>= 3.17.0)
|
language_server-protocol (>= 3.17.0)
|
||||||
@ -362,6 +382,7 @@ DEPENDENCIES
|
|||||||
react-rails
|
react-rails
|
||||||
redis (>= 4.0.1)
|
redis (>= 4.0.1)
|
||||||
rspec-rails (~> 7.1.0)
|
rspec-rails (~> 7.1.0)
|
||||||
|
rswag
|
||||||
rubocop
|
rubocop
|
||||||
rubytree
|
rubytree
|
||||||
shoulda-matchers (~> 6.0)
|
shoulda-matchers (~> 6.0)
|
||||||
|
10
README.md
10
README.md
@ -68,6 +68,16 @@ Unit tests can be executed with
|
|||||||
bundle exec rspec
|
bundle exec rspec
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## API documentation
|
||||||
|
|
||||||
|
Generate the OpenAPI documentation with the command:
|
||||||
|
|
||||||
|
```
|
||||||
|
rake rswag:specs:swaggerize
|
||||||
|
```
|
||||||
|
|
||||||
|
The documentation is available in Swagger UI in http://libre-wedding-planner.app.localhost/api/api-docs/index.html. If testing the API through the UI, you will need to select the second server (which includes the `/api` path), intended for development.
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
Contributions of all kinds (code, UX/UI, testing, translations, etc.) are welcome. The procedures to contribute are still being defined, but don't hesitate to reach out in case you want to participate.
|
Contributions of all kinds (code, UX/UI, testing, translations, etc.) are welcome. The procedures to contribute are still being defined, but don't hesitate to reach out in case you want to participate.
|
||||||
|
@ -10,7 +10,7 @@ module Groups
|
|||||||
|
|
||||||
def query
|
def query
|
||||||
<<~SQL.squish
|
<<~SQL.squish
|
||||||
SELECT#{' '}
|
SELECT
|
||||||
groups.id,
|
groups.id,
|
||||||
groups.name,
|
groups.name,
|
||||||
groups.icon,
|
groups.icon,
|
||||||
|
16
config/initializers/rswag_api.rb
Normal file
16
config/initializers/rswag_api.rb
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
# Copyright (C) 2024 Manuel Bustillo
|
||||||
|
|
||||||
|
Rswag::Api.configure do |c|
|
||||||
|
|
||||||
|
# Specify a root folder where Swagger JSON files are located
|
||||||
|
# This is used by the Swagger middleware to serve requests for API descriptions
|
||||||
|
# NOTE: If you're using rswag-specs to generate Swagger, you'll need to ensure
|
||||||
|
# that it's configured to generate files in the same folder
|
||||||
|
c.openapi_root = Rails.root.to_s + '/swagger'
|
||||||
|
|
||||||
|
# Inject a lambda function to alter the returned Swagger prior to serialization
|
||||||
|
# The function will have access to the rack env for the current request
|
||||||
|
# For example, you could leverage this to dynamically assign the "host" property
|
||||||
|
#
|
||||||
|
#c.swagger_filter = lambda { |swagger, env| swagger['host'] = env['HTTP_HOST'] }
|
||||||
|
end
|
18
config/initializers/rswag_ui.rb
Normal file
18
config/initializers/rswag_ui.rb
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# Copyright (C) 2024 Manuel Bustillo
|
||||||
|
|
||||||
|
Rswag::Ui.configure do |c|
|
||||||
|
|
||||||
|
# List the Swagger endpoints that you want to be documented through the
|
||||||
|
# swagger-ui. The first parameter is the path (absolute or relative to the UI
|
||||||
|
# host) to the corresponding endpoint and the second is a title that will be
|
||||||
|
# displayed in the document selector.
|
||||||
|
# NOTE: If you're using rspec-api to expose Swagger files
|
||||||
|
# (under openapi_root) as JSON or YAML endpoints, then the list below should
|
||||||
|
# correspond to the relative paths for those endpoints.
|
||||||
|
|
||||||
|
c.swagger_endpoint '/api/api-docs/v1/swagger.yaml', 'API V1 Docs'
|
||||||
|
|
||||||
|
# Add Basic Auth in case your API is private
|
||||||
|
# c.basic_auth_enabled = true
|
||||||
|
# c.basic_auth_credentials 'username', 'password'
|
||||||
|
end
|
@ -1,6 +1,8 @@
|
|||||||
# Copyright (C) 2024 Manuel Bustillo
|
# Copyright (C) 2024 Manuel Bustillo
|
||||||
|
|
||||||
Rails.application.routes.draw do
|
Rails.application.routes.draw do
|
||||||
|
mount Rswag::Ui::Engine => '/api-docs'
|
||||||
|
mount Rswag::Api::Engine => '/api-docs'
|
||||||
resources :groups, only: :index
|
resources :groups, only: :index
|
||||||
resources :guests, only: %i[index update] do
|
resources :guests, only: %i[index update] do
|
||||||
post :bulk_update, on: :collection
|
post :bulk_update, on: :collection
|
||||||
|
32
spec/requests/groups_spec.rb
Normal file
32
spec/requests/groups_spec.rb
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
# Copyright (C) 2024 Manuel Bustillo
|
||||||
|
|
||||||
|
require 'swagger_helper'
|
||||||
|
|
||||||
|
RSpec.describe 'groups', type: :request do
|
||||||
|
path '/groups' do
|
||||||
|
get('list groups') do
|
||||||
|
produces 'application/json'
|
||||||
|
response(200, 'successful') do
|
||||||
|
schema type: :array,
|
||||||
|
items: {
|
||||||
|
type: :object,
|
||||||
|
required: %i[id name icon parent_id color total considered invited confirmed declined tentative],
|
||||||
|
properties: {
|
||||||
|
id: { type: :string, format: :uuid, required: true },
|
||||||
|
name: { type: :string },
|
||||||
|
icon: { type: :string, example: 'pi pi-crown', description: 'The CSS classes used by the icon' },
|
||||||
|
parent_id: { type: :string, format: :uuid },
|
||||||
|
color: { type: :string, pattern: '^#(?:[0-9a-fA-F]{3}){1,2}$' },
|
||||||
|
total: { type: :integer, minimum: 0, description: 'Total number of guests in any status' },
|
||||||
|
considered: { type: :integer, minimum: 0 },
|
||||||
|
invited: { type: :integer, minimum: 0 },
|
||||||
|
confirmed: { type: :integer, minimum: 0 },
|
||||||
|
declined: { type: :integer, minimum: 0 },
|
||||||
|
tentative: { type: :integer, minimum: 0 }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
run_test!
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
45
spec/swagger_helper.rb
Normal file
45
spec/swagger_helper.rb
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
# Copyright (C) 2024 Manuel Bustillo
|
||||||
|
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.configure do |config|
|
||||||
|
# Specify a root folder where Swagger JSON files are generated
|
||||||
|
# NOTE: If you're using the rswag-api to serve API descriptions, you'll need
|
||||||
|
# to ensure that it's configured to serve Swagger from the same folder
|
||||||
|
config.openapi_root = Rails.root.join('swagger').to_s
|
||||||
|
|
||||||
|
# Define one or more Swagger documents and provide global metadata for each one
|
||||||
|
# When you run the 'rswag:specs:swaggerize' rake task, the complete Swagger will
|
||||||
|
# be generated at the provided relative path under openapi_root
|
||||||
|
# By default, the operations defined in spec files are added to the first
|
||||||
|
# document below. You can override this behavior by adding a openapi_spec tag to the
|
||||||
|
# the root example_group in your specs, e.g. describe '...', openapi_spec: 'v2/swagger.json'
|
||||||
|
config.openapi_specs = {
|
||||||
|
'v1/swagger.yaml' => {
|
||||||
|
openapi: '3.0.1',
|
||||||
|
info: {
|
||||||
|
title: 'API V1',
|
||||||
|
version: 'v1'
|
||||||
|
},
|
||||||
|
paths: {},
|
||||||
|
servers: [
|
||||||
|
{
|
||||||
|
url: '/',
|
||||||
|
description: 'suitable for testing'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
url: 'http://libre-wedding-planner.app.localhost/api',
|
||||||
|
description: 'Suitable for development'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Specify the format of the output Swagger file when running 'rswag:specs:swaggerize'.
|
||||||
|
# The openapi_specs configuration option has the filename including format in
|
||||||
|
# the key, this may want to be changed to avoid putting yaml in json files.
|
||||||
|
# Defaults to json. Accepts ':json' and ':yaml'.
|
||||||
|
config.openapi_format = :yaml
|
||||||
|
end
|
Loading…
x
Reference in New Issue
Block a user