- fix broken param parsing caused from Plug 1.11.0
- allow swagger ui validator url to be customized
- validatorUrl replaced with configUrl
- warning messages fixed for Elixir 1.11
- dialyxir, plug, ex_json_schema and other dependencies are updated to the latests versions
- 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
- 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 theresources
convention), then callingdelete/2
fromPhoenixSwagger.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.