API: Queries
A query defines how work packages can be filtered and displayed. Clients can define a query once, store it, and use it later on to load the same set of filters and display options.
Actions
Link | Description | Condition |
---|---|---|
star | Elevates the query to the status of ‘starred’ | Permission: save queries for own queries, manage public queries for public queries; Only present if query is not yet starred |
unstar | Removes the ‘starred’ status | Permission: save queries for own queries, manage public queries for public queries; Only present if query is starred |
update | Use the Form based process to verify the query before persisting | Permission: view work packages |
updateImmediately | Persist the query without using a Form based process for guidance | Permission: save queries for own queries, manage public queries for public queries; |
Linked Properties
Property | Description | Type | Constraints | Supported operations |
---|---|---|---|---|
self | This query | Query | not null | READ |
user | The user that owns this query | User | not null | READ |
project | The project on which this query operates | Project | READ | |
columns | Ordered list of QueryColumns. The columns, when mapped to WorkPackage properties determine which WorkPackage properties to display | []QueryColumn | READ | |
highlightedAttributes | Only with valid Enterprise Token available: List of QueryColumns that should get highlighted when highlightingMode is set to inline . | []QueryColumn | READ | |
sortBy | Ordered list of QuerySortBys. Indicates the WorkPackage property the results will be ordered by as well as the direction | []QuerySortBy | READ | |
groupBy | The WorkPackage property results of this query are grouped by | String | READ | |
results | The list of work packages returned by applying the filters, sorting and grouping defined in the query | WorkPackageCollection | READ | |
schema | This query’s schema | Schema | READ |
Please note, that all the properties listed above will also be embedded when individual queries are returned but will not be embedded when a list of queries is returned. Whether the properties are embedded or not may be subject to change in the future.
The columns
and highlightedAttributes
properties will be moved into Views::WorkPackagesTable
so it is deprecated to have it listed within the Query directly.
Local Properties
Property | Description | Type | Constraints | Supported operations |
---|---|---|---|---|
id | Query id | Integer | x > 0 | READ |
name | Query name | String | READ/WRITE | |
filters | A set of QueryFilters which will be applied to the work packages to determine the resulting work packages | []QueryFilterInstance | READ/WRITE | |
sums | Should sums (of supported properties) be shown? | Boolean | READ/WRITE | |
timelineVisible | Should the timeline mode be shown? | Boolean | READ/WRITE | |
timelineLabels | Which labels are shown in the timeline, empty when default | QueryTimelineLabels | READ/WRITE | |
timelineZoomLevel | Which zoom level should the timeline be rendered in? | String | days, weeks, months, quarters, years | READ/WRITE |
timestamps | The timestamps to filter by when showing changed attributes on work packages. | []Timestamp | Values older than 1 day are accepted only with valid Enterprise Token available. | |
highlightingMode | Which highlighting mode should the table have? | String | none, inline, status, priority, type | READ/WRITE |
showHierarchies | Should the hierarchy mode be enabled? | Boolean | READ/WRITE | |
hidden | Should the query be hidden from the query list? | Boolean | READ/WRITE | |
public | Can users besides the owner see the query? | Boolean | READ/WRITE | |
starred | Should the query be highlighted to the user? | Boolean | READ | |
createdAt | Time of creation | DateTime | not null | READ |
updatedAt | Time of the most recent change to the query | DateTime | not null | READ |
A query that is not assigned to a project ("project": null
) is called a global query. Global queries filter work packages regardless of the project they are assigned to. As such, a different set of filters exists for those queries.
The hidden
property is deprecated as it is replaced by the Views
concept. A query that isn’t hidden will have a View
while a query that is hidden won’t.
The timelineVisible
, timelineLabels
, timelineZoomLevel
, highlightingMode
and showHierarchies
properties will be moved into the more appropriate Views (probably Views::WorkPackagesTable
) so it is deprecated to have them within the Query directly.
Query Filter Instance
A QueryFilterInstance defines a filtering applied to the list of work packages. As such it contains:
-
the filter type (
QueryFilter
) used -
the operator (
QueryOperator
) used -
the list of values
The list of values can either consist of a list of links or of a list of strings. If the values are primitive (e.g. Integer, Boolean, Date) they will be displayed as strings and the QueryFilterInstance will have a values
property.
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
}
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
If the values are nonprimitive (e.g. User, Project), they will be listed as objects and the QueryFilterInstance will have a values
link.
{
"_type": "AssigneeQueryFilter",
"name": "Assignee",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/assignee",
"title": "Assignee"
},
"operator": {
"href": "/api/v3/queries/operators/=",
"title": "is"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/assignee"
},
"values": [
{
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
}
]
}
}
Methods
View default query for project
Same as viewing an existing, persisted Query in its response, this resource returns an unpersisted query and by that allows to get the default query configuration. The client may also provide additional parameters which will modify the default query. The query will already be scoped for the project.
id
integer
required path
Id of the project the default query is requested for
Example:1
filters
string
optional query
JSON specifying filter conditions. The filters provided as parameters are not applied to the query but are instead used to override the query’s persisted filters. All filters also accepted by the work packages endpoint are accepted. If no filter is to be applied, the client should send an empty array ([]
).
Default:[{ "status_id": { "operator": "o", "values": null }}]
Example:[{ "assignee": { "operator": "=", "values": ["1", "5"] }" }]
offset
integer
optional query
Page number inside the queries’ result collection of work packages.
Default:1
Example:25
pageSize
integer
optional query
Number of elements to display per page for the queries’ result collection of work packages.
Example:25
sortBy
string
optional query
JSON specifying sort criteria. The sort criteria is applied to the query’s result collection of work packages overriding the query’s persisted sort criteria.
Default:[["id", "asc"]]
Example:[["status", "asc"]]
groupBy
string
optional query
The column to group by. The grouping criteria is applied to the to the query’s result collection of work packages overriding the query’s persisted group criteria.
Example:status
showSums
boolean
optional query
Indicates whether properties should be summed up if they support it. The showSums parameter is applied to the to the query’s result collection of work packages overriding the query’s persisted sums property.
Default:false
Example:true
timestamps
string
optional query
Indicates the timestamps to filter by when showing changed attributes on work packages. Values can be either ISO8601 dates, ISO8601 durations and the following relative date keywords: “oneDayAgo@HH:MM+HH:MM”, “lastWorkingDay@HH:MM+HH:MM”, “oneWeekAgo@HH:MM+HH:MM”, “oneMonthAgo@HH:MM+HH:MM”. The first “HH:MM” part represents the zero paded hours and minutes. The last “+HH:MM” part represents the timezone offset from UTC associated with the time. Values older than 1 day are accepted only with valid Enterprise Token available.
Default:PT0S
Example:2023-01-01,P-1Y,PT0S,lastWorkingDay@12:00
timelineVisible
boolean
optional query
Indicates whether the timeline should be shown.
Default:false
Example:true
showHierarchies
boolean
optional query
Indicates whether the hierarchy mode should be enabled.
Default:true
Example:true
200
OK
{
"_embedded": {
"results": {
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"changeSize": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
},
"jumpTo": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"self": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
}
},
"_type": "WorkPackageCollection",
"count": 30,
"offset": 1,
"pageSize": 2,
"total": 234
}
},
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"project": {
"href": "/api/v3/projects/42",
"title": "Lorem ipsum project"
},
"results": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"self": {
"href": "/api/v3/projects/42/queries/default",
"title": "Default"
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
}
},
"_type": "Query",
"filters": [
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
},
"_type": "StatusQueryFilter",
"name": "Status"
}
],
"name": "default",
"public": false,
"showHierarchies": true,
"starred": false,
"sums": false,
"timelineVisible": false,
"timelineZoomLevel": "days"
}
Default_Query_for_ProjectModel
{
"type": "object",
"example": {
"_type": "Query",
"name": "default",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
}
],
"public": false,
"sums": false,
"timelineVisible": false,
"timelineZoomLevel": "days",
"showHierarchies": true,
"starred": false,
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 2,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/projects/42/queries/default",
"title": "Default"
},
"results": {
"href": "/api/v3/projects/42/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/42",
"title": "Lorem ipsum project"
}
}
}
}
403
Returned if the client does not have sufficient permissions to see the default query.
Required permission: view work packages in the project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not authorized to access this resource."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
404
Returned if the client does not have sufficient permissions to see the project.
Required permission: any permission in the project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:NotFound",
"message": "The requested resource could not be found."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
View schema for project queries
Retrieve the schema for project queries.
id
integer
required path
Project id
Example:1
200
OK
{
"_dependencies": [],
"_embedded": {
"filtersSchemas": {
"_embedded": {
"elements": [
{
"_dependencies": [
{
"_type": "SchemaDependency",
"dependencies": {
"/api/v3/queries/operators/!": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
},
"/api/v3/queries/operators/!*": {},
"/api/v3/queries/operators/*": {},
"/api/v3/queries/operators/=": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
}
},
"on": "operator"
}
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/assignee",
"title": "Assignee"
},
"self": {
"href": "/api/v3/queries/filter_instance_schemas/assignee"
}
},
"_type": "QueryFilterInstanceSchema",
"filter": {
"_links": {},
"hasDefault": false,
"name": "Filter",
"required": true,
"type": "QueryFilter",
"writable": true
},
"name": {
"hasDefault": true,
"name": "Name",
"required": true,
"type": "String",
"writable": false
}
},
{
"_dependencies": [
{
"_type": "SchemaDependency",
"dependencies": {
"/api/v3/queries/operators/!": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
},
"/api/v3/queries/operators/=": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
}
},
"on": "operator"
}
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/author",
"title": "Author"
},
"self": {
"href": "/api/v3/queries/filter_instance_schemas/author"
}
},
"_type": "QueryFilterInstanceSchema",
"filter": {
"_links": {},
"hasDefault": false,
"name": "Filter",
"required": true,
"type": "QueryFilter",
"writable": true
},
"name": {
"hasDefault": true,
"name": "Name",
"required": true,
"type": "String",
"writable": false
}
}
]
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas"
}
},
"_type": "Collection",
"count": 20,
"total": 20
}
},
"_links": {
"self": {
"href": "/api/v3/queries/schema"
}
},
"_type": "Schema",
"columns": {
"_links": {},
"hasDefault": true,
"location": "_links",
"name": "Columns",
"required": false,
"type": "[]QueryColumn",
"writable": true
},
"createdAt": {
"hasDefault": false,
"name": "Created on",
"required": true,
"type": "DateTime",
"writable": false
},
"filters": {
"_links": {
"allowedValuesSchemas": {
"href": "/api/v3/queries/filter_instance_schemas"
}
},
"hasDefault": true,
"location": "_links",
"name": "Filters",
"required": false,
"type": "[]QueryFilterInstance",
"writable": true
},
"groupBy": {
"_links": {},
"hasDefault": false,
"name": "Group results by",
"required": false,
"type": "[]QueryGroupBy",
"writable": true
},
"highlightedAttributes": {
"hasDefault": true,
"location": "_links",
"name": "Highlighted attributes",
"required": false,
"type": "[]QueryColumn",
"writable": true,
"deprecated": true
},
"highlightingMode": {
"hasDefault": true,
"name": "Highlighting mode",
"required": false,
"type": "String",
"writable": true,
"deprecated": true
},
"id": {
"hasDefault": false,
"name": "ID",
"required": true,
"type": "Integer",
"writable": false
},
"name": {
"hasDefault": false,
"maxLength": 255,
"minLength": 1,
"name": "Name",
"required": true,
"type": "String",
"writable": true
},
"project": {
"_links": {},
"hasDefault": false,
"location": "_links",
"name": "Project",
"required": false,
"type": "Project",
"writable": true
},
"public": {
"hasDefault": true,
"name": "Public",
"required": false,
"type": "Boolean",
"writable": true
},
"results": {
"hasDefault": false,
"name": "Results",
"required": false,
"type": "WorkPackageCollection",
"writable": false
},
"showHierarchies": {
"hasDefault": true,
"name": "Show hierarchies",
"required": false,
"type": "Boolean",
"writable": true,
"deprecated": true
},
"sortBy": {
"_links": {},
"hasDefault": true,
"name": "Sort by",
"required": false,
"type": "[]QuerySortBy",
"writable": true
},
"starred": {
"hasDefault": true,
"name": "Starred",
"required": false,
"type": "Boolean",
"writable": true
},
"sums": {
"hasDefault": true,
"name": "Sums",
"required": false,
"type": "Boolean",
"writable": true
},
"timelineLabels": {
"hasDefault": true,
"name": "Timeline labels",
"required": false,
"type": "QueryTimelineLabels",
"writable": true,
"deprecated": true
},
"timelineVisible": {
"hasDefault": true,
"name": "Timeline visible",
"required": false,
"type": "Boolean",
"writable": true,
"deprecated": true
},
"timelineZoomLevel": {
"hasDefault": true,
"name": "Timeline zoom level",
"required": false,
"type": "String",
"writable": true,
"deprecated": true
},
"timestamps": {
"hasDefault": true,
"name": "Timestamps",
"required": false,
"type": "[]Timestamp",
"writable": true
},
"updatedAt": {
"hasDefault": false,
"name": "Updated on",
"required": true,
"type": "DateTime",
"writable": false
},
"user": {
"hasDefault": true,
"name": "User",
"required": true,
"type": "User",
"writable": false
}
}
Schema_For_Project_QueriesModel
{
"type": "object",
"example": {
"_type": "Schema",
"_dependencies": [],
"id": {
"type": "Integer",
"name": "ID",
"required": true,
"hasDefault": false,
"writable": false
},
"name": {
"type": "String",
"name": "Name",
"required": true,
"hasDefault": false,
"writable": true,
"minLength": 1,
"maxLength": 255
},
"createdAt": {
"type": "DateTime",
"name": "Created on",
"required": true,
"hasDefault": false,
"writable": false
},
"updatedAt": {
"type": "DateTime",
"name": "Updated on",
"required": true,
"hasDefault": false,
"writable": false
},
"user": {
"type": "User",
"name": "User",
"required": true,
"hasDefault": true,
"writable": false
},
"project": {
"type": "Project",
"name": "Project",
"required": false,
"hasDefault": false,
"writable": true,
"_links": {}
},
"public": {
"type": "Boolean",
"name": "Public",
"required": false,
"hasDefault": true,
"writable": true
},
"sums": {
"type": "Boolean",
"name": "Sums",
"required": false,
"hasDefault": true,
"writable": true
},
"timelineVisible": {
"type": "Boolean",
"name": "Timeline visible",
"required": false,
"hasDefault": true,
"writable": true
},
"timelineZoomLevel": {
"type": "String",
"name": "Timeline zoom level",
"required": false,
"hasDefault": true,
"writable": true
},
"showHierarchies": {
"type": "Boolean",
"name": "Show hierarchies",
"required": false,
"hasDefault": true,
"writable": true
},
"starred": {
"type": "Boolean",
"name": "Starred",
"required": false,
"hasDefault": true,
"writable": true
},
"columns": {
"type": "[]QueryColumn",
"name": "Columns",
"required": false,
"hasDefault": true,
"writable": true,
"_links": {}
},
"filters": {
"type": "[]QueryFilterInstance",
"name": "Filters",
"required": false,
"writable": true,
"hasDefault": true,
"_links": {
"allowedValuesSchemas": {
"href": "/api/v3/projects/42/queries/filter_instance_schemas"
}
}
},
"groupBy": {
"type": "[]QueryGroupBy",
"name": "Group results by",
"required": false,
"hasDefault": false,
"writable": true,
"_links": {}
},
"sortBy": {
"type": "[]QuerySortBy",
"name": "Sort by",
"required": false,
"hasDefault": true,
"writable": true,
"_links": {}
},
"results": {
"type": "WorkPackageCollection",
"name": "Results",
"required": false,
"hasDefault": false,
"writable": false
},
"_embedded": {
"filtersSchemas": {
"_type": "Collection",
"total": 20,
"count": 20,
"_embedded": {
"elements": [
{
"_type": "QueryFilterInstanceSchema",
"_dependencies": [
{
"_type": "SchemaDependency",
"on": "operator",
"dependencies": {
"/api/v3/queries/operators/=": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
},
"/api/v3/queries/operators/!": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
},
"/api/v3/queries/operators/!*": {},
"/api/v3/queries/operators/*": {}
}
}
],
"name": {
"type": "String",
"name": "Name",
"required": true,
"hasDefault": true,
"writable": false
},
"filter": {
"type": "QueryFilter",
"name": "Filter",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas/assignee"
},
"filter": {
"href": "/api/v3/queries/filters/assignee",
"title": "Assignee"
}
}
},
{
"_type": "QueryFilterInstanceSchema",
"_dependencies": [
{
"_type": "SchemaDependency",
"on": "operator",
"dependencies": {
"/api/v3/queries/operators/=": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
},
"/api/v3/queries/operators/!": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
}
}
}
],
"name": {
"type": "String",
"name": "Name",
"required": true,
"hasDefault": true,
"writable": false
},
"filter": {
"type": "QueryFilter",
"name": "Filter",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas/author"
},
"filter": {
"href": "/api/v3/queries/filters/author",
"title": "Author"
}
}
}
]
},
"_links": {
"self": {
"href": "/api/v3/projects/42/queries/filter_instance_schemas"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/projects/42/queries/schema"
}
}
}
}
403
Required permission: view work package in the project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not authorized to access this resource."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
List queries
Returns a collection of queries. The collection can be filtered via query parameters similar to how work packages are filtered. Please note however, that the filters are applied to the queries and not to the work packages the queries in turn might return.
filters
string
optional query
JSON specifying filter conditions. Currently supported filters are:
-
project: filters queries by the project they are assigned to. If the project filter is passed with the
!*
(not any) operator, global queries are returned. -
id: filters queries based on their id
-
updated_at: filters queries based on the last time they where updated
Example:[{ "project_id": { "operator": "!*", "values": null }" }]
200
OK
{
"_links": {
"self": {
"href": "/api/v3/queries"
}
},
"total": 1,
"count": 1,
"_type": "Collection",
"_embedded": {
"elements": [
{
"_type": "Query",
"id": 9,
"name": "fdsfdsfdsf",
"createdAt": "2015-03-20T12:56:56.413Z",
"updatedAt": "2015-05-20T18:16:53.392Z",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
},
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
],
"public": false,
"sums": false,
"starred": true,
"projections": [
{
"_type": "QueryProjection::Table"
},
{
"_type": "QueryProjection::TeamPlanner",
"_links": {
"rows": [
{
"href": "/api/v3/users/1",
"title": "Bob Bobbit"
}
]
}
},
{
"_type": "QueryProjection::Calendar"
}
],
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 30,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
}
}
}
]
}
}
QueriesModel
{
"type": "object",
"example": {
"_links": {
"self": {
"href": "/api/v3/queries"
}
},
"total": 1,
"count": 1,
"_type": "Collection",
"_embedded": {
"elements": [
{
"_type": "Query",
"id": 9,
"name": "fdsfdsfdsf",
"createdAt": "2015-03-20T12:56:56.858Z",
"updatedAt": "2015-05-20T18:16:53.887Z",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
},
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
],
"public": false,
"sums": false,
"starred": true,
"projections": [
{
"_type": "Query::TableProjection"
},
{
"_type": "Query::TeamPlannerProjection",
"_links": {
"rows": [
{
"href": "/api/v3/users/1",
"title": "Bob Bobbit"
}
]
}
},
{
"_type": "Query::CalendarProjection"
}
],
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 30,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
}
}
}
]
}
}
}
403
Returned if the client does not have sufficient permissions to see queries.
Required permission: view work packages or manage public queries in any project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not allowed to see the queries."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Create query
When calling this endpoint the client provides a single object, containing at least the properties and links that are required, in the body. The required fields of a Query can be found in its schema, which is embedded in the respective form. Note that it is only allowed to provide properties or links supporting the write operation.
201
Created
{
"_type": "Query",
"id": 9,
"name": "abcdefg",
"createdAt": "2015-03-20T12:56:56.235Z",
"updatedAt": "2015-05-20T18:16:53.976Z",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
},
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
],
"public": false,
"sums": false,
"starred": false,
"hidden": false,
"timestamps": [
"PT0S"
],
"projections": [
{
"_type": "QueryProjection::Table",
"showHierarchies": true,
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"highlightedAttributes": []
}
},
{
"_type": "QueryProjection::Gantt",
"labels": {},
"zoomLevel": "auto",
"_links": {
"highlightedAttributes": []
}
},
{
"_type": "QueryProjection::TeamPlanner",
"_links": {
"rows": [
{
"href": "/api/v3/users/1",
"title": "Alan Touring"
},
{
"href": "/api/v3/users/5",
"title": "John von Neumann"
}
]
}
},
{
"_type": "QueryProjection::Calendar"
}
],
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 30,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/9",
"title": "abcdefg"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
}
}
}
QueryModel
{
"type": "object",
"required": [
"createdAt",
"updatedAt"
],
"properties": {
"id": {
"type": "integer",
"description": "Query id",
"readOnly": true,
"exclusiveMinimum": 0
},
"name": {
"type": "string",
"description": "Query name",
"readOnly": true
},
"filters": {
"type": "array",
"description": "A set of QueryFilters which will be applied to the work packages to determine the resulting work packages",
"readOnly": false,
"items": {
"$ref": "#/components/schemas/Query_Filter_Instance_SchemaModel"
}
},
"sums": {
"type": "boolean",
"description": "Should sums (of supported properties) be shown?",
"readOnly": true
},
"timelineVisible": {
"type": "boolean",
"description": "Should the timeline mode be shown?",
"readOnly": true,
"deprecated": true
},
"timelineLabels": {
"type": "array",
"description": "Which labels are shown in the timeline, empty when default",
"readOnly": true,
"deprecated": true,
"items": {
"type": "string"
}
},
"timelineZoomLevel": {
"type": "string",
"description": "Which zoom level should the timeline be rendered in?",
"readOnly": true,
"deprecated": true
},
"timestamps": {
"type": "array",
"description": "Timestamps to filter by when showing changed attributes on work packages.",
"readOnly": false
},
"highlightingMode": {
"type": "string",
"description": "Which highlighting mode should the table have?",
"readOnly": true,
"deprecated": true
},
"showHierarchies": {
"type": "boolean",
"description": "Should the hierarchy mode be enabled?",
"readOnly": true,
"deprecated": true
},
"hidden": {
"type": "boolean",
"description": "Should the query be hidden from the query list?",
"readOnly": true,
"deprecated": true
},
"public": {
"type": "boolean",
"description": "Can users besides the owner see the query?",
"readOnly": true
},
"starred": {
"type": "boolean",
"description": "Should the query be highlighted to the user?",
"readOnly": true
},
"createdAt": {
"type": "string",
"format": "date-time",
"description": "Time of creation",
"readOnly": true
},
"updatedAt": {
"type": "string",
"format": "date-time",
"description": "Time of the most recent change to the query",
"readOnly": true
},
"_links": {
"type": "object",
"properties": {
"star": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Elevates the query to the status of 'starred'\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries; Only present if query is not yet starred",
"readOnly": true
}
]
},
"unstar": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Removes the 'starred' status\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries; Only present if query is starred",
"readOnly": true
}
]
},
"update": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Use the Form based process to verify the query before persisting\n\n# Conditions\n\n**Permission**: view work packages",
"readOnly": true
}
]
},
"updateImmediately": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Persist the query without using a Form based process for guidance\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries;",
"readOnly": true
}
]
}
}
}
}
}
400
Occurs when the client did not send a valid JSON object in the request body.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:InvalidRequestBody",
"message": "The request body was not a single JSON object."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
406
415
Occurs when the client sends an unsupported Content-Type header.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:TypeNotSupported",
"message": "Expected CONTENT-TYPE to be (expected value) but got (actual value)."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
422
Returned if:
-
the client tries to modify a read-only property (
PropertyIsReadOnly
) -
a constraint for a property was violated (
PropertyConstraintViolation
) -
the client provides a link to an invalid resource (
ResourceTypeMismatch
), e.g. a user, project or operator not found
{
"_embedded": {
"details": {
"attribute": "project"
}
},
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation",
"message": "Project not found"
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Available projects for query
Gets a list of projects that are available as projects a query can be assigned to.
200
OK
{
"_embedded": {
"elements": [
{
"_links": {
"categories": {
"href": "/api/v3/projects/6/categories"
},
"createWorkPackage": {
"href": "/api/v3/projects/6/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/projects/6/work_packages",
"method": "post"
},
"self": {
"href": "/api/v3/projects/6",
"title": "A project"
},
"versions": {
"href": "/api/v3/projects/6/versions"
}
},
"_type": "Project",
"createdAt": "2015-07-06T13:28:14+00:00",
"description": "Eveniet molestias omnis quis aut qui eum adipisci.",
"id": 6,
"identifier": "a_project",
"name": "A project",
"type": "Customer Project",
"updatedAt": "2015-10-01T09:55:02+00:00"
},
{
"_links": {
"categories": {
"href": "/api/v3/projects/14/categories"
},
"createWorkPackage": {
"href": "/api/v3/projects/14/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/projects/14/work_packages",
"method": "post"
},
"self": {
"href": "/api/v3/projects/14",
"title": "Another project"
},
"versions": {
"href": "/api/v3/projects/14/versions"
}
},
"_type": "Project",
"createdAt": "2016-02-29T12:50:20+00:00",
"description": "",
"id": 14,
"identifier": "another_project",
"name": "Another project",
"type": null,
"updatedAt": "2016-02-29T12:50:20+00:00"
}
]
},
"_links": {
"self": {
"href": "/api/v3/queries/available_projects"
}
},
"_type": "Collection",
"count": 2,
"total": 2
}
Available_projects_for_queryModel
{
"type": "object",
"example": {
"_links": {
"self": {
"href": "/api/v3/queries/available_projects"
}
},
"_type": "Collection",
"total": 2,
"count": 2,
"_embedded": {
"elements": [
{
"_type": "Project",
"_links": {
"self": {
"href": "/api/v3/projects/6",
"title": "A project"
},
"createWorkPackage": {
"href": "/api/v3/projects/6/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/projects/6/work_packages",
"method": "post"
},
"categories": {
"href": "/api/v3/projects/6/categories"
},
"versions": {
"href": "/api/v3/projects/6/versions"
}
},
"id": 6,
"identifier": "a_project",
"name": "A project",
"description": "Eveniet molestias omnis quis aut qui eum adipisci.",
"createdAt": "2015-07-06T13:28:14+00:00",
"updatedAt": "2015-10-01T09:55:02+00:00",
"type": "Customer Project"
},
{
"_type": "Project",
"_links": {
"self": {
"href": "/api/v3/projects/14",
"title": "Another project"
},
"createWorkPackage": {
"href": "/api/v3/projects/14/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/projects/14/work_packages",
"method": "post"
},
"categories": {
"href": "/api/v3/projects/14/categories"
},
"versions": {
"href": "/api/v3/projects/14/versions"
}
},
"id": 14,
"identifier": "another_project",
"name": "Another project",
"description": "",
"createdAt": "2016-02-29T12:50:20+00:00",
"updatedAt": "2016-02-29T12:50:20+00:00",
"type": null
}
]
}
}
}
403
Returned if the client does not have sufficient permissions.
Required permission: view work packages
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not authorized to access this resource."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
View default query
Same as viewing an existing, persisted Query in its response, this resource returns an unpersisted query and by that allows to get the default query configuration. The client may also provide additional parameters which will modify the default query.
filters
string
optional query
JSON specifying filter conditions. The filters provided as parameters are not applied to the query but are instead used to override the query’s persisted filters. All filters also accepted by the work packages endpoint are accepted. If no filter is to be applied, the client should send an empty array ([]
).
Default:[{ "status_id": { "operator": "o", "values": null }}]
Example:[{ "assignee": { "operator": "=", "values": ["1", "5"] }" }]
offset
integer
optional query
Page number inside the queries’ result collection of work packages.
Default:1
Example:25
pageSize
integer
optional query
Number of elements to display per page for the queries’ result collection of work packages.
Example:25
sortBy
string
optional query
JSON specifying sort criteria. The sort criteria is applied to the query’s result collection of work packages overriding the query’s persisted sort criteria.
Default:[["id", "asc"]]
Example:[["status", "asc"]]
groupBy
string
optional query
The column to group by. The grouping criteria is applied to the to the query’s result collection of work packages overriding the query’s persisted group criteria.
Example:status
showSums
boolean
optional query
Indicates whether properties should be summed up if they support it. The showSums parameter is applied to the to the query’s result collection of work packages overriding the query’s persisted sums property.
Default:false
Example:true
timestamps
string
optional query
Indicates the timestamps to filter by when showing changed attributes on work packages. Values can be either ISO8601 dates, ISO8601 durations and the following relative date keywords: “oneDayAgo@HH:MM+HH:MM”, “lastWorkingDay@HH:MM+HH:MM”, “oneWeekAgo@HH:MM+HH:MM”, “oneMonthAgo@HH:MM+HH:MM”. The first “HH:MM” part represents the zero paded hours and minutes. The last “+HH:MM” part represents the timezone offset from UTC associated with the time, the offset can be positive or negative e.g.“oneDayAgo@01:00+01:00”, “oneDayAgo@01:00-01:00”. Values older than 1 day are accepted only with valid Enterprise Token available.
Default:PT0S
Example:2023-01-01,P-1Y,PT0S,lastWorkingDay@12:00
timelineVisible
boolean
optional query
Indicates whether the timeline should be shown.
Default:false
Example:true
timelineZoomLevel
string
optional query
Indicates in what zoom level the timeline should be shown. Valid values are days
, weeks
, months
, quarters
, and years
.
Default:days
Example:days
showHierarchies
boolean
optional query
Indicates whether the hierarchy mode should be enabled.
Default:true
Example:true
200
OK
{
"_embedded": {
"results": {
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"changeSize": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
},
"jumpTo": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"self": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
}
},
"_type": "WorkPackageCollection",
"count": 30,
"offset": 1,
"pageSize": 2,
"total": 234
}
},
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"highlightedAttributes": [],
"project": {
"href": null
},
"results": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"self": {
"href": "/api/v3/queries/default",
"title": "Default"
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
}
},
"_type": "Query",
"filters": [
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
},
"_type": "StatusQueryFilter",
"name": "Status"
}
],
"highlightingMode": "inline",
"name": "default",
"public": false,
"showHierarchies": true,
"starred": false,
"sums": false,
"timelineLabels": {},
"timelineVisible": false,
"timelineZoomLevel": "days"
}
Default_QueryModel
{
"type": "object",
"example": {
"_type": "Query",
"name": "default",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
}
],
"public": false,
"sums": false,
"timelineVisible": false,
"timelineZoomLevel": "days",
"timelineLabels": {},
"highlightingMode": "inline",
"timestamps": [
"P0D"
],
"showHierarchies": true,
"starred": false,
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 2,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
},
"highlightedAttributes": []
}
},
"_links": {
"self": {
"href": "/api/v3/queries/default",
"title": "Default"
},
"results": {
"href": "/api/v3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"highlightedAttributes": [],
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": null
}
}
}
}
403
Returned if the client does not have sufficient permissions to see the default query.
Required permission: view work packages in any project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not authorized to access this resource."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Query create form
200
OK
View schema for global queries
Retrieve the schema for global queries, those, that are not assigned to a project.
200
OK
{
"_dependencies": [],
"_embedded": {
"filtersSchemas": {
"_embedded": {
"elements": [
{
"_dependencies": [
{
"_type": "SchemaDependency",
"dependencies": {
"/api/v3/queries/operators/!": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
},
"/api/v3/queries/operators/!*": {},
"/api/v3/queries/operators/*": {},
"/api/v3/queries/operators/=": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
}
},
"on": "operator"
}
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/assignee",
"title": "Assignee"
},
"self": {
"href": "/api/v3/queries/filter_instance_schemas/assignee"
}
},
"_type": "QueryFilterInstanceSchema",
"filter": {
"_links": {},
"hasDefault": false,
"name": "Filter",
"required": true,
"type": "QueryFilter",
"writable": true
},
"name": {
"hasDefault": true,
"name": "Name",
"required": true,
"type": "String",
"writable": false
}
},
{
"_dependencies": [
{
"_type": "SchemaDependency",
"dependencies": {
"/api/v3/queries/operators/!": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
},
"/api/v3/queries/operators/=": {
"values": {
"_links": {},
"hasDefault": false,
"name": "Values",
"required": true,
"type": "[]User",
"writable": true
}
}
},
"on": "operator"
}
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/author",
"title": "Author"
},
"self": {
"href": "/api/v3/queries/filter_instance_schemas/author"
}
},
"_type": "QueryFilterInstanceSchema",
"filter": {
"_links": {},
"hasDefault": false,
"name": "Filter",
"required": true,
"type": "QueryFilter",
"writable": true
},
"name": {
"hasDefault": true,
"name": "Name",
"required": true,
"type": "String",
"writable": false
}
}
]
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas"
}
},
"_type": "Collection",
"count": 20,
"total": 20
}
},
"_links": {
"self": {
"href": "/api/v3/queries/schema"
}
},
"_type": "Schema",
"columns": {
"_links": {},
"hasDefault": true,
"location": "_links",
"name": "Columns",
"required": false,
"type": "[]QueryColumn",
"writable": true
},
"createdAt": {
"hasDefault": false,
"name": "Created on",
"required": true,
"type": "DateTime",
"writable": false
},
"filters": {
"_links": {
"allowedValuesSchemas": {
"href": "/api/v3/queries/filter_instance_schemas"
}
},
"hasDefault": true,
"location": "_links",
"name": "Filters",
"required": false,
"type": "[]QueryFilterInstance",
"writable": true
},
"groupBy": {
"_links": {},
"hasDefault": false,
"name": "Group results by",
"required": false,
"type": "[]QueryGroupBy",
"writable": true
},
"highlightedAttributes": {
"hasDefault": true,
"location": "_links",
"name": "Highlighted attributes",
"required": false,
"type": "[]QueryColumn",
"writable": true,
"deprecated": true
},
"highlightingMode": {
"hasDefault": true,
"name": "Highlighting mode",
"required": false,
"type": "String",
"writable": true,
"deprecated": true
},
"id": {
"hasDefault": false,
"name": "ID",
"required": true,
"type": "Integer",
"writable": false
},
"name": {
"hasDefault": false,
"maxLength": 255,
"minLength": 1,
"name": "Name",
"required": true,
"type": "String",
"writable": true
},
"project": {
"_links": {},
"hasDefault": false,
"location": "_links",
"name": "Project",
"required": false,
"type": "Project",
"writable": true
},
"public": {
"hasDefault": true,
"name": "Public",
"required": false,
"type": "Boolean",
"writable": true
},
"results": {
"hasDefault": false,
"name": "Results",
"required": false,
"type": "WorkPackageCollection",
"writable": false
},
"showHierarchies": {
"hasDefault": true,
"name": "Show hierarchies",
"required": false,
"type": "Boolean",
"writable": true,
"deprecated": true
},
"sortBy": {
"_links": {},
"hasDefault": true,
"name": "Sort by",
"required": false,
"type": "[]QuerySortBy",
"writable": true
},
"starred": {
"hasDefault": true,
"name": "Starred",
"required": false,
"type": "Boolean",
"writable": true
},
"sums": {
"hasDefault": true,
"name": "Sums",
"required": false,
"type": "Boolean",
"writable": true
},
"timelineLabels": {
"hasDefault": true,
"name": "Timeline labels",
"required": false,
"type": "QueryTimelineLabels",
"writable": true,
"deprecated": true
},
"timelineVisible": {
"hasDefault": true,
"name": "Timeline visible",
"required": false,
"type": "Boolean",
"writable": true,
"deprecated": true
},
"timelineZoomLevel": {
"hasDefault": true,
"name": "Timeline zoom level",
"required": false,
"type": "String",
"writable": true,
"deprecated": true
},
"timestamps": {
"hasDefault": true,
"name": "Timestamps",
"required": false,
"type": "[]Timestamp",
"writable": true
},
"updatedAt": {
"hasDefault": false,
"name": "Updated on",
"required": true,
"type": "DateTime",
"writable": false
},
"user": {
"hasDefault": true,
"name": "User",
"required": true,
"type": "User",
"writable": false
}
}
Schema_For_Global_QueriesModel
{
"type": "object",
"example": {
"_type": "Schema",
"_dependencies": [],
"id": {
"type": "Integer",
"name": "ID",
"required": true,
"hasDefault": false,
"writable": false
},
"name": {
"type": "String",
"name": "Name",
"required": true,
"hasDefault": false,
"writable": true,
"minLength": 1,
"maxLength": 255
},
"createdAt": {
"type": "DateTime",
"name": "Created on",
"required": true,
"hasDefault": false,
"writable": false
},
"updatedAt": {
"type": "DateTime",
"name": "Updated on",
"required": true,
"hasDefault": false,
"writable": false
},
"user": {
"type": "User",
"name": "User",
"required": true,
"hasDefault": true,
"writable": false
},
"project": {
"type": "Project",
"name": "Project",
"required": false,
"hasDefault": false,
"writable": true,
"location": "_links",
"_links": {}
},
"public": {
"type": "Boolean",
"name": "Public",
"required": false,
"hasDefault": true,
"writable": true
},
"sums": {
"type": "Boolean",
"name": "Sums",
"required": false,
"hasDefault": true,
"writable": true
},
"timelineVisible": {
"type": "Boolean",
"name": "Timeline visible",
"required": false,
"hasDefault": true,
"writable": true,
"deprecated": true
},
"timelineZoomLevel": {
"type": "String",
"name": "Timeline zoom level",
"required": false,
"hasDefault": true,
"writable": true,
"deprecated": true
},
"timelineLabels": {
"type": "QueryTimelineLabels",
"name": "Timeline labels",
"required": false,
"hasDefault": true,
"writable": true,
"deprecated": true
},
"timestamps": {
"type": "[]Timestamp",
"name": "Timestamps",
"required": false,
"hasDefault": true,
"writable": true
},
"highlightingMode": {
"type": "String",
"name": "Highlighting mode",
"required": false,
"hasDefault": true,
"writable": true,
"deprecated": true
},
"highlightedAttributes": {
"type": "[]QueryColumn",
"name": "Highlighted attributes",
"required": false,
"hasDefault": true,
"writable": true,
"location": "_links",
"deprecated": true
},
"showHierarchies": {
"type": "Boolean",
"name": "Show hierarchies",
"required": false,
"hasDefault": true,
"writable": true,
"deprecated": true
},
"starred": {
"type": "Boolean",
"name": "Starred",
"required": false,
"hasDefault": true,
"writable": true
},
"columns": {
"type": "[]QueryColumn",
"name": "Columns",
"required": false,
"hasDefault": true,
"writable": true,
"location": "_links",
"_links": {}
},
"filters": {
"type": "[]QueryFilterInstance",
"name": "Filters",
"required": false,
"writable": true,
"hasDefault": true,
"location": "_links",
"_links": {
"allowedValuesSchemas": {
"href": "/api/v3/queries/filter_instance_schemas"
}
}
},
"groupBy": {
"type": "[]QueryGroupBy",
"name": "Group results by",
"required": false,
"hasDefault": false,
"writable": true,
"_links": {}
},
"sortBy": {
"type": "[]QuerySortBy",
"name": "Sort by",
"required": false,
"hasDefault": true,
"writable": true,
"_links": {}
},
"results": {
"type": "WorkPackageCollection",
"name": "Results",
"required": false,
"hasDefault": false,
"writable": false
},
"_embedded": {
"filtersSchemas": {
"_type": "Collection",
"total": 20,
"count": 20,
"_embedded": {
"elements": [
{
"_type": "QueryFilterInstanceSchema",
"_dependencies": [
{
"_type": "SchemaDependency",
"on": "operator",
"dependencies": {
"/api/v3/queries/operators/=": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
},
"/api/v3/queries/operators/!": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
},
"/api/v3/queries/operators/!*": {},
"/api/v3/queries/operators/*": {}
}
}
],
"name": {
"type": "String",
"name": "Name",
"required": true,
"hasDefault": true,
"writable": false
},
"filter": {
"type": "QueryFilter",
"name": "Filter",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas/assignee"
},
"filter": {
"href": "/api/v3/queries/filters/assignee",
"title": "Assignee"
}
}
},
{
"_type": "QueryFilterInstanceSchema",
"_dependencies": [
{
"_type": "SchemaDependency",
"on": "operator",
"dependencies": {
"/api/v3/queries/operators/=": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
},
"/api/v3/queries/operators/!": {
"values": {
"type": "[]User",
"name": "Values",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
}
}
}
}
],
"name": {
"type": "String",
"name": "Name",
"required": true,
"hasDefault": true,
"writable": false
},
"filter": {
"type": "QueryFilter",
"name": "Filter",
"required": true,
"hasDefault": false,
"writable": true,
"_links": {}
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas/author"
},
"filter": {
"href": "/api/v3/queries/filters/author",
"title": "Author"
}
}
}
]
},
"_links": {
"self": {
"href": "/api/v3/queries/filter_instance_schemas"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/schema"
}
}
}
}
403
Required permission: view work package in any project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not authorized to access this resource."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
View query
Retrieve an individual query as identified by the id parameter. Then end point accepts a number of parameters that can be used to override the resources’ persisted parameters.
id
integer
required path
Query id
Example:1
filters
string
optional query
JSON specifying filter conditions. The filters provided as parameters are not applied to the query but are instead used to override the query’s persisted filters. All filters also accepted by the work packages endpoint are accepted. If no filter is to be applied, the client should send an empty array ([]
).
Default:[{ "status_id": { "operator": "o", "values": null }}]
Example:[{ "assignee": { "operator": "=", "values": ["1", "5"] }" }]
offset
integer
optional query
Page number inside the queries’ result collection of work packages.
Default:1
Example:25
pageSize
integer
optional query
Number of elements to display per page for the queries’ result collection of work packages.
Example:25
columns
string
optional query
Selected columns for the table view.
Default:['type', 'priority']
Example:[]
sortBy
string
optional query
JSON specifying sort criteria. The sort criteria is applied to the query’s result collection of work packages overriding the query’s persisted sort criteria.
Default:[["id", "asc"]]
Example:[["status", "asc"]]
groupBy
string
optional query
The column to group by. The grouping criteria is applied to the to the query’s result collection of work packages overriding the query’s persisted group criteria.
Example:status
showSums
boolean
optional query
Indicates whether properties should be summed up if they support it. The showSums parameter is applied to the to the query’s result collection of work packages overriding the query’s persisted sums property.
Default:false
Example:true
timestamps
string
optional query
Indicates the timestamps to filter by when showing changed attributes on work packages. Values can be either ISO8601 dates, ISO8601 durations and the following relative date keywords: “oneDayAgo@HH:MM+HH:MM”, “lastWorkingDay@HH:MM+HH:MM”, “oneWeekAgo@HH:MM+HH:MM”, “oneMonthAgo@HH:MM+HH:MM”. The first “HH:MM” part represents the zero paded hours and minutes. The last “+HH:MM” part represents the timezone offset from UTC associated with the time, the offset can be positive or negative e.g.“oneDayAgo@01:00+01:00”, “oneDayAgo@01:00-01:00”. Values older than 1 day are accepted only with valid Enterprise Token available.
Default:PT0S
Example:2023-01-01,P-1Y,PT0S,lastWorkingDay@12:00
timelineVisible
boolean
optional query
Indicates whether the timeline should be shown.
Default:false
Example:true
timelineLabels
string
optional query
Overridden labels in the timeline view
Default:{}
Example:{}
highlightingMode
string
optional query
Highlighting mode for the table view.
Default:inline
Example:inline
highlightedAttributes
string
optional query
Highlighted attributes mode for the table view when highlightingMode
is inline
. When set to []
all highlightable attributes will be returned as highlightedAttributes
.
Default:['type', 'priority']
Example:[]
showHierarchies
boolean
optional query
Indicates whether the hierarchy mode should be enabled.
Default:true
Example:true
200
OK
{
"_type": "Query",
"id": 9,
"name": "abcdefg",
"createdAt": "2015-03-20T12:56:56.235Z",
"updatedAt": "2015-05-20T18:16:53.976Z",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
},
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
],
"public": false,
"sums": false,
"starred": false,
"hidden": false,
"timestamps": [
"PT0S"
],
"projections": [
{
"_type": "QueryProjection::Table",
"showHierarchies": true,
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"highlightedAttributes": []
}
},
{
"_type": "QueryProjection::Gantt",
"labels": {},
"zoomLevel": "auto",
"_links": {
"highlightedAttributes": []
}
},
{
"_type": "QueryProjection::TeamPlanner",
"_links": {
"rows": [
{
"href": "/api/v3/users/1",
"title": "Alan Touring"
},
{
"href": "/api/v3/users/5",
"title": "John von Neumann"
}
]
}
},
{
"_type": "QueryProjection::Calendar"
}
],
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 30,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/9",
"title": "abcdefg"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
}
}
}
QueryModel
{
"type": "object",
"required": [
"createdAt",
"updatedAt"
],
"properties": {
"id": {
"type": "integer",
"description": "Query id",
"readOnly": true,
"exclusiveMinimum": 0
},
"name": {
"type": "string",
"description": "Query name",
"readOnly": true
},
"filters": {
"type": "array",
"description": "A set of QueryFilters which will be applied to the work packages to determine the resulting work packages",
"readOnly": false,
"items": {
"$ref": "#/components/schemas/Query_Filter_Instance_SchemaModel"
}
},
"sums": {
"type": "boolean",
"description": "Should sums (of supported properties) be shown?",
"readOnly": true
},
"timelineVisible": {
"type": "boolean",
"description": "Should the timeline mode be shown?",
"readOnly": true,
"deprecated": true
},
"timelineLabels": {
"type": "array",
"description": "Which labels are shown in the timeline, empty when default",
"readOnly": true,
"deprecated": true,
"items": {
"type": "string"
}
},
"timelineZoomLevel": {
"type": "string",
"description": "Which zoom level should the timeline be rendered in?",
"readOnly": true,
"deprecated": true
},
"timestamps": {
"type": "array",
"description": "Timestamps to filter by when showing changed attributes on work packages.",
"readOnly": false
},
"highlightingMode": {
"type": "string",
"description": "Which highlighting mode should the table have?",
"readOnly": true,
"deprecated": true
},
"showHierarchies": {
"type": "boolean",
"description": "Should the hierarchy mode be enabled?",
"readOnly": true,
"deprecated": true
},
"hidden": {
"type": "boolean",
"description": "Should the query be hidden from the query list?",
"readOnly": true,
"deprecated": true
},
"public": {
"type": "boolean",
"description": "Can users besides the owner see the query?",
"readOnly": true
},
"starred": {
"type": "boolean",
"description": "Should the query be highlighted to the user?",
"readOnly": true
},
"createdAt": {
"type": "string",
"format": "date-time",
"description": "Time of creation",
"readOnly": true
},
"updatedAt": {
"type": "string",
"format": "date-time",
"description": "Time of the most recent change to the query",
"readOnly": true
},
"_links": {
"type": "object",
"properties": {
"star": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Elevates the query to the status of 'starred'\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries; Only present if query is not yet starred",
"readOnly": true
}
]
},
"unstar": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Removes the 'starred' status\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries; Only present if query is starred",
"readOnly": true
}
]
},
"update": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Use the Form based process to verify the query before persisting\n\n# Conditions\n\n**Permission**: view work packages",
"readOnly": true
}
]
},
"updateImmediately": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Persist the query without using a Form based process for guidance\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries;",
"readOnly": true
}
]
}
}
}
}
}
404
Returned if the query does not exist or the client does not have sufficient permissions to see it.
Required condition: query belongs to user or query is public
Required permission: view work package in queries project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:NotFound",
"message": "The specified query does not exist."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Edit query
When calling this endpoint the client provides a single object, containing the properties and links that it wants to change, in the body. Note that it is only allowed to provide properties or links supporting the write operation.
id
integer
required path
Query id
Example:1
200
OK
{
"_embedded": {
"highlightedAttributes": [],
"results": {
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
}
},
"_type": "WorkPackageCollection",
"count": 30,
"offset": 1,
"pageSize": 2,
"total": 234
}
},
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"highlightedAttributes": [],
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
}
},
"_type": "Query",
"createdAt": "2015-03-20T12:56:56.343Z",
"filters": [
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
},
"_type": "StatusQueryFilter",
"name": "Status"
},
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
},
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
]
}
],
"id": 9,
"name": "fdsfdsfdsf",
"public": false,
"starred": false,
"sums": false,
"updatedAt": "2015-05-20T18:16:53.884Z"
}
QueryModel
{
"type": "object",
"required": [
"createdAt",
"updatedAt"
],
"properties": {
"id": {
"type": "integer",
"description": "Query id",
"readOnly": true,
"exclusiveMinimum": 0
},
"name": {
"type": "string",
"description": "Query name",
"readOnly": true
},
"filters": {
"type": "array",
"description": "A set of QueryFilters which will be applied to the work packages to determine the resulting work packages",
"readOnly": false,
"items": {
"$ref": "#/components/schemas/Query_Filter_Instance_SchemaModel"
}
},
"sums": {
"type": "boolean",
"description": "Should sums (of supported properties) be shown?",
"readOnly": true
},
"timelineVisible": {
"type": "boolean",
"description": "Should the timeline mode be shown?",
"readOnly": true,
"deprecated": true
},
"timelineLabels": {
"type": "array",
"description": "Which labels are shown in the timeline, empty when default",
"readOnly": true,
"deprecated": true,
"items": {
"type": "string"
}
},
"timelineZoomLevel": {
"type": "string",
"description": "Which zoom level should the timeline be rendered in?",
"readOnly": true,
"deprecated": true
},
"timestamps": {
"type": "array",
"description": "Timestamps to filter by when showing changed attributes on work packages.",
"readOnly": false
},
"highlightingMode": {
"type": "string",
"description": "Which highlighting mode should the table have?",
"readOnly": true,
"deprecated": true
},
"showHierarchies": {
"type": "boolean",
"description": "Should the hierarchy mode be enabled?",
"readOnly": true,
"deprecated": true
},
"hidden": {
"type": "boolean",
"description": "Should the query be hidden from the query list?",
"readOnly": true,
"deprecated": true
},
"public": {
"type": "boolean",
"description": "Can users besides the owner see the query?",
"readOnly": true
},
"starred": {
"type": "boolean",
"description": "Should the query be highlighted to the user?",
"readOnly": true
},
"createdAt": {
"type": "string",
"format": "date-time",
"description": "Time of creation",
"readOnly": true
},
"updatedAt": {
"type": "string",
"format": "date-time",
"description": "Time of the most recent change to the query",
"readOnly": true
},
"_links": {
"type": "object",
"properties": {
"star": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Elevates the query to the status of 'starred'\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries; Only present if query is not yet starred",
"readOnly": true
}
]
},
"unstar": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Removes the 'starred' status\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries; Only present if query is starred",
"readOnly": true
}
]
},
"update": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Use the Form based process to verify the query before persisting\n\n# Conditions\n\n**Permission**: view work packages",
"readOnly": true
}
]
},
"updateImmediately": {
"allOf": [
{
"$ref": "#/components/schemas/Link"
},
{
"description": "Persist the query without using a Form based process for guidance\n\n# Conditions\n\n**Permission**: save queries for own queries, manage public queries for public queries;",
"readOnly": true
}
]
}
}
}
}
}
400
Occurs when the client did not send a valid JSON object in the request body.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:InvalidRequestBody",
"message": "The request body was not a single JSON object."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
403
Returned if the client does not have sufficient permissions.
Required permission: edit work package
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not allowed to edit the content of the work package."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
404
Returned if the query does not exist or the client does not have sufficient permissions to see it.
Required permission: view work packages in the query’s project (unless global)
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:NotFound",
"message": "The specified query does not exist."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
406
415
Occurs when the client sends an unsupported Content-Type header.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:TypeNotSupported",
"message": "Expected CONTENT-TYPE to be (expected value) but got (actual value)."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
422
Returned if:
-
the client tries to modify a read-only property (
PropertyIsReadOnly
) -
a constraint for a property was violated (
PropertyConstraintViolation
) -
the client provides a link to an invalid resource (
ResourceTypeMismatch
)
{
"_embedded": {
"details": {
"attribute": "name"
}
},
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation",
"message": "The name might not be blank."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Delete query
Delete the query identified by the id parameter
id
integer
required path
Query id
Example:1
204
No Content
403
Returned if the client does not have sufficient permissions.
Required permission: for own queries none; for public queries: manage public queries
Note that you will only receive this error, if you are at least allowed to see the corresponding query.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not authorized to access this resource."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
404
Returned if the query does not exist or the client does not have sufficient permissions to see it.
Required condition: query belongs to user or query is public
Required permission: view work package in queries project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:NotFound",
"message": "The requested resource could not be found."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Query update form
id
integer
required path
Query id
Example:1
200
OK
Star query
id
integer
required path
Query id
Example:1
200
OK
{
"_embedded": {
"results": {
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
}
},
"_type": "WorkPackageCollection",
"count": 30,
"offset": 1,
"pageSize": 2,
"total": 234
}
},
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
}
},
"_type": "Query",
"createdAt": "2015-03-20T12:56:56.856Z",
"filters": [
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
},
"_type": "StatusQueryFilter",
"name": "Status"
},
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
},
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
]
}
],
"id": 9,
"name": "fdsfdsfdsf",
"public": false,
"starred": true,
"sums": false,
"updatedAt": "2015-05-20T18:16:53.089Z"
}
Star_QueryModel
{
"type": "object",
"example": {
"_type": "Query",
"id": 9,
"name": "fdsfdsfdsf",
"createdAt": "2015-03-20T12:56:56.085Z",
"updatedAt": "2015-05-20T18:16:53.619Z",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
},
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
],
"public": false,
"sums": false,
"starred": true,
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 2,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
}
}
}
}
400
Occurs when the client did not send a valid JSON object in the request body.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:InvalidRequestBody",
"message": "The request body was not a single JSON object."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
403
Returned if the client does not have sufficient permissions.
Required permission: for own queries none; for public queries: manage public queries
Note that you will only receive this error, if you are at least allowed to see the corresponding query.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not allowed to star this query."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
404
Returned if the query does not exist or the client does not have sufficient permissions to see it.
Required condition: query belongs to user or query is public
Required permission: view work package in queries project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:NotFound",
"message": "The specified query does not exist."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
Unstar query
id
integer
required path
Query id
Example:1
200
OK
{
"_embedded": {
"results": {
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
}
},
"_type": "WorkPackageCollection",
"count": 30,
"offset": 1,
"pageSize": 2,
"total": 234
}
},
"_links": {
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
}
},
"_type": "Query",
"createdAt": "2015-03-20T12:56:56.468Z",
"filters": [
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
},
"_type": "StatusQueryFilter",
"name": "Status"
},
{
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
},
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
]
}
],
"id": 9,
"name": "fdsfdsfdsf",
"public": false,
"starred": false,
"sums": false,
"updatedAt": "2015-05-20T18:16:53.386Z"
}
Unstar_QueryModel
{
"type": "object",
"example": {
"_type": "Query",
"id": 9,
"name": "fdsfdsfdsf",
"createdAt": "2015-03-20T12:56:56.257Z",
"updatedAt": "2015-05-20T18:16:53.953Z",
"filters": [
{
"_type": "StatusQueryFilter",
"name": "Status",
"_links": {
"filter": {
"href": "/api/v3/queries/filters/status",
"title": "Status"
},
"operator": {
"href": "/api/v3/queries/operators/o",
"title": "open"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/status"
},
"values": []
}
},
{
"_type": "DueDateQueryFilter",
"name": "Finish date",
"values": [
"1"
],
"_links": {
"filter": {
"href": "/api/v3/queries/filters/dueDate",
"title": "Finish date"
},
"operator": {
"href": "/api/v3/queries/operators/<t+",
"title": "in less than"
},
"schema": {
"href": "/api/v3/queries/filter_instance_schemas/dueDate"
}
}
}
],
"public": false,
"sums": false,
"starred": false,
"_embedded": {
"results": {
"_type": "WorkPackageCollection",
"total": 234,
"count": 30,
"pageSize": 2,
"offset": 1,
"_embedded": {
"elements": [
"<--- shortened for brevity --->"
]
},
"_links": {
"self": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"jumpTo": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=%7Boffset%7D&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"changeSize": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=%7Bsize%7D&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D",
"templated": true
},
"createWorkPackage": {
"href": "/api/v3/work_packages/form",
"method": "post"
},
"createWorkPackageImmediate": {
"href": "/api/v3/work_packages",
"method": "post"
}
}
}
},
"_links": {
"self": {
"href": "/api/v3/queries/9",
"title": "fdsfdsfdsf"
},
"results": {
"href": "/api/v3/projects/3/work_packages?filters=%5B%7B%22status%22%3A%7B%22operator%22%3A%22o%22%2C%22values%22%3A%5B%5D%7D%7D%2C%7B%22dueDate%22%3A%7B%22operator%22%3A%22%3Ct%2B%22%2C%22values%22%3A%5B%221%22%5D%7D%7D%5D&offset=1&pageSize=2&sortBy=%5B%5B%22parent%22%2C%22desc%22%5D%5D"
},
"columns": [
{
"href": "/api/v3/queries/columns/id",
"title": "ID"
},
{
"href": "/api/v3/queries/columns/subject",
"title": "Subject"
},
{
"href": "/api/v3/queries/columns/type",
"title": "Type"
},
{
"href": "/api/v3/queries/columns/status",
"title": "Status"
},
{
"href": "/api/v3/queries/columns/priority",
"title": "Priority"
},
{
"href": "/api/v3/queries/columns/assignee",
"title": "Assignee"
},
{
"href": "/api/v3/queries/columns/updated_at",
"title": "Updated on"
}
],
"groupBy": {
"href": null,
"title": null
},
"sortBy": [
{
"href": "/api/v3/queries/sort_bys/parent-desc",
"title": "Parent (Descending)"
}
],
"user": {
"href": "/api/v3/users/1",
"title": "OpenProject Admin"
},
"project": {
"href": "/api/v3/projects/3",
"title": "copy"
}
}
}
}
400
Occurs when the client did not send a valid JSON object in the request body.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:InvalidRequestBody",
"message": "The request body was not a single JSON object."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
403
Returned if the client does not have sufficient permissions.
Required permission: for own queries none; for public queries: manage public queries
Note that you will only receive this error, if you are at least allowed to see the corresponding query.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:MissingPermission",
"message": "You are not allowed to unstar this query."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
404
Returned if the query does not exist or the client does not have sufficient permissions to see it.
Required condition: query belongs to user or query is public
Required permission: view work package in queries project
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:NotFound",
"message": "The specified query does not exist."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}
406
415
Occurs when the client sends an unsupported Content-Type header.
{
"_type": "Error",
"errorIdentifier": "urn:openproject-org:api:v3:errors:TypeNotSupported",
"message": "Expected CONTENT-TYPE to be (expected value) but got (actual value)."
}
ErrorResponse
{
"type": "object",
"required": [
"_type",
"errorIdentifier",
"message"
],
"properties": {
"_embedded": {
"type": "object",
"properties": {
"details": {
"type": "object",
"properties": {
"attribute": {
"type": "string",
"example": "project"
}
}
}
}
},
"_type": {
"type": "string",
"enum": [
"Error"
]
},
"errorIdentifier": {
"type": "string",
"example": "urn:openproject-org:api:v3:errors:PropertyConstraintViolation"
},
"message": {
"type": "string",
"example": "Project can't be blank."
}
}
}