Skip to content

Search and filter

To retrieve items from a resource, you need a GET request with the URL from the resource definition:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/admin/default/jsonadm/product'
var params = {};

var result = $.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // from OPTIONS response
    data: {}
});

result.done( function( result ) {
    console.log( result.data );
});

Response structure#

All GET requests will return a JSON object with the structure defined by jsonapi.org:

{
    "meta": {
         "total": 100
    },
    "links": {
        "first": "https://localhost:8000/admin/default/jsonadm/product?page[offset]=0",
        "prev": "https://localhost:8000/admin/default/jsonadm/product?page[offset]=0",
        "next": "https://localhost:8000/admin/default/jsonadm/product?page[offset]=25",
        "last": "https://localhost:8000/admin/default/jsonadm/product?page[offset]=75",
        "self": "https://localhost:8000/admin/default/jsonadm/product?page[offset]=0",
    },
    "data": [{
        "type": "product",
        "id": "1",
        "attributes": {
             "product.id": "1",
             "product.editor": "admin"
        },
        "links": {
            "self": "http://localhost:8000/admin/default/jsonadm/product/1"
        },
        "relationships": {
            "product/property": [{
                "data": {
                    "id": "12",
                    "type": "product/property"
                }
            }],
            "text": [{
                "data": {
                    "id": "9",
                    "type": "text",
                    "attributes": {
                        "product.lists.id": "5",
                        "product.lists.refid": "9",
                    },
                    "links": {
                        "self": "http://localhost:8000/admin/default/jsonadm/product/lists/5"
                    }
                }
            }]
        }
    }],
    "included": [{
        "id": "12",
        "type": "product/property",
        "attributes": {
            "product.property.id": "12",
            "product.property.type": "erp-id",
            "product.property.value": "1234-ABCD-5678",
        },
        "links": {
            "self": "http://localhost:8000/admin/default/jsonadm/product/property/12"
        }
    }, {
        "type": "text",
        "id": "9",
        "attributes": {
           "text.id": "9",
            "text.content": "My product name"
        },
        "links": {
            "self": "http://localhost:8000/admin/default/jsonadm/text/9"
        }
    }]
}

The "meta" section will always contain a "total" property on success. It's value is the number of items found in total for the current search filter.

In the "links" section, all necessary links for navigating through the result set are listed including the link for the current request.

"data" contains the items and each item always includes the ID and the resource type. In the attributes section, you will find the same data as returned by the toArray() method for every item. An URL referencing the unique resource is included in "links". If related items are included, they will be referenced by their ID and type in the "relationships" section. For items that are associated via lists, they will also contain an "attributes" section with the data for the list table.

In the "included" section all related items are listed if you told the server to hand them over in the same request as well. It's structure is the same as for the "data" section. For more information, please have a look into the related resources section.

By default, the first 25 items available will be returned if no further GET parameters are sent along with the request. There are three parameters to modify that behavior:

  • filter
    Conditions to retrieve specific items
  • sort
    Defines the order of the items in the result set
  • page
    Contains "start" and "limit" for getting slices of the result set

Conditions for filtering#

Filtering the result set by custom conditions is crucial for getting the items you want. The JSON API standard defines a parameter named "filter" that can contain arbitrary conditions. In the Aimeos API, you can use conditions for comparing values and combining them. To get the first 25 products items which are enabled use:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/admin/default/jsonadm/product?filter[%3E][product.status]=0'
var params = {
    filter: {'>': {'product.status': 0}}
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

There are several operators available:

=~ (%3D%7E)
Strings that starts with the given value
~= (%7E%3D)
Strings that contains the given value
> (%3E)
Greater than for date, date/time, integer and float values
>= (%3E%3D)
Greater than and equal for date, date/time, integer and float values
< (%3C)
Smaller than for date, date/time, integer and float values
<= (%3C%3D)
Smaller than and equal for date, date/time, integer and float values
== (%3D%3D)
Equal for boolean, date, date/time, integer, float and string values
!= (%21%3D)
Not equal for boolean, date, date/time, integer, float and string values

Warning

Don't forget to nest the parameters if a prefix is sent in the meta data!

To combine several conditions into one request, you can combine two or more "compare" expressions by using a "combine" expression:

# filter[&&][][>][product.type]=select
# &filter[&&][][=~][product.label]=demo
curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?filter[%26%26][][%3E][product.type]=select&filter[%26%26][][%3D%7E][product.label]=demo'
var params = {
    filter: {'&&': [
        {'>': {'product.status': 0}},
        {'=~': {'product.label': 'demo'}}
    ]}
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

That would search for all product items which are enabled AND whose labels starts with "demo". The available "combine" expressions are:

&& (%26%26)
Combines expressions using an AND operator
|| (%7C%7C)
Combines expressions using an OR operator
! (%21)
Negates an expression

The negation is a special case because it only accepts one "compare" condition while the others require more than one condition. Nevertheless, the value of the negation operator must be an array like for the other "combine" operators:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?filter[%21][][%3D%7E][product.label]=demo'
var params = {
    filter: {'!': [
        {'=~': {'product.label': 'demo'}}
    ]}
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

You can also create more complicated statements by nesting them like:

var params = {
    filter: {'&&': [
        {'>': {'product.status': 0}},
        {'!': [
            {'=~': {'product.label': 'demo'}}
        ]},
        {'||': [
            {'==': {'product.datestart': null}},
            {'>': {'product.datestart': '2000-01-01 00:00:00'}}
        }
    ]}
};

It combines the three expression by using the AND operator. In the second expression we tell the server that we want to get all items that doesn't start with "demo". The third expression is in this case an OR expression that specifies that "product.datestart" can be either be a null value or the start date must be after the beginning of the year 2000.

Warning

Don't forget to nest the parameters if a prefix is sent in the meta data!

Sort the result set#

Server-side sorting of the filtered result set is also essential to retrieve the items in the required order. In the JSON API standard, the URL parameter "sort" is used to define the sorting of the result set:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?sort=product.label'
var params = {
    sort: 'product.label'
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

This will return the results ordered by the product label. You can also tell the server to sort the result set in the reverse order by adding a minus symbol in front of the sort key:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?sort=-product.label'
var params = {
    sort: '-product.label'
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

Sorting by several keys is also possible if they are separated by a comma:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?sort=-product.status,product.id'
var params = {
    sort: '-product.status,product.id'
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

It would sort the result set by the product status (descending) and the product ID.

Warning

Don't forget to nest the parameters if a prefix is sent in the meta data!

Retrieve slices of the result#

By default, only the first 25 items are returned if nothing else is specified. To get more or less items and step through the result set, the JSON API standard uses the "page" parameter:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?sort=-product.status,product.id'
var params = {
    page: {
        offset: 0,
        limit: 100
    }
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

Thus, you will get the first 100 items instead. To get 100 items starting from the 300th one, simply increase the offset value:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?sort=-product.status,product.id'
var params = {
    page: {
        offset: 300,
        limit: 100
    }
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

When you use paging to retrieve the result set in slices, you should always use a key for sorting too! Otherwise, the order of the items returned may change between two requests. This can lead to item returned twice and items that are in the result set but won't be returned at all. The fastest sort key is always the ID of the item.

Warning

Don't forget to nest the parameters if a prefix is sent in the meta data!

Return specific fields only#

If you only need the values of a few fields and want to reduce the amount of data transferred over the network, you can specify the fields that should be returned without the rest of the available ones. In the JSON API standard the parameter "fields" is used for this. It must contain a comma separated list of item properties for the resource (product in this case) you want to reduce:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?fields[product]=product.id,product.label'
var params = {
    fields: {
        product: 'product.id,product.label'
    }
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

The response will then only return the ID and label of product items.

Warning

Don't forget to nest the parameters if a prefix is sent in the meta data!

To minimize the number of requests, the Aimeos JSON API can add related resources to the response. For example, you can tell the server that it should not only return the list of products but also the texts and prices associated to these products. The JSON API uses the parameter "include" to specify the related resources:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?include=text,price'
var params = {
    include: 'text,price'
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

You can use the "include" parameter for all items that are associated via the lists to categories, products, services, attributes, media, prices and texts. This does also work for items from the same domain that have a parent/child relationship like product properties:

curl -b cookies.txt -c cookies.txt \
-X GET 'http://localhost:8000/jsonapi/product?include=text,product/property'
var params = {
    include: 'text,product/property'
};

$.ajax({
    method: "GET",
    dataType: "json",
    url: options.meta.resources['product'], // returned from OPTIONS response
    data: params
}).done( function( result ) {
    console.log( result.data );
});

Then, the text items associated via the list table would be returned as well as the properties directly attached to the products.

Warning

Don't forget to nest the parameters if a prefix is sent in the meta data!

Comments

Become an Aimeos Partner

Aimeos partners are first-class specialists in creating or hosting your Aimeos e-commerce project. They have proven their expertise by building top level e-commerce applications using Aimeos.