Some endpoints are secured. To use this endpoints a user must be authenticated. To authenticate, the application using the endpoints must be whitelisted in the settings (see CORS_ORIGIN_WHITELIST
and CSRF_TRUSTED_ORIGINS
) and with each request the credentials (sessionid
and csrftoken
) must be sent.
Returns all products ordered by product group name.
GET /products/products
Details
Parameter | Type | Description | Required |
---|
None
Authentication not required
[
{
"id": 3,
"name": "Lays - Paprika",
"price": 1.66,
"stock": 60,
"image_url": "",
"product_group": {
"id": 2,
"name": "Chips",
"created": "2023-05-19T10:51:59.472081Z",
"last_modified": "2023-05-19T10:51:59.472081Z"
}
},
{
"id": 4,
"name": "Lays - Naturel",
"price": 1.66,
"stock": 66,
"image_url": "",
"product_group": {
"id": 2,
"name": "Chips",
"created": "2023-05-19T10:51:59.472081Z",
"last_modified": "2023-05-19T10:51:59.472081Z"
}
},
{
"id": 1,
"name": "Fanta",
"price": 1.66,
"stock": 14,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
},
{
"id": 2,
"name": "Cola",
"price": 1.23,
"stock": 13,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
}
]
Returns the specific product that was requested.
GET /products/products/${id}
Details
Parameter | Type | Description | Required |
---|---|---|---|
id |
integer |
Id of product to fetch | Required |
Authentication not required
{
"id": 1,
"name": "Fanta",
"price": 1.66,
"stock": 14,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
}
Returns all product groups ordered by name including the products that belong to them.
GET /products/product_groups
Details
Parameter | Type | Description | Required |
---|
None
Authentication not required
[
{
"id": 1,
"name": "Frisdrank",
"products": [
{
"id": 1,
"name": "Fanta",
"price": 1.66,
"stock": 14,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
},
{
"id": 2,
"name": "Cola",
"price": 1.23,
"stock": 13,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
}
]
},
{
"id": 2,
"name": "Chips",
"products": [
{
"id": 3,
"name": "Lays - Paprika",
"price": 1.66,
"stock": 60,
"image_url": "",
"product_group": {
"id": 2,
"name": "Chips",
"created": "2023-05-19T10:51:59.472081Z",
"last_modified": "2023-05-19T10:51:59.472081Z"
}
},
{
"id": 4,
"name": "Lays - Naturel",
"price": 1.66,
"stock": 66,
"image_url": "",
"product_group": {
"id": 2,
"name": "Chips",
"created": "2023-05-19T10:51:59.472081Z",
"last_modified": "2023-05-19T10:51:59.472081Z"
}
}
]
}
]
Returns the specific product group that was requested.
GET /products/product_groups/${id}
Details
Parameter | Type | Description | Required |
---|---|---|---|
id |
string |
Id of product group to fetch | Required |
Authentication not required
{
"id": 1,
"name": "Frisdrank",
"products": [
{
"id": 1,
"name": "Fanta",
"price": 1.66,
"stock": 14,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
},
{
"id": 2,
"name": "Cola",
"price": 1.23,
"stock": 13,
"image_url": "",
"product_group": {
"id": 1,
"name": "Frisdrank",
"created": "2023-05-09T19:00:11.947134Z",
"last_modified": "2023-05-09T19:00:11.947134Z"
}
}
]
}
Use this endpoint to get an overview of all transactions of the customer that is logged in.
GET /transactions/transactions
Details
Parameter | Type | Description | Required |
---|---|---|---|
flat |
bool |
Lists all subtransactions in one list | Optional |
month |
int |
Filter transactions for this month (1=Jan) | Optional |
year |
int |
Filter transactions for this year | Optional |
Exampe:
GET /transactions/transactions/?flat=true&month=5&year=2023
Authentication is required. Only the transactions of the authenticated user are returned.
[
{
"transaction_id": "c3bb7b19-bcfb-413d-a88a-ee0d50aefdb7",
"customer": 3,
"date": "2023-04-21T09:33:57Z",
"subtransactions": [
{
"description": "Cosmo kosten (5km)",
"amount": "1.66"
}
],
"subpurchases": []
},
{
"transaction_id": "e7a5f3e5-3f1d-4a66-a50b-b1cb8e148897",
"customer": 3,
"date": "2023-05-13T17:51:58Z",
"subtransactions": [
{
"description": "AV eten 13/05",
"amount": "12.78"
}
],
"subpurchases": [
{
"product": 1,
"quantity": 2,
"price": "3.45",
"amount": 6.9
}
]
},
{
"transaction_id": "c90a24a4-4d00-4b29-aae6-454eb15469a8",
"customer": 3,
"date": "2023-05-20T11:00:29Z",
"subtransactions": [
{
"description": "AV eten 20/05",
"amount": "10.66"
}
],
"subpurchases": []
}
]
Example response for flat = True
[
{
"name": "Cosmo kosten (5km)",
"quantity": 1,
"amount": 1.66,
"date": "2023-04-21T09:33:57Z"
},
{
"name": "AV eten 13/05",
"quantity": 1,
"amount": 12.78,
"date": "2023-05-13T17:51:58Z"
},
{
"name": "Fanta",
"quantity": 2,
"amount": 6.9,
"date": "2023-05-13T17:51:58Z"
},
{
"name": "AV eten 20/05",
"quantity": 1,
"amount": 10.66,
"date": "2023-05-20T11:00:29Z"
}
]
Use this endpoint to create a transaction.
POST /transactions/transactions/
Details
Parameter | Type | Description | Required |
---|
One or more of the following is required: SubTransaction
or SubPurchase
. These can be provided in the post request as a list with the name subtransactions
and/or subpurchases
.
A SubTransaction
has the following form:
{
"description": "AV Eten",
"amount": 10.66
}
A SubPurchase
has the following form: (it uses the product id)
{
"product": 1,
"quantity": 8
}
An example request can look like this:
subpurchases
or subtransactions
can be left out of the request below.
{
"subpurchases": [
{
"product": 4,
"quantity": 2
},
{
"product": 1,
"quantity": 8
}
],
"subtransactions": [
{
"description": "test",
"amount": 78.21
}
]
}
Authentication is required. Only transactions for the authenticated user can be created.
{
"transaction_id": "054b83c2-8380-4c49-8ebb-b317b337c8a0",
"customer": 1,
"date": "2024-02-22T19:59:23.559999Z",
"subtransactions": [
{
"description": "Test",
"amount": "5.00"
}
],
"subpurchases": [
{
"product": 4,
"quantity": 2,
"price": "1.00",
"amount": 2.0
}
]
}
Use this endpoint to get information about the logged in customer.
GET /transactions/customer
Details
Parameter | Type | Description | Required |
---|
None
Authentication is required. Only information about the current user is returned.
{
"id": 4,
"netid": "dewijzeuil",
"sub": "WISVCH.660001",
"relation_code": 6601,
"user": {
"id": 5,
"username": "WISVCH.660001",
"last_login": "2024-02-22T19:19:00Z",
"first_name": "De",
"last_name": "Wijze Uil",
"email": "dewijzeuil@ch.tudelft.nl",
"is_staff": true,
"is_superuser": true,
"days_since_joined": 0
}
}