mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-08-04 04:20:12 +03:00
3.7 release announcement & related docs.
This commit is contained in:
parent
de4ec58ccf
commit
51ceabbea1
|
@ -53,7 +53,7 @@ There is a live example API for testing purposes, [available here][sandbox].
|
|||
# Requirements
|
||||
|
||||
* Python (2.7, 3.4, 3.5, 3.6)
|
||||
* Django (1.10, 1.11)
|
||||
* Django (1.10, 1.11, 2.0 alpha)
|
||||
|
||||
# Installation
|
||||
|
||||
|
|
|
@ -155,7 +155,7 @@ Basic usage is just to provide the title for your schema and call
|
|||
generator = schemas.SchemaGenerator(title='Flight Search API')
|
||||
schema = generator.get_schema()
|
||||
|
||||
### Per-View Schema Customisation
|
||||
## Per-View Schema Customisation
|
||||
|
||||
By default, view introspection is performed by an `AutoSchema` instance
|
||||
accessible via the `schema` attribute on `APIView`. This provides the
|
||||
|
@ -191,7 +191,7 @@ To customise the `Link` generation you may:
|
|||
|
||||
class CustomSchema(AutoSchema):
|
||||
def get_link(...):
|
||||
# Implemet custom introspection here (or in other sub-methods)
|
||||
# Implement custom introspection here (or in other sub-methods)
|
||||
|
||||
class CustomView(APIView):
|
||||
...
|
||||
|
@ -784,3 +784,4 @@ in [OpenAPI][open-api] format.
|
|||
[api-blueprint]: https://apiblueprint.org/
|
||||
[static-files]: https://docs.djangoproject.com/en/stable/howto/static-files/
|
||||
[named-arguments]: https://docs.djangoproject.com/en/stable/topics/http/urls/#named-groups
|
||||
|
BIN
docs/img/bayer.png
Normal file
BIN
docs/img/bayer.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 42 KiB |
|
@ -87,7 +87,7 @@ continued development by **[signing up for a paid plan][funding]**.
|
|||
REST framework requires the following:
|
||||
|
||||
* Python (2.7, 3.2, 3.3, 3.4, 3.5, 3.6)
|
||||
* Django (1.8, 1.9, 1.10, 1.11)
|
||||
* Django (1.10, 1.11, 2.0 alpha)
|
||||
|
||||
The following packages are optional:
|
||||
|
||||
|
@ -247,6 +247,7 @@ General guides to using REST framework.
|
|||
* [3.4 Announcement][3.4-announcement]
|
||||
* [3.5 Announcement][3.5-announcement]
|
||||
* [3.6 Announcement][3.6-announcement]
|
||||
* [3.7 Announcement][3.7-announcement]
|
||||
* [Kickstarter Announcement][kickstarter-announcement]
|
||||
* [Mozilla Grant][mozilla-grant]
|
||||
* [Funding][funding]
|
||||
|
@ -377,6 +378,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||
[3.4-announcement]: topics/3.4-announcement.md
|
||||
[3.5-announcement]: topics/3.5-announcement.md
|
||||
[3.6-announcement]: topics/3.6-announcement.md
|
||||
[3.7-announcement]: topics/3.7-announcement.md
|
||||
[kickstarter-announcement]: topics/kickstarter-announcement.md
|
||||
[mozilla-grant]: topics/mozilla-grant.md
|
||||
[funding]: topics/funding.md
|
||||
|
|
|
@ -1,29 +1,131 @@
|
|||
|
||||
<style>
|
||||
.promo li a {
|
||||
float: left;
|
||||
width: 130px;
|
||||
height: 20px;
|
||||
text-align: center;
|
||||
margin: 10px 30px;
|
||||
padding: 150px 0 0 0;
|
||||
background-position: 0 50%;
|
||||
background-size: 130px auto;
|
||||
background-repeat: no-repeat;
|
||||
font-size: 120%;
|
||||
color: black;
|
||||
}
|
||||
.promo li {
|
||||
list-style: none;
|
||||
}
|
||||
</style>
|
||||
|
||||
# Django REST framework 3.7
|
||||
|
||||
The 3.7 release focuses on improvements to schema generation and interactive API
|
||||
documentation.
|
||||
The 3.7 release focuses on improvements to schema generation and the interactive API documentation.
|
||||
|
||||
## Per-view customisation of schema generation.
|
||||
This release has been made possible by [Bayer](https://www.bayer.com/) who have sponsored the release.
|
||||
|
||||
`APIView` now exposes a `schema` attribute. By default this is an instance of
|
||||
`rest_framwork.schemas.AutoSchema`. You can subclass this to customise schema
|
||||
generation on a per-view basis, whilst maintaining the default schema generation
|
||||
elsewhere.
|
||||
<a href="https://www.bayer.com/"><img src="/img/bayer.png"/></a>
|
||||
|
||||
See [Schema Docs][schema-docs] for full details.
|
||||
---
|
||||
|
||||
[schema-docs]: ../api-guide/schemas.md
|
||||
## Funding
|
||||
|
||||
If you use REST framework commercially and would like to see this work continue, we strongly encourage you to invest in its continued development by
|
||||
**[signing up for a paid plan][funding]**.
|
||||
|
||||
<ul class="premium-promo promo">
|
||||
<li><a href="http://jobs.rover.com/" style="background-image: url(https://fund-rest-framework.s3.amazonaws.com/rover_130x130.png)">Rover.com</a></li>
|
||||
<li><a href="https://getsentry.com/welcome/" style="background-image: url(https://fund-rest-framework.s3.amazonaws.com/sentry130.png)">Sentry</a></li>
|
||||
<li><a href="https://getstream.io/try-the-api/?utm_source=drf&utm_medium=banner&utm_campaign=drf" style="background-image: url(https://fund-rest-framework.s3.amazonaws.com/stream-130.png)">Stream</a></li>
|
||||
<li><a href="https://hello.machinalis.co.uk/" style="background-image: url(https://fund-rest-framework.s3.amazonaws.com/Machinalis130.png)">Machinalis</a></li>
|
||||
<li><a href="https://rollbar.com" style="background-image: url(https://fund-rest-framework.s3.amazonaws.com/rollbar.png)">Rollbar</a></li>
|
||||
</ul>
|
||||
<div style="clear: both; padding-bottom: 20px;"></div>
|
||||
|
||||
*As well as our release sponsor, we'd like to say thanks in particular our premium backers, [Rover](http://jobs.rover.com/), [Sentry](https://getsentry.com/welcome/), [Stream](https://getstream.io/?utm_source=drf&utm_medium=banner&utm_campaign=drf), [Machinalis](https://hello.machinalis.co.uk/), and [Rollbar](https://rollbar.com).*
|
||||
|
||||
---
|
||||
|
||||
## Customizing API docs & schema generation.
|
||||
|
||||
The schema generation introduced in 3.5 and the related API docs generation in 3.6 are both hugely powerful features, however they've been somewhat limited in cases where the view introspection isn't able to correctly identify the schema for a particular view.
|
||||
|
||||
In order to try to address this we're now adding the ability for per-view customization of the API schema. The interface that we're adding for this allows either basic manual overrides over which fields should be included on a view, or for more complex programmatic overriding of the schema generation. We believe this release comprehensively addresses some of the existing shortcomings of the schema features.
|
||||
|
||||
Let's take a quick look at using the new functionality...
|
||||
|
||||
The `APIView` class has a `schema` attribute, that is used to control how the Schema for that particular view is generated. The default behaviour is to use the `AutoSchema` class.
|
||||
|
||||
from rest_framework.views import APIView
|
||||
from rest_framework.schemas import AutoSchema
|
||||
|
||||
class CustomView(APIView):
|
||||
schema = AutoSchema() # Included for demonstration only. This is the default behavior.
|
||||
|
||||
We can remove a view from the API schema and docs, like so:
|
||||
|
||||
class CustomView(APIView):
|
||||
schema = None
|
||||
|
||||
If we want to mostly use the default behavior, but additionally include some additional fields on a particular view, we can now do so easily...
|
||||
|
||||
class CustomView(APIView):
|
||||
schema = AutoSchema(manual_fields=[
|
||||
coreapi.Field('search', location='query')
|
||||
])
|
||||
|
||||
To ignore the automatic generation for a particular view, and instead specify the schema explicitly, we use the `ManualSchema` class instead...
|
||||
|
||||
class CustomView(APIView):
|
||||
schema = ManualSchema(fields=[...])
|
||||
|
||||
For more advanced behaviors you can subclass `AutoSchema` to provide for customized schema generation, and apply that to particular views.
|
||||
|
||||
class CustomView(APIView):
|
||||
schema = CustomizedSchemaGeneration()
|
||||
|
||||
For full details on the new functionality, please see the [Schema Documentation][schema-docs].
|
||||
|
||||
---
|
||||
|
||||
## Django 2.0 support
|
||||
|
||||
REST framework 3.7 supports Django versions 1.10, 1.11, and 2.0 alpha.
|
||||
|
||||
---
|
||||
|
||||
## Minor fixes and improvements
|
||||
|
||||
There are a large number of minor fixes and improvements in this release. See the [release notes](release-notes.md) page for a complete listing.
|
||||
|
||||
The number of [open tickets against the project](https://github.com/encode/django-rest-framework/issues) currently at its lowest number in quite some time, and we're continuing to focus on reducing these to a manageable amount.
|
||||
|
||||
---
|
||||
|
||||
## Deprecations
|
||||
|
||||
### `exclude_from_schema`
|
||||
|
||||
Both `APIView.exclude_from_schema` and the `exclude_from_schema` argument to the
|
||||
`@api_view` decorator and now `PendingDeprecation`.
|
||||
Both `APIView.exclude_from_schema` and the `exclude_from_schema` argument to the `@api_view` decorator and now `PendingDeprecation`. They will be moved to deprecated in the 3.8 release, and removed entirely in 3.9.
|
||||
|
||||
For `APIView` set `schema = None`. For function based views use the `@schema`
|
||||
decorator passing `None`.
|
||||
For `APIView` you should instead set a `schema = None` attribute on the view class.
|
||||
|
||||
For function based views the `@schema` decorator can be used to exclude the view from the schema, by using `@schema(None)`.
|
||||
|
||||
### `DjangoFilterBackend`
|
||||
|
||||
The `DjangoFilterBackend` was moved to pending deprecation in 3.5, and deprecated in 3.6. It has now been removed from the core framework.
|
||||
|
||||
The functionality remains fully available, but is instead provided in the `django-filter` package.
|
||||
|
||||
---
|
||||
|
||||
## What's next
|
||||
|
||||
We're still planning to work on improving real-time support for REST framework by providing documentation on integrating with Django channels, as well adding support for more easily adding WebSocket support to existing HTTP endpoints.
|
||||
|
||||
This will likely be timed so that any REST framework development here ties in with similar work on [API Star][api-star].
|
||||
|
||||
[funding]: funding.md
|
||||
[schema-docs]: ../api-guide/schemas.md
|
||||
[api-star]: https://github.com/encode/apistar
|
|
@ -70,6 +70,7 @@ pages:
|
|||
- '3.4 Announcement': 'topics/3.4-announcement.md'
|
||||
- '3.5 Announcement': 'topics/3.5-announcement.md'
|
||||
- '3.6 Announcement': 'topics/3.6-announcement.md'
|
||||
- '3.7 Announcement': 'topics/3.7-announcement.md'
|
||||
- 'Kickstarter Announcement': 'topics/kickstarter-announcement.md'
|
||||
- 'Mozilla Grant': 'topics/mozilla-grant.md'
|
||||
- 'Funding': 'topics/funding.md'
|
||||
|
|
Loading…
Reference in New Issue
Block a user