Required permission:
- ticket.agent (access to all ticket in allocated groups)
- ticket.customer (access to all ticket with customer_id ** current_user.id || organization_id ** current_user.organization_id)
Request:
GET /api/v1/tickets
Response:
Status: 200 Ok [ { "id": 123, "title": "Help me!", "group_id": 1, "state_id": 1, "priority_id": 2, "customer_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }, { "id": 124, "title": "Just want to ask for support", "state_id": 2, "priority_id": 2, "customer_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }, ]
Required permission:
- ticket.agent (access to all ticket in allocated groups)
- ticket.customer (access to all ticket with customer_id ** current_user.id || organization_id ** current_user.organization_id)
Request:
GET /api/v1/tickets/search?query=what&limit=10
Note: As of Zammad 2.6 parameters (sort_by=some_row and order_by=asc or desc) can also be used for sorting.
Response:
Status: 200 Ok [ { "id": 123, "title": "Help me!", "group_id": 1, "state_id": 1, "priority_id": 2, "customer_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }, { "id": 124, "title": "Just want to ask for support", "state_id": 2, "priority_id": 2, "customer_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }, ]
Required permission:
- ticket.agent (access to all ticket in allocated groups)
- ticket.customer (access to all ticket with customer_id ** current_user.id || organization_id ** current_user.organization_id)
Request:
GET /api/v1/tickets/{id}
Response:
Status: 200 Ok { "id": 123, "title": "Help me!", "group_id": 1, "state_id": 1, "priority_id": 2, "customer_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }
Required permission:
- ticket.agent (create in all allocated groups)
- ticket.customer
Request:
POST /api/v1/tickets { "title": "Help me!", "group": "Users", "customer": "email_of_existing_customer@example.com", "article": { "subject": "some subject", "body": "some message", "type": "note", "internal": false }, ... "note": "some note" }
Response:
Status: 201 Created { "id": 123, "title": "Help me!", "group_id": 1, "state_id": 1, "priority_id": 2, "customer_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }
For more article attributes have a look into "Ticket Article".
If you want to include attachments of the first article, the payload looks like:
Request:
POST /api/v1/tickets { "title": "Help me!", "group": "Users", "article": { "subject": "some subject", "body": "some message", "attachments": [ { "filename": "some_file1.txt", "data": "content in base64", "mime-type": "text/plain" }, { "filename": "some_file2.txt", "data": "content in base64", "mime-type": "text/plain" } ] }, ... "note": "some note" }
If you want to add inline images, just use data URIs in HTML markup:
Request:
POST /api/v1/tickets { "title": "Help me!", "group": "Users", "article": { "content_type": "text/html", "subject": "some subject", "body": "<b>some</b> message witn inline image <img src=\"\">" }, ... "note": "some note" }
If you want to use or create an customer by email address at ticket creation, you can do with "guess:customer@example.com" in the customer_id attribute:
Request:
POST /api/v1/tickets { "title": "Help me!", "group": "Users", "customer_id": "guess:customer@example.com", ... "note": "some note" }
Required permission:
- ticket.agent (access to all ticket in allocated groups)
- ticket.customer (access to all ticket with customer_id ** current_user.id || organization_id ** current_user.organization_id)
Request:
PUT /api/v1/tickets/{id} { "id": 123, "title": "Help me!", "group": "Users", "state": "open", "priority": "3 high", "article": { "subject": "some subject of update", "body": "some message of update" }, ... }
Response:
Status: 200 Ok { "id": 123, "title": "Help me!", "group_id": 1, "state_id": 1, "priority_id": 2, ... "note": "some note", "updated_at": "2016-08-16T07:55:42.119Z", "created_at": "2016-08-16T07:55:42.119Z" }
If you want to include attachments of the article, the payload looks like:
Request:
PUT /api/v1/tickets/{id} { "id": 123, "title": "Help me!", "group": "Users", "article": { "subject": "some subject", "body": "some message", "attachments": [ { "filename": "some_file1.txt", "data": "content in base64", "mime-type": "text/plain" }, { "filename": "some_file2.txt", "data": "content in base64", "mime-type": "text/plain" } ] }, ... "note": "some note" }
If you want to add inline images, just use data URIs in HTML markup:
Request:
PUT /api/v1/tickets/{id} { "id": 123, "title": "Help me!", "group": "Users", "article": { "content_type": "text/html", "subject": "some subject", "body": "<b>some</b> message witn inline image <img src=\"\">" }, ... "note": "some note" }
Required permission:
- admin
Request:
DELETE /api/v1/tickets/{id}
Response:
Status: 200 Ok {}