Vouchers¶
Resource description¶
The voucher resource contains the following public fields:
Field |
Type |
Description |
---|---|---|
id |
integer |
Internal ID of the voucher |
code |
string |
The voucher code that is required to redeem the voucher |
max_usages |
integer |
The maximum number of times this voucher can be redeemed (default: 1). |
redeemed |
integer |
The number of times this voucher already has been redeemed. |
min_usages |
integer |
The minimum number of times this voucher must be redeemed on first usage (default: 1). |
valid_until |
datetime |
The voucher expiration date (or |
block_quota |
boolean |
If |
allow_ignore_quota |
boolean |
If |
price_mode |
string |
Determines how this voucher affects product prices. Possible values:
|
value |
decimal (string) |
The value (see |
item |
integer |
An ID of an item this voucher is restricted to (or |
variation |
integer |
An ID of a variation this voucher is restricted to (or |
quota |
integer |
An ID of a quota this voucher is restricted to (or
|
seat |
string |
|
tag |
string |
A string that is used for grouping vouchers |
comment |
string |
An internal comment on the voucher |
subevent |
integer |
ID of the date inside an event series this voucher belongs to (or |
show_hidden_items |
boolean |
Only if set to |
Endpoints¶
- GET /api/v1/organizers/(organizer)/events/(event)/vouchers/¶
Returns a list of all vouchers within a given event.
Example request:
GET /api/v1/organizers/bigevents/events/sampleconf/vouchers/ HTTP/1.1 Host: pretix.eu Accept: application/json, text/javascript
Example response:
HTTP/1.1 200 OK Vary: Accept Content-Type: application/json { "count": 1, "next": null, "previous": null, "results": [ { "id": 1, "code": "43K6LKM37FBVR2YG", "max_usages": 1, "redeemed": 0, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "12.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "seat": null, "subevent": null, } ] }
- Query Parameters:
page (integer) – The page number in case of a multi-page result set, default is 1
code (string) – Only show the voucher with the given voucher code.
max_usages (integer) – Only show vouchers with the given maximal number of usages.
redeemed (integer) – Only show vouchers with the given number of redemptions. Note that this doesn’t tell you if the voucher can still be redeemed, as this also depends on
max_usages
. See theactive
query parameter as well.block_quota (boolean) – If set to
true
orfalse
, only vouchers with this value in the fieldblock_quota
will be shown.allow_ignore_quota (boolean) – If set to
true
orfalse
, only vouchers with this value in the fieldallow_ignore_quota
will be shown.price_mode (string) – If set, only vouchers with this value in the field
price_mode
will be shown (see above).value (string) – If set, only vouchers with this value in the field
value
will be shown.item (integer) – If set, only vouchers attached to the item with the given ID will be shown.
variation (integer) – If set, only vouchers attached to the variation with the given ID will be shown.
quota (integer) – If set, only vouchers attached to the quota with the given ID will be shown.
tag (string) – If set, only vouchers with the given tag will be shown.
subevent (integer) – Only return vouchers of the sub-event with the given ID
ordering (string) – Manually set the ordering of results. Valid fields to be used are
id
,code
,max_usages
,valid_until
, andvalue
. Default:id
- Parameters:
organizer – The
slug
field of the organizer to fetchevent – The
slug
field of the event to fetch
- Status Codes:
200 OK – no error
401 Unauthorized – Authentication failure
403 Forbidden – The requested organizer/event does not exist or you have no permission to view this resource.
- GET /api/v1/organizers/(organizer)/events/(event)/vouchers/(id)/¶
Returns information on one voucher, identified by its internal ID.
Example request:
GET /api/v1/organizers/bigevents/events/sampleconf/vouchers/1/ HTTP/1.1 Host: pretix.eu Accept: application/json, text/javascript
Example response:
HTTP/1.1 200 OK Vary: Accept Content-Type: application/json { "id": 1, "code": "43K6LKM37FBVR2YG", "max_usages": 1, "redeemed": 0, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "12.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "seat": null, "subevent": null }
- Parameters:
organizer – The
slug
field of the organizer to fetchevent – The
slug
field of the event to fetchid – The
id
field of the voucher to fetch
- Status Codes:
200 OK – no error
401 Unauthorized – Authentication failure
403 Forbidden – The requested organizer/event does not exist or you have no permission to view this resource.
- POST /api/v1/organizers/(organizer)/events/(event)/vouchers/¶
Create a new voucher.
Example request:
POST /api/v1/organizers/bigevents/events/sampleconf/vouchers/ HTTP/1.1 Host: pretix.eu Accept: application/json, text/javascript Content-Type: application/json Content-Length: 408 { "code": "43K6LKM37FBVR2YG", "max_usages": 1, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "12.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "subevent": null }
Example response:
HTTP/1.1 201 Created Vary: Accept Content-Type: application/json { "id": 1, "code": "43K6LKM37FBVR2YG", "max_usages": 1, "redeemed": 0, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "12.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "seat": null, "subevent": null }
- Parameters:
organizer – The
slug
field of the organizer to create a voucher forevent – The
slug
field of the event to create a voucher for
- Status Codes:
201 Created – no error
400 Bad Request – The voucher could not be created due to invalid submitted data.
401 Unauthorized – Authentication failure
403 Forbidden – The requested organizer/event does not exist or you have no permission to create this resource.
409 Conflict – The server was unable to acquire a lock and could not process your request. You can try again after a short waiting period.
- POST /api/v1/organizers/(organizer)/events/(event)/vouchers/batch_create/¶
Creates multiple new vouchers atomically.
Example request:
POST /api/v1/organizers/bigevents/events/sampleconf/vouchers/batch_create/ HTTP/1.1 Host: pretix.eu Accept: application/json, text/javascript Content-Type: application/json Content-Length: 408 [ { "code": "43K6LKM37FBVR2YG", "max_usages": 1, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "12.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "subevent": null }, { "code": "ASDKLJCYXCASDASD", "max_usages": 1, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "12.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "subevent": null },
Example response:
HTTP/1.1 201 Created Vary: Accept Content-Type: application/json [ { "id": 1, "code": "43K6LKM37FBVR2YG", … }, … }
- Parameters:
organizer – The
slug
field of the organizer to create a vouchers forevent – The
slug
field of the event to create a vouchers for
- Status Codes:
201 Created – no error
400 Bad Request – The vouchers could not be created due to invalid submitted data.
401 Unauthorized – Authentication failure
403 Forbidden – The requested organizer/event does not exist or you have no permission to create this resource.
409 Conflict – The server was unable to acquire a lock and could not process your request. You can try again after a short waiting period.
- PATCH /api/v1/organizers/(organizer)/events/(event)/vouchers/(id)/¶
Update a voucher. You can also use
PUT
instead ofPATCH
. WithPUT
, you have to provide all fields of the resource, other fields will be reset to default. WithPATCH
, you only need to provide the fields that you want to change.You can change all fields of the resource except the
id
andredeemed
fields.Example request:
PATCH /api/v1/organizers/bigevents/events/sampleconf/vouchers/1/ HTTP/1.1 Host: pretix.eu Accept: application/json, text/javascript Content-Type: application/json Content-Length: 408 { "price_mode": "set", "value": "24.00" }
Example response:
HTTP/1.1 200 OK Vary: Accept Content-Type: application/json { "id": 1, "code": "43K6LKM37FBVR2YG", "max_usages": 1, "redeemed": 0, "valid_until": null, "block_quota": false, "allow_ignore_quota": false, "price_mode": "set", "value": "24.00", "item": 1, "variation": null, "quota": null, "tag": "testvoucher", "comment": "", "seat": null, "subevent": null }
- Parameters:
organizer – The
slug
field of the organizer to modifyevent – The
slug
field of the event to modifyid – The
id
field of the voucher to modify
- Status Codes:
200 OK – no error
400 Bad Request – The voucher could not be modified due to invalid submitted data
401 Unauthorized – Authentication failure
403 Forbidden – The requested organizer/event does not exist or you have no permission to change this resource.
409 Conflict – The server was unable to acquire a lock and could not process your request. You can try again after a short waiting period.
- DELETE /api/v1/organizers/(organizer)/events/(event)/vouchers/(id)/¶
Delete a voucher. Note that you cannot delete a voucher if it already has been redeemed.
Example request:
DELETE /api/v1/organizers/bigevents/events/sampleconf/vouchers/1/ HTTP/1.1 Host: pretix.eu Accept: application/json, text/javascript
Example response:
HTTP/1.1 204 No Content Vary: Accept
- Parameters:
organizer – The
slug
field of the organizer to modifyevent – The
slug
field of the event to modifyid – The
id
field of the voucher to delete
- Status Codes:
204 No Content – no error
401 Unauthorized – Authentication failure
403 Forbidden – The requested organizer/event does not exist or you have no permission to delete this resource.