- Add support for Phoenix ~> 1.4.9
- Ability to configure json library e.g. config
:phoenix_swagger, json_library: Jason
- Improvements in SwagerUI Plug
- Update dependencies
- Bug fixes
- Add
add_module/2
function to add path and schema definitions not in controllers.
- Fix for crash on non-GET requests
- Fix compilation error running
mix phx.swagger.generate
beforemix compile
- Validate number type in query parameter
- Add
id
andtype
properties to theincluded
-items schema - Add
Schema.nullable
function to set thex-nullable
property - Add
nullable:
option toJsonSchema.relationship
function - Handle
x-nullable
schemas inSchemaTest
- Add
deprecated
flag for operations
- Passing module names and output path as mix task parameters is no longer supported.
- Inferring default module names from mix project is no longer supported.
- Swagger file outputs, router module and optional endpoint module must now be specified in application config:
config :my_app, :phoenix_swagger,
swagger_files: %{
"priv/static/swagger.json" => [router: MyAppWeb.Router, endpoint: MyAppWeb.Endpoint],
# additional swagger files here
}
phoenix_swagger
can now be run as a mix compiler task, ensuring that the generated swagger is kept in sync with code, and enabling live reloading.
compilers: [:phoenix, :gettext, :phoenix_swagger] ++ Mix.compilers
- The HTTP verb and path can now be inferred from the phoenix router:
swagger_path :show do
get "/api/users/{id}
description "Gets a user by ID"
response 200, "OK", Schema.ref(User)
end
Can now be written without the get
:
swagger_path :show do
description "Gets a user by ID"
response 200, "OK", Schema.ref(User)
end
Note that if your controller contains a delete/2
function (such as when using the resources
convention), then calling delete/2
from PhoenixSwagger.Path
will now cause a compilation error. To avoid this problem, include the full module (shown below), or simply remove the line and allow the verb and path to be inferred from the route:
swagger_path(:delete) do
PhoenixSwagger.Path.delete "/api/users/{id}"
summary "Delete User"
end
- Use the :load_from_system_env Endpoint config flag to detect dynamic host and port configuration
- Minor fix that supports the Phoenix 1.3 namespacing, where it is {Project}Web instead of {Project}.Web.
- Add support for has_many relationships for JSON-API resource schemas
- Upgrade to swagger-ui 3.1.7
- Tests for nested and non-nested required parameters for
PhoenixSwagger.Plug.Validate
. - Decode parameter names using
Plug.Conn.Query.decode
and walkconn.params
to find the nested param asconn.params
is already nested whileparameter["name"]
is not when received byPhoenixSwagger.Plug.Validate.validate_query_params/2
.
- Adds support to enable security by endpoint
PhoenixSwagger.Plug.Validate
sets response content type on error toapplication/json
PhoenixSwagger.Plug.Validate
accepts:validation_failed_status
option, defaults to 400- Example application includes usage of validator
- Adds support for custom Endpoint module names by passing
--endpoint
- Added patch request support
- fix path assignation of a swagger specification file in UI plug
- add
disable_validator
option to disable/enable validation of a swagger schema.
- Provide default host and port when generating swagger host config
- Suppress host config when dynamic hostname or port are used
- Use phoenix 1.3 conventions for mix tasks and module names
- Add
PhoenixSwagger.SchemaTest
module for response validation - Swagger UI plug redirects / to /index.html automatically avoiding errors when fetching assets.
- Swagger UI configured to list all operations by default
- Allow property schemas to be declared inline using
Schema.new
macro - Allow schemas to include an example
- Add support for
discriminator
in polymorphic schemas - Do not set a host if a url has not been provided
- Ability to validate boolean values
- Include swagger-ui plug
PhoenixSwagger.Plug.SwaggerUI
- Allow for a list of types on
PhoenixSwagger.Schema.type
- Fix not running all doctests
- Fix
ArgumentError
inPhoenix.Swagger.Generate
when routing to plug with keyword opts #58
- Fix FunctionClauseError in
response
when noproduces
mime type defined on an operation.
- Fix compilation errors when using
PhoenixSwagger.JsonApi
macros
- Add
PhoenixSwagger.Schema
module that provides a structure which represents swagger schema. - Add
swagger_schema
macro to build a swagger schema. - New JSON-API helpers.
- Provide documentation with ex_doc.
- And other changes from @everydayhero fork.