djangorestframework-api-key


Namedjangorestframework-api-key JSON
Version 3.0.0 PyPI version JSON
download
home_page
SummaryAPI key permissions for the Django REST Framework
upload_time2023-10-19 04:17:12
maintainer
docs_urlNone
author
requires_python>=3.8
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Django REST Framework API Key

API key permissions for the [Django REST Framework](https://www.django-rest-framework.org).

<div>
  <a href="https://dev.azure.com/florimondmanca/public/_build/latest?definitionId=7&branchName=master">
      <img src="https://dev.azure.com/florimondmanca/public/_apis/build/status/florimondmanca.djangorestframework-api-key?branchName=master" alt="build status"/>
  </a>
  <a href="https://codecov.io/gh/florimondmanca/djangorestframework-api-key">
      <img src="https://codecov.io/gh/florimondmanca/djangorestframework-api-key/branch/master/graph/badge.svg" alt="coverage">
  </a>
  <a href="https://pypi.org/project/djangorestframework-api-key">
      <img src="https://badge.fury.io/py/djangorestframework-api-key.svg" alt="package version"/>
  </a>
</div>
<div>
  <img src="https://img.shields.io/pypi/pyversions/djangorestframework-api-key.svg" alt="python versions"/>
  <img src="https://img.shields.io/pypi/djversions/djangorestframework-api-key.svg?colorB=44b78b" alt="django versions"/>
  <img src="https://img.shields.io/badge/drf-3.8+-7f2d2d.svg" alt="drf versions"/>
</div>

## Introduction

**Django REST Framework API Key is a library for allowing server-side clients to safely use your API.** These clients are typically third-party backends and services (i.e. _machines_) which do not have a user account but still need to interact with your API in a secure way.

### Features

- ✌️ **Simple to use**: create, view and revoke API keys via the admin site, or use built-in helpers to create API keys programmatically.
- 🔒 **As secure as possible**: API keys are treated with the same level of care as user passwords. They are only visible at creation and hashed before storing in the database.
- 🎨 **Customizable**: satisfy specific business requirements by building your own customized API key models, permission classes and admin panels.

### Should I use API keys?

There are important security aspects you need to consider before switching to an API key access control scheme. We've listed some of these in [Security caveats](docs/security.md#caveats), including serving your API over HTTPS.

Besides, see [Why and when to use API keys](https://cloud.google.com/endpoints/docs/openapi/when-why-api-key#top_of_page) for hints on whether API keys can fit your use case.

API keys are ideal in the following situations:

- Blocking anonymous traffic.
- Implementing API key-based [throttling](https://www.django-rest-framework.org/api-guide/throttling/). (Note that Django REST Framework already has may built-in utilities for this use case.)
- Identifying usage patterns by logging request information along with the API key.

They can also present enough security for authorizing internal services, such as your API server and an internal frontend application.

> Please note that this package is NOT meant for authentication. You should NOT use this package to identify individual users, either directly or indirectly.
>
> If you need server-to-server authentication, you may want to consider OAuth instead. Libraries such as [django-oauth-toolkit](https://django-oauth-toolkit.readthedocs.io/en/latest/index.html) can help.

## Quickstart

Install with `pip`:

```bash
pip install "djangorestframework-api-key==3.*"
```

_**Note**: It is highly recommended to **pin your dependency** to the latest major version (as depicted above), as breaking changes may and will happen between major releases._

Add the app to your `INSTALLED_APPS`:

```python
# settings.py

INSTALLED_APPS = [
  # ...
  "rest_framework",
  "rest_framework_api_key",
]
```

Run the included migrations:

```bash
python manage.py migrate
```

To learn how to configure permissions and manage API keys, head to the [Documentation](https://florimondmanca.github.io/djangorestframework-api-key).

## Changelog

See [CHANGELOG.md](https://github.com/florimondmanca/djangorestframework-api-key/tree/master/CHANGELOG.md).

## Contributing

See [CONTRIBUTING.md](https://github.com/florimondmanca/djangorestframework-api-key/tree/master/CONTRIBUTING.md).

## License

MIT

# Changelog

All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## 3.0.0 - 2023-09-30

### Changed

- Use faster SHA512-based key hasher instead of password hashers. Reduces server load by making API key validation orders of magnitude faster (10x to 30x according to estimations, network latency aside). Hashed key will be transparently upgraded the first time `.is_valid()` is called. (Pull #244, Pull #251)

### Removed

- Dropped support for Python 3.7, which has reached EOL. (Pull #247)
- Drop redundant `.has_object_permission()` implementation on `BaseHasAPIKey` when using DRF 3.14.0 or above. (Pull #240)

### Added

- Add official support for Python 3.11. (Pull #247)

## 2.3.0 - 2023-01-19

### Removed

- Drop support for Python 3.6, which has reached EOL. (Pull #210)

### Fixed

- Fix migration 0004 when run against a non default database. (Pull #215)

## 2.2.0 - 2022-03-11

### Added

- Added support for Django config detection for different versions (PR #187)

### Changed

- Add official support for Django 3.2 and Python 3.9 and 3.10 (PR #189)
- Bumped `hashed_key` field's `max_length` from 100 to 150 to address length issue with `argon2-cffi` (PR #193)

## 2.1.0 - 2021-09-24

### Added

- Add support for custom API `keyword`. (Pull #175)

## 2.0.0 - 2020-04-07

**NOTE**: this release drops compatibility with certain Python and Django versions, but contains no other breaking changes. See [Upgrade to 2.0](https://florimondmanca.github.io/djangorestframework-api-key/upgrade/2.0/) for detailed migration steps.

### Removed

- Dropped support for Django 2.0 and Django 2.1. (Pull #126)
- Dropped support for Python 3.5. (Pull #84)

### Added

- Add support for Django 3.0. (Pull #82)
- Add support for Python 3.8. (Pull #81)
- Add `BaseAPIKeyManager.get_from_key()` to allow retrieving API keys from views. (Pull #93)
- Add type annotations, and partial support for `django-stubs` and `djangorestframework-stubs`. (Pull #88, Pull #122)

## 1.4.1 - 2019-08-24

### Added

- Now ships with type annotations ([PEP 561](https://www.python.org/dev/peps/pep-0561/)). (Pull #73)

## 1.4.0 - 2019-07-16

**NOTE**: this release contains migrations. See [Upgrade to v1.4](https://florimondmanca.github.io/djangorestframework-api-key/upgrade/1.4/) for detailed instructions.

### Added

- The `prefix` and `hashed_key` are now stored in dedicated fields on the `APIKey` model. (Pull #62)

## 1.3.0 - 2019-06-28

**NOTE**: this release contains migrations. In your Django project, run them using:

```python
python manage.py migrate rest_framework_api_key
```

### Added

- Add abstract API key model (`AbstractAPIKey`) and base manager (`BaseAPIKeyManager`). (Pull #36)
- Add base permissions (`BaseHasAPIKey`). (Pull #46)

### Changed

- The `id` field of `APIKey` is now non-`editable`.
- `APIKeyModelAdmin` does not define `fieldsets` anymore. This allows subclasses to benefit from Django's automatic fieldsets. (Pull #52)

### Fixed

- Explicitly use `utf-8` encoding in `setup.py`, which could previously lead to issues when installing on certain systems. (Pull #58)

## 1.2.1 - 2019-06-03

### Fixed

- Fixed a critical bug in `APIKeyModelAdmin` that prevented `rest_framework_api_key` from passing Django system checks. (Pull #39)

## 1.2.0 - 2019-05-29

**NOTE**: this release contains migrations. In your Django project, run them using:

```python
python manage.py migrate rest_framework_api_key
```

### Added

- API keys can now have an optional `expiry_date`. (Pull #33) `HasAPIKey` denies access if the API key has expired, i.e. if `expiry_date`, if set, is in the past.
- It is now possible to search by `prefix` in the API key admin panel.
- The `prefix` is now displayed in the edit view of the API key admin panel.

## 1.1.0 - 2019-05-14

### Added

- Improve documentation on which password hasher is used.
- Add tests against the Argon2, BcryptSHA256 and PBKDF2SHA1 hashers. (Pull #32)

### Fixed

- Fix support for password hashers that generate hashes that contain dots. (Pull #31)

## 1.0.0 - 2019-04-24

**This release is incompatible with 0.x**. See [Upgrade to 1.0](https://florimondmanca.github.io/djangorestframework-api-key/upgrade/1.4/) for migration steps.

### Removed

- Remove `HasAPIKeyOrIsAuthenticated` permission class. You should use bitwise composition now, e.g. `HasAPIKey | IsAuthenticated`.
- Drop the `DRF_API_KEY_*` settings. (Pull #19)

### Changed

- Switch to a new API key generation and validation scheme. Clients must now authorize using a single API key header (Pull #19). The header is `Authorization` by default. It can be customized using the `API_KEY_CUSTOM_HEADER` setting (Pull #26). Use the `name` field to identify clients.

### Added

- Add support for Django 2.2. (Pull #27)
- Add programmatic API key creation using `APIKey.objects.create_key()`. (Pull #19)

### Fixed

- Improved API key storage using Django's password hashing helpers. (Uses the default Django password hasher.) (Pull #19)

## 0.4.0 - 2019-04-21

### Removed

- Drop support for Python 3.4. Only 3.5, 3.6 and 3.7 are supported now.
- Drop support for Django < 2.0. Only 2.0 and 2.1 are supported now.

### Fixed

- `HasAPIKey` now implements `.has_object_permissions()`, which allows to compose it with other permission classes and perform object-level permission checks. (Pull #25)

## 0.3.1 - 2018-11-17

_Initial changelog entry._

### Added

- `APIKey` model.
- `HasAPIKey` and `HasAPIKeyOrIsAuthenticated` permission classes.
- Generate, view and revoke API keys from the Django admin.
- Authenticate requests using the `Api-Token` and `Api-Secret-Key` headers. Customizable via the `DRF_API_KEY_TOKEN_HEADER` and `DRF_API_KEY_SECRET_KEY_HEADER` settings.

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "djangorestframework-api-key",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "",
    "keywords": "",
    "author": "",
    "author_email": "Florimond Manca <florimond.manca@protonmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/78/4a/f30dc4121839323acfaee8d9938c0ff0630945f9d1765643adf420c1f042/djangorestframework-api-key-3.0.0.tar.gz",
    "platform": null,
    "description": "# Django REST Framework API Key\n\nAPI key permissions for the [Django REST Framework](https://www.django-rest-framework.org).\n\n<div>\n  <a href=\"https://dev.azure.com/florimondmanca/public/_build/latest?definitionId=7&branchName=master\">\n      <img src=\"https://dev.azure.com/florimondmanca/public/_apis/build/status/florimondmanca.djangorestframework-api-key?branchName=master\" alt=\"build status\"/>\n  </a>\n  <a href=\"https://codecov.io/gh/florimondmanca/djangorestframework-api-key\">\n      <img src=\"https://codecov.io/gh/florimondmanca/djangorestframework-api-key/branch/master/graph/badge.svg\" alt=\"coverage\">\n  </a>\n  <a href=\"https://pypi.org/project/djangorestframework-api-key\">\n      <img src=\"https://badge.fury.io/py/djangorestframework-api-key.svg\" alt=\"package version\"/>\n  </a>\n</div>\n<div>\n  <img src=\"https://img.shields.io/pypi/pyversions/djangorestframework-api-key.svg\" alt=\"python versions\"/>\n  <img src=\"https://img.shields.io/pypi/djversions/djangorestframework-api-key.svg?colorB=44b78b\" alt=\"django versions\"/>\n  <img src=\"https://img.shields.io/badge/drf-3.8+-7f2d2d.svg\" alt=\"drf versions\"/>\n</div>\n\n## Introduction\n\n**Django REST Framework API Key is a library for allowing server-side clients to safely use your API.** These clients are typically third-party backends and services (i.e. _machines_) which do not have a user account but still need to interact with your API in a secure way.\n\n### Features\n\n- \u270c\ufe0f **Simple to use**: create, view and revoke API keys via the admin site, or use built-in helpers to create API keys programmatically.\n- \ud83d\udd12 **As secure as possible**: API keys are treated with the same level of care as user passwords. They are only visible at creation and hashed before storing in the database.\n- \ud83c\udfa8 **Customizable**: satisfy specific business requirements by building your own customized API key models, permission classes and admin panels.\n\n### Should I use API keys?\n\nThere are important security aspects you need to consider before switching to an API key access control scheme. We've listed some of these in [Security caveats](docs/security.md#caveats), including serving your API over HTTPS.\n\nBesides, see [Why and when to use API keys](https://cloud.google.com/endpoints/docs/openapi/when-why-api-key#top_of_page) for hints on whether API keys can fit your use case.\n\nAPI keys are ideal in the following situations:\n\n- Blocking anonymous traffic.\n- Implementing API key-based [throttling](https://www.django-rest-framework.org/api-guide/throttling/). (Note that Django REST Framework already has may built-in utilities for this use case.)\n- Identifying usage patterns by logging request information along with the API key.\n\nThey can also present enough security for authorizing internal services, such as your API server and an internal frontend application.\n\n> Please note that this package is NOT meant for authentication. You should NOT use this package to identify individual users, either directly or indirectly.\n>\n> If you need server-to-server authentication, you may want to consider OAuth instead. Libraries such as [django-oauth-toolkit](https://django-oauth-toolkit.readthedocs.io/en/latest/index.html) can help.\n\n## Quickstart\n\nInstall with `pip`:\n\n```bash\npip install \"djangorestframework-api-key==3.*\"\n```\n\n_**Note**: It is highly recommended to **pin your dependency** to the latest major version (as depicted above), as breaking changes may and will happen between major releases._\n\nAdd the app to your `INSTALLED_APPS`:\n\n```python\n# settings.py\n\nINSTALLED_APPS = [\n  # ...\n  \"rest_framework\",\n  \"rest_framework_api_key\",\n]\n```\n\nRun the included migrations:\n\n```bash\npython manage.py migrate\n```\n\nTo learn how to configure permissions and manage API keys, head to the [Documentation](https://florimondmanca.github.io/djangorestframework-api-key).\n\n## Changelog\n\nSee [CHANGELOG.md](https://github.com/florimondmanca/djangorestframework-api-key/tree/master/CHANGELOG.md).\n\n## Contributing\n\nSee [CONTRIBUTING.md](https://github.com/florimondmanca/djangorestframework-api-key/tree/master/CONTRIBUTING.md).\n\n## License\n\nMIT\n\n# Changelog\n\nAll notable changes to this project will be documented in this file.\n\nThe format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).\n\n## 3.0.0 - 2023-09-30\n\n### Changed\n\n- Use faster SHA512-based key hasher instead of password hashers. Reduces server load by making API key validation orders of magnitude faster (10x to 30x according to estimations, network latency aside). Hashed key will be transparently upgraded the first time `.is_valid()` is called. (Pull #244, Pull #251)\n\n### Removed\n\n- Dropped support for Python 3.7, which has reached EOL. (Pull #247)\n- Drop redundant `.has_object_permission()` implementation on `BaseHasAPIKey` when using DRF 3.14.0 or above. (Pull #240)\n\n### Added\n\n- Add official support for Python 3.11. (Pull #247)\n\n## 2.3.0 - 2023-01-19\n\n### Removed\n\n- Drop support for Python 3.6, which has reached EOL. (Pull #210)\n\n### Fixed\n\n- Fix migration 0004 when run against a non default database. (Pull #215)\n\n## 2.2.0 - 2022-03-11\n\n### Added\n\n- Added support for Django config detection for different versions (PR #187)\n\n### Changed\n\n- Add official support for Django 3.2 and Python 3.9 and 3.10 (PR #189)\n- Bumped `hashed_key` field's `max_length` from 100 to 150 to address length issue with `argon2-cffi` (PR #193)\n\n## 2.1.0 - 2021-09-24\n\n### Added\n\n- Add support for custom API `keyword`. (Pull #175)\n\n## 2.0.0 - 2020-04-07\n\n**NOTE**: this release drops compatibility with certain Python and Django versions, but contains no other breaking changes. See [Upgrade to 2.0](https://florimondmanca.github.io/djangorestframework-api-key/upgrade/2.0/) for detailed migration steps.\n\n### Removed\n\n- Dropped support for Django 2.0 and Django 2.1. (Pull #126)\n- Dropped support for Python 3.5. (Pull #84)\n\n### Added\n\n- Add support for Django 3.0. (Pull #82)\n- Add support for Python 3.8. (Pull #81)\n- Add `BaseAPIKeyManager.get_from_key()` to allow retrieving API keys from views. (Pull #93)\n- Add type annotations, and partial support for `django-stubs` and `djangorestframework-stubs`. (Pull #88, Pull #122)\n\n## 1.4.1 - 2019-08-24\n\n### Added\n\n- Now ships with type annotations ([PEP 561](https://www.python.org/dev/peps/pep-0561/)). (Pull #73)\n\n## 1.4.0 - 2019-07-16\n\n**NOTE**: this release contains migrations. See [Upgrade to v1.4](https://florimondmanca.github.io/djangorestframework-api-key/upgrade/1.4/) for detailed instructions.\n\n### Added\n\n- The `prefix` and `hashed_key` are now stored in dedicated fields on the `APIKey` model. (Pull #62)\n\n## 1.3.0 - 2019-06-28\n\n**NOTE**: this release contains migrations. In your Django project, run them using:\n\n```python\npython manage.py migrate rest_framework_api_key\n```\n\n### Added\n\n- Add abstract API key model (`AbstractAPIKey`) and base manager (`BaseAPIKeyManager`). (Pull #36)\n- Add base permissions (`BaseHasAPIKey`). (Pull #46)\n\n### Changed\n\n- The `id` field of `APIKey` is now non-`editable`.\n- `APIKeyModelAdmin` does not define `fieldsets` anymore. This allows subclasses to benefit from Django's automatic fieldsets. (Pull #52)\n\n### Fixed\n\n- Explicitly use `utf-8` encoding in `setup.py`, which could previously lead to issues when installing on certain systems. (Pull #58)\n\n## 1.2.1 - 2019-06-03\n\n### Fixed\n\n- Fixed a critical bug in `APIKeyModelAdmin` that prevented `rest_framework_api_key` from passing Django system checks. (Pull #39)\n\n## 1.2.0 - 2019-05-29\n\n**NOTE**: this release contains migrations. In your Django project, run them using:\n\n```python\npython manage.py migrate rest_framework_api_key\n```\n\n### Added\n\n- API keys can now have an optional `expiry_date`. (Pull #33) `HasAPIKey` denies access if the API key has expired, i.e. if `expiry_date`, if set, is in the past.\n- It is now possible to search by `prefix` in the API key admin panel.\n- The `prefix` is now displayed in the edit view of the API key admin panel.\n\n## 1.1.0 - 2019-05-14\n\n### Added\n\n- Improve documentation on which password hasher is used.\n- Add tests against the Argon2, BcryptSHA256 and PBKDF2SHA1 hashers. (Pull #32)\n\n### Fixed\n\n- Fix support for password hashers that generate hashes that contain dots. (Pull #31)\n\n## 1.0.0 - 2019-04-24\n\n**This release is incompatible with 0.x**. See [Upgrade to 1.0](https://florimondmanca.github.io/djangorestframework-api-key/upgrade/1.4/) for migration steps.\n\n### Removed\n\n- Remove `HasAPIKeyOrIsAuthenticated` permission class. You should use bitwise composition now, e.g. `HasAPIKey | IsAuthenticated`.\n- Drop the `DRF_API_KEY_*` settings. (Pull #19)\n\n### Changed\n\n- Switch to a new API key generation and validation scheme. Clients must now authorize using a single API key header (Pull #19). The header is `Authorization` by default. It can be customized using the `API_KEY_CUSTOM_HEADER` setting (Pull #26). Use the `name` field to identify clients.\n\n### Added\n\n- Add support for Django 2.2. (Pull #27)\n- Add programmatic API key creation using `APIKey.objects.create_key()`. (Pull #19)\n\n### Fixed\n\n- Improved API key storage using Django's password hashing helpers. (Uses the default Django password hasher.) (Pull #19)\n\n## 0.4.0 - 2019-04-21\n\n### Removed\n\n- Drop support for Python 3.4. Only 3.5, 3.6 and 3.7 are supported now.\n- Drop support for Django < 2.0. Only 2.0 and 2.1 are supported now.\n\n### Fixed\n\n- `HasAPIKey` now implements `.has_object_permissions()`, which allows to compose it with other permission classes and perform object-level permission checks. (Pull #25)\n\n## 0.3.1 - 2018-11-17\n\n_Initial changelog entry._\n\n### Added\n\n- `APIKey` model.\n- `HasAPIKey` and `HasAPIKeyOrIsAuthenticated` permission classes.\n- Generate, view and revoke API keys from the Django admin.\n- Authenticate requests using the `Api-Token` and `Api-Secret-Key` headers. Customizable via the `DRF_API_KEY_TOKEN_HEADER` and `DRF_API_KEY_SECRET_KEY_HEADER` settings.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "API key permissions for the Django REST Framework",
    "version": "3.0.0",
    "project_urls": {
        "Documentation": "https://florimondmanca.github.io/djangorestframework-api-key/",
        "Homepage": "https://github.com/florimondmanca/djangorestframework-api-key"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "188b5b7cf37dfc3474f06eda417ea0dce4c970e3bde85f72e71d31225a46c7c4",
                "md5": "d574068d1bc5039fe97187f2e5c685bd",
                "sha256": "b9443cd864e43caebdd330224f9309957b38128267fbc9dc1ba2f3fa1c8414d0"
            },
            "downloads": -1,
            "filename": "djangorestframework_api_key-3.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "d574068d1bc5039fe97187f2e5c685bd",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 15564,
            "upload_time": "2023-10-19T04:17:11",
            "upload_time_iso_8601": "2023-10-19T04:17:11.044144Z",
            "url": "https://files.pythonhosted.org/packages/18/8b/5b7cf37dfc3474f06eda417ea0dce4c970e3bde85f72e71d31225a46c7c4/djangorestframework_api_key-3.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "784af30dc4121839323acfaee8d9938c0ff0630945f9d1765643adf420c1f042",
                "md5": "477ac4b9269190e3279c4a084518c65d",
                "sha256": "f18cdfa45aaea10fd4daaebffa60481ce4002c9b9ef6c551ef1fc21dadf28845"
            },
            "downloads": -1,
            "filename": "djangorestframework-api-key-3.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "477ac4b9269190e3279c4a084518c65d",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 36741,
            "upload_time": "2023-10-19T04:17:12",
            "upload_time_iso_8601": "2023-10-19T04:17:12.735202Z",
            "url": "https://files.pythonhosted.org/packages/78/4a/f30dc4121839323acfaee8d9938c0ff0630945f9d1765643adf420c1f042/djangorestframework-api-key-3.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-10-19 04:17:12",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "florimondmanca",
    "github_project": "djangorestframework-api-key",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "djangorestframework-api-key"
}
        
Elapsed time: 0.22977s