All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Support latest openapiv3 and indexmap. PR#507
- Pin openapiv3 to wa breaking change. PR#508
- Add support for
PathBuf
type. PR#502 - Add support for
actix-identity
type. PR#495 - Add support for
head
method type. PR#493
- Correct parameter name ordering. PR#504
- No spec path for
json_spec_v3
andswagger-ui
combination. PR#498
- Support non-boxed bodies in scope middleware. PR#457
- Add
uuid0
anduuid1
features. PR#461 - Add Content-Type Header to Swagger-UI Requests. PR#467
- Updated copyrights to use "Paperclip Contributors". PR#470
- Switch from
parking_lot
tostd::sync
. PR#473 - Replaced dependency
pin-project
withpin-project-lite
. PR#472
- Ensures that each chunk is written fully (code-gen). PR#491
- Strip template pattern from paths. PR#486
- Inconsistent behavior between
rapidoc
andswagger_ui
(extra slash). PR#460 - Fixed header-based
SecuritySchema
conversion forOpenAPI v3
. PR#458 - Respect host setting of v2 spec when converting to v3. PR#463
- Move root level extensions to root. PR#464
Apiv2Header
link in documentation. PR#468
- Add support for
PATCH
methods. PR#422 - Add support for header parameters through the newly introduced
Apiv2Header
derive macro. PR#413 - Add support for RapiDoc UI. PR#420
- Add example support for derived
Apiv2Schema
. PR#421 - Add ability to not generate documentation for some operations through the skip attribute on api_v2_schema macro. PR#423
- Add support for deprecated operations. PR#424
- Fix missing slash between url parts PR#416
- Properly support non-BoxBody response payload types PR#414
- Fix required fields definition when using serde flatten PR#412
- Fix reference urls not being RFC3986-compliant PR#411
- Add openapi component rename attribute PR#367
- Allow automatically adding the module path to the openapi component name, via a feature "path-in-definition" PR#373
- Add missing ip, ipv4 and ipv6 string format types
- Add support for actix-web 4
- Middleware support does not support non-
BoxBody
response payload types. As a workaround you can useactix-web::middlware::Compat
.
- Middleware support does not support non-
- Add support for Schemas wrapping Generic types (e.g.
DataResponse<T>
whereT
also derivesApiv2Schema
) PR#332 - Add support for actix-web validator PR#403
- Add more tuple sizes for web::Path for OperationModifier impl PR#379
- Add missing extensions to openapi v2 Info
- Schemas that enclose Generics are no longer conflicting/overwritten
- Actix2 plugin: fix compilation error
ReqData
not found
- Add support for actix-web-macros methods routing PR#289
- Actix plugin: add an empty impl for actix-web
ReqData<T>
- Add support for the
#[serde(skip)]
attribute in structs and enums. - Expose openapi v3 spec through
with_json_spec_v3_at
andwith_raw_json_spec_v3
- this is done through a conversion from the v2 types to v3 and so all existing code should be valid. It also means that we're not yet exposing any specific v3 features. - Added new method
trim_base_path
to trim the api base path from all method paths. Apiv2Schema
supportsurl
PR#334- Add swagger-ui for visualization/test of API via
with_swagger_ui_at
PR#331.
- Actix plugin:
#[api_v2_errors]
macro now supports adding different error schemes per response code. - Actix plugin: Add new
#[api_v2_errors_overlay]
macro which can be used to filter out unwanted responses from an existing error type.
- Optional type aliases like
type Email = Option<String>
will not be added to therequired
fields. - Actix plugin: Path tuples now inherit field names and descriptions from doc comments
0.5.0 - 2020-11-28
- Actix plugin: Support for actix-web 3.0 (is now default).
- Arrays up to length 32 are supported (in codegen and actix-web plugin).
- Actix plugin:
#[api_v2_operation]
macro now supports specifyingconsumes
,produces
,summary
,description
,tags
andoperation_id
in macro. - Actix plugin: Support for
actix-session
,serde_qs
andchrono
types in handlers. - Actix plugin:
App::wrap_api_with_spec
allows to provide default specification withinfo
and other custom settings - Actix plugin: Support tags in api_v2_operation macros.
- Actix plugin:
#[serde(flatten)]
support inApiv2Schema
derive. - Actix plugin: Added wrapper types for some 2xx status codes.
- Actix plugin: Refactored internals of
#[api_v2_operation]
proc macro (long-outstanding technical debt). This now generates operation metadata (on the fly) for each handler, which enables us to tie custom changes to operations easily. - Actix plugin: Grouping of parameters across handlers have been disabled as a result of major bugs (it's now under
normalize
feature). - Actix plugin: actix-web
2.x
is supported throughactix2
andactix2-nightly
features.
Apiv2Schema
supportsHashMap<Uuid, Foo>
.- Actix plugin:
#[api_v2_operation]
supports referencing inside handlers. - Actix plugin: Fixed a bug on using
where
clause in handlers marked with#[api_v2_operation]
. - Actix plugin: API objects have
object
type specified in their schemas.
0.4.1 - 2020-07-01
- Re-exported import from
proc-macro-error
which broke builds.
0.4.0 - 2020-06-13
- Client timeout in CLI.
- Codegen for header parameters in operations.
- Validation for non-body parameters.
x-rust-dependencies
field in root for specifying additional crate dependencies.- Default en/decoders (JSON/YAML) and support for custom en/decoders through
x-rust-coders
field in root. - Methods to
Schema
trait for aiding resolution and codegen. - Codegen for nested arrays in operation parameters.
- Codegen for form data parameters in operations.
- Codegen for
Any
type in schema. - CLI payload encoding/decoding supports custom types and not limited to JSON.
- Codegen for
#[deprecated]
attribute whendeprecated
field is set totrue
in schema. - Codegen adds
Request
andResponse
traits for HTTP request and response objects. - CLI uses name and version from
info
field in spec. - Codegen for file responses with streaming to
AsyncWrite
implementors. - Codegen for
multipart/form-data
parameters with file streaming. - Referencing globally defined parameters and responses.
- Codegen for enums in object definitions.
- Response wrapper containing headers and status code for operation.
- Parsing for custom response headers.
- Actix plugin:
#[openapi(empty)]
attribute can be used to any type to implement empty schema and ignore the warning. - Actix plugin: Empty impls for some actix-web types (like
Payload
,Data<T>
, etc.). - Actix plugin: Raw JSON spec generation from handlers.
- Actix plugin: Support for
#[serde(rename = "...")]
and#[serde(rename_all = "...")]
. - Actix plugin: Support for error (non-2xx) response codes.
- Actix plugin: Type-level and field-level documentation is now used for
description
fields in schema and properties. - Actix plugin: Security definitions (globally) and security requirements (for operations).
- Actix plugin: Support for
serde_json::Value
andserde_yaml::Value
(by default), and for objects fromuuid
,rust_decimal
,chrono
, etc. (through features of the same name) in structs.
- Switched to templating for (almost) static modules.
- Operation IDs are preferred for method names if they exist.
ApiClient
uses the newly addedRequest
andResponse
and is now async/await.Sendable
accepts the newApiClient
and is now async/await.SchemaRepr
renamed toResolvable
.OperationMap
renamed toPathItem
.Api
struct is now generic over parameters and responses in addition to definitions.- Actix plugin: Switched to
actix-web = "^2.0"
. - Actix plugin: Supports stable compiler.
- Actix plugin:
#[api_v2_schema]
macro attribute is now#[derive(Apiv2Schema)]
.
- Switched
enum
field to array ofany
rather than strings. - Resolution of anonymous schema definitions in objects, operation parameters and responses.
- Unmappable operations (i.e., without body parameters and simple response types) are now namespaced in a separate module.
- Array definitions are now allowed in schemas.
additionalProperties
takes boolean or a schema.- Deadlock when resolving some recursive types.
- Actix plugin:
.route()
method call onApp
,Scope
andServiceConfig
don't override existing route operations. - Actix plugin:
web::Path<T>
also supports simple types (strings, integers, etc.). - Actix plugin:
#[api_v2_schema]
derivatives can now use references. - Actix plugin: Breakage of
#[api_v2_operation]
when returningimpl Handler
. - Actix plugin:
web::scope
supports having path parameters. - Actix plugin: Misuse of
actix_web::Scope
inApp::configure
which resulted in missing overwritten routes.
0.3.0 - 2019-07-30
- Paperclip's
#[api_v2_schema]
derives raw schema structs (i.e., no smart pointers) along with actual schema structs for other users and plugins. An effect of this would be that now there's aDefaultSchemaRaw
in addition toDefaultSchema
. TypedData
,Apiv2Schema
andApiv2Operation
traits for deriving v2 spec for server plugins.paperclip-core
crate for segregating core types and traits.paperclip-actix
crate as an actix-web plugin for hosting v2 spec as a JSON by marking models and operations using proc macro attributes.paperclip::actix
module for exportingpaperclip_actix::*
whenactix
feature is enabled.
- Segregated dependencies using feature gates.
Api::<S>::resolve
now returnsValidationError
instead offailure::Error
.- During serialization, optional schema fields are skipped when empty/null.
- Allowing ports in
host
field in v2 spec.
0.2.0 - 2019-07-03
- Gitbook for detailed documentation and walkthroughs.
- Changelog
- Root module (
mod.rs
,lib.rs
ormain.rs
) generation for codegen (previously we were only generating children modules). - Cargo manifest generation (gated by
"cli"
feature). [bin]
target (CLI) for generating crates.- CLI generation (fancy curl for your APIs) - generated app uses async/await and
runtime_tokio
. ApiClient::make_request
for sending a request and fetching a response future.- Support for operations returning array of objects.
- Codegen uses
basePath
andhost
fields (if they exist) to override default base URL (https://example.com
). - API relative paths are checked for uniqueness.
- Codegen now writes the dependency traits, types and impls in the root module.
ApiClient::base_url
in favor ofApiClient::make_request
- Redundant
Optional
trait for generated markers.
- Templated paths are now validated against parameters.
- Import prefixes support in emitter (for codegen).
0.1.0 - 2019-06-13
- Build script example in README.
impl Sendable
for fulfilled builders to send API requests and return response futures.- Documentation for builders and methods from
description
fields. - Generation of
#[repr(transparent)]
builders with phantom fields for enforcing required parameters. - Generation of builders for API objects and operations.
- Generation of Rust structs with appropriate serde rules from definitions.
#[api_schema]
proc-macro attribute for implementingSchema
trait for custom schemas.- Resolution of
$ref
references in definitions and paths to objects in the same file. - Loading OpenAPI v2 schema from JSON/YAML
- Workspace, README, LICENSE, Makefile, CI config, etc.