mirror of
https://github.com/inventree/InvenTree.git
synced 2025-06-20 13:56:30 +00:00
* Add builtin plugin for auto-issuing orders * Add plugin to auto-issue orders * Add placeholder documentation * Fix typo * Adds image macro - To replace img.html - includes checking if file exists * Fix tooltips * More docs * Adjust plugin settings filters * docs * More docs * More docs * Updates * Less restrictive URL checking * Refactor build order page * Fix typo * Allow 429 * Debug output * More debug * Construct assets dir * Cleanup * Update docs README * Refactoring more pages * Fix image link * Fix SSO settings * Add hook to check for missing settings - Ensure that all settings are documented! * Add missing user settings * Update docstring * Tweak SSO.md * Image updates * More updates * Tweaks * Exclude orders without a target_date * Fix for issuing build orders * Further refactoring * Fixes * Image refactoring * More refactoring * More refactoring * Refactor app images * Fix pathing issues * Suppress some openapidocs warnings in logs (much easier to debug docs build issues) * Fix image reference * Reduce error messages * Fix image links * Fix image links * Reduce docs log output * Ensure settings are loaded before displaying them * Fix for UI test * Fix unit test * Test tweaks
162 lines
6.0 KiB
Markdown
162 lines
6.0 KiB
Markdown
---
|
|
title: InvenTree API
|
|
---
|
|
|
|
## InvenTree API
|
|
|
|
InvenTree provides a powerful REST API for interacting with inventory data on the server. Low-level data access and manipulation is available, with integrated user authentication and data validation.
|
|
|
|
!!! info "Django REST Framework"
|
|
The InvenTree API is based on the powerful and flexible [Django REST Framework](https://www.django-rest-framework.org/).
|
|
|
|
## Documentation
|
|
|
|
The API is self-documenting, and the documentation is provided alongside any InvenTree installation instance. If (for example) you have an InvenTree instance running at `http://127.0.0.1:8000` then the API documentation is available at `http://127.0.0.1:8000/api-doc/`
|
|
|
|
{{ image("api/api_doc.png", "API documentation") }}
|
|
|
|
### Browseble API
|
|
|
|
If [debug mode](../start/index.md#debug-mode) is enabled, the API can be browsed directly from the web interface. This provides a simple way to explore the API and test out different endpoints. Simply navigate your web browser to any API endpoint, and the API will be displayed in a human-readable format.
|
|
|
|
### Schema Description
|
|
|
|
The API schema is also documented in the [API Schema](./schema.md) page.
|
|
|
|
### Generating Schema File
|
|
|
|
If you want to generate the API schema file yourself. For example, to use with an external client, use the `invoke dev.schema` command. Run with the `-help` command to see available options.
|
|
|
|
```
|
|
invoke dev.schema -help
|
|
```
|
|
|
|
|
|
## Authentication
|
|
|
|
Users must be authenticated to gain access to the InvenTree API. The API accepts either basic username:password authentication, or token authentication. Token authentication is recommended as it provides much faster API access.
|
|
|
|
!!! warning "Permissions"
|
|
API access is restricted based on the permissions assigned to the user or scope of the application.
|
|
|
|
### Basic Auth
|
|
|
|
Users can authenticate against the API using basic authentication - specifically a valid combination of `username` and `password` credentials.
|
|
|
|
### Tokens
|
|
|
|
Each user is assigned an authentication token which can be used to access the API. This token is persistent for that user (unless invalidated by an administrator) and can be used across multiple sessions.
|
|
|
|
!!! info "Token Administration"
|
|
User tokens can be created and/or invalidated via the user settings, [Admin Center](../settings/admin.md#admin-center) or admin interface.
|
|
|
|
#### Requesting a Token
|
|
|
|
If a user does not know their access token, it can be requested via the API interface itself, using a basic authentication request.
|
|
|
|
To obtain a valid token, perform a GET request to `/api/user/token/`. No data are required, but a valid username / password combination must be supplied in the authentication headers.
|
|
|
|
!!! info "Credentials"
|
|
Ensure that a valid username:password combination are supplied as basic authorization headers.
|
|
|
|
Once a valid token is received from the server, subsequent API requests should be performed using that token.
|
|
|
|
If the supplied user credentials are validated, the server will respond with:
|
|
|
|
```
|
|
HTTP_200_OK
|
|
{
|
|
token: "usertokendatastring",
|
|
}
|
|
```
|
|
|
|
#### Using a Token
|
|
|
|
After reception of a valid authentication token, it can be subsequently used to perform token-based authentication.
|
|
|
|
The token value sent to the server must be of the format `Token <TOKEN-VALUE>` (without the `<` and `>` characters).
|
|
|
|
**Example: Javascript**
|
|
```javascript
|
|
var token = "MY-TOKEN-VALUE-HERE";
|
|
|
|
$.ajax({
|
|
url: "http://localhost:8080/api/part/",
|
|
type: 'GET',
|
|
headers: {"Authorization": `Token ${token}`}
|
|
});
|
|
```
|
|
|
|
**Example: Python (Requests)**
|
|
```python
|
|
import requests
|
|
|
|
token = 'MY-TOKEN-VALUE-HERE'
|
|
data = { ... }
|
|
headers = {
|
|
'AUTHORIZATION': f'Token {token}'
|
|
}
|
|
response = request.get('http://localhost:8080/api/part/', data=data, headers=headers)
|
|
```
|
|
|
|
### oAuth2 / OIDC
|
|
|
|
!!! warning "Experimental"
|
|
This is an experimental feature that needs to be specifically enabled. See [Experimental features](../settings/experimental.md) for more information.
|
|
|
|
InvenTree has built-in support for using [oAuth2](https://oauth.net/2/) and OpenID Connect (OIDC) for authentication to the API. This enables using the instance as a very limited identity provider.
|
|
|
|
A default application using a public client with PKCE enabled ships with each instance. Intended to be used with the python api and configured with very wide scopes this can also be used for quick tests - the cliend_id is `zDFnsiRheJIOKNx6aCQ0quBxECg1QBHtVFDPloJ6`.
|
|
|
|
#### Managing applications
|
|
|
|
Superusers can register new applications and manage existing ones using a small application under the subpath `/o/applications/`.
|
|
It is recommended to:
|
|
- read the spec (RFC 6749 / 6750) and/or best practices (RFC 9700) before choosing client types
|
|
- chose scopes as narrow as possible
|
|
- configure redirection URIs as exact as possible
|
|
|
|
#### Scopes
|
|
|
|
InvenTree's oAuth scopes are strongly related to the [user roles](#user-roles).
|
|
Names consist of 1. type, 2. kind and 3. (opt) role, separated by colons.
|
|
|
|
|
|
There are 3 types:
|
|
|
|
- a: administrative scopes - used for administrating the server - these can be staff or superuser scopes
|
|
- g: general scopes - give wide access to the basic building blocks of InvenTree
|
|
- r: role scopes - map to specific actions (2) and roles (3)
|
|
|
|
Examples:
|
|
```bash
|
|
a:superuser
|
|
g:read
|
|
r:change:part
|
|
r:delete:stock
|
|
```
|
|
|
|
!!! info "Read the API docs"
|
|
The API [documentation](#documentation) and [schema](./schema.md) list the required scopes for every API endpoint / interaction in the security sections.
|
|
|
|
## Authorization
|
|
|
|
### User Roles
|
|
|
|
Users can only perform REST API actions which align with their assigned [role permissions](../settings/permissions.md#roles).
|
|
Once a user has *authenticated* via the API, a list of the available roles can be retrieved from:
|
|
|
|
`/api/user/roles/`
|
|
|
|
For example, when accessing the API from a *superuser* account:
|
|
|
|
{{ image("api/api_roles.png", "API superuser roles") }}
|
|
|
|
Or, when accessing the API from an account which has read-only permissions:
|
|
|
|
{{ image("api/api_roles_2.png", "API user roles") }}
|
|
|
|
### Permission Denied
|
|
|
|
If an API action outside of the user's role(s) is attempted, the server will respond with a 403 permission error message.
|