Search API v1 → v2 mapping
Migrating from v1 to v2 involves updating your endpoint URLs to call the new v2 version and modifying your applications to account for breaking changes introduced in v2.
Search Request
Here's a mapping of how v1 search queries map to v2:
Text Attribute Search Parameters
Use the range
operator instead of the deprecated range_closed
operator
v1 | v2 |
---|---|
{ "type": "terminal", "service": "text", "parameters": { "attribute": "search.attribute", "operator": "range_closed", "value": [ 5, 10 ] } } |
{ "type": "terminal", "service": "text", "parameters": { "attribute": "search.attribute", "operator": "range", "value": { "from": 5, "include_lower": true, "to": 10, "include_upper": true } } } |
The range
operator no longer accepts an array of values as an input. Use an object notation
to query ranges
v1 | v2 |
---|---|
{ "type": "terminal", "service": "text", "parameters": { "attribute": "search.attribute", "operator": "range", "value": [ 5, 10 ] } } |
{ "type": "terminal", "service": "text", "parameters": { "attribute": "search.attribute", "operator": "range", "value": { "from": 5, "include_lower": true, "to": 10, "include_upper": false } } } |
Strucmotif Search Parameters
If you used this search API to search for structure motifs, refer to this list of breaking changes in
strucmotif
query parameters:
whitelist
is renamed toallowed_structures
blacklist
is renamed toexcluded_structures
- empty arrays are disallowed
v1 | v2 |
---|---|
{ "query": { "type": "terminal", "service": "strucmotif", "parameters": { "value": { "entry_id": "2mnr", "residue_ids": [ { "label_asym_id": "A", "label_seq_id": 162 }, { "label_asym_id": "A", "label_seq_id": 193 }, { "label_asym_id": "A", "label_seq_id": 219 } ] }, "rmsd_cutoff": 10, "exchanges": [], "blacklist": [ "2mnr" ] } } } |
{ "query": { "type": "terminal", "service": "strucmotif", "parameters": { "value": { "entry_id": "2mnr", "residue_ids": [ { "label_asym_id": "A", "label_seq_id": 162 }, { "label_asym_id": "A", "label_seq_id": 193 }, { "label_asym_id": "A", "label_seq_id": 219 } ] }, "rmsd_cutoff": 10, "excluded_structures": [ "2mnr" ] } } } |
Structure and Strucmotif Search File Upload Parameters
File upload parameters for structure
and strucmotif
services have changed:
file
is renamed todata
file_format
is renamed toformat
gzipped
is removedccp4
format is no loner supported
v1 | v2 |
---|---|
{ "file": "...", "file_format": "cif", "gzipped": true } |
{ "data": "...", "format": "cif" } |
Request Options
Pagination
If you used request_options
to paginate through the search results, note that the
pager
parameter is renamed to paginate
v1 | v2 |
---|---|
{ "request_options": { "pager": { "start": 0, "rows": 10 } } } |
{ "request_options": { "paginate": { "start": 0, "rows": 10 } } } |
Faceted Queries
If you used the filtering capabilities for faceted (aggregated) search queries, you need to change your applications to account for the following changes:
-
The
filter
parameter is removed from Terms Facet, Histogram Facet, Date Histogram Facet, Range Facet, Date Range Facet, and Cardinality Facet. Use a dedicated Filter Facet to obtain the aggregations relevant to the search query -
The search query syntax in the
filter
context of the Filter Facet fully supports boolean operations
v1 | v2 |
---|---|
{ "request_options": { "facets": [ { "attribute": "search.attribute.name", "min_interval_population": 1, "aggregation_type": "terms", "filter": { "attribute": "search.attribute.id", "operator": "in", "value": [ "1", "2" ] } } ] } } |
{ "request_options": { "facets": [ { "filter": { "type": "terminal", "service": "text", "parameters": { "attribute": "search.attribute.id", "operator": "in", "value": [ "1", "2" ] } }, "facets": [ { "name": "My Aggregation", "attribute": "search.attribute.name", "aggregation_type": "terms" } ] } ] } } |
Following parameters were removed from the faceted (aggregated) search queries:
-
max_num_intervals
is removed from Histogram Facet, Date Histogram Facet, Range Facet, Date Range Facet -
min_interval_population
is removed from Range Facet, Date Range Facet -
min_interval_population
default is changed from 0 to 1
Aggregation name parameter was added to faceted (aggregated) search queries. This property is required:
v1 | v2 |
---|---|
{ "request_options": { "facets": [ { "attribute": "search.attribute", "min_interval_population": 1, "aggregation_type": "terms" } ] } } |
{ "request_options": { "facets": [ { "name": "My Aggregation", "attribute": "search.attribute", "aggregation_type": "terms" } ] } } |
Results Metadata
The results_verbosity
parameter default changed from verbose
to
minimal
. Additional metadata will no longer be returned by default and search results
will be represented by the identifier and a total score only. Set results_verbosity
to
verbose
to match an old behavior
v1 | v2 |
---|---|
{ "query": { "type": "terminal", "service": "sequence", "parameters": { "value": "VLSPADKTNVKAAWGKVGAHA", "target": "pdb_protein_sequence" } }, "return_type": "polymer_entity" } |
{ "query": { "type": "terminal", "service": "sequence", "parameters": { "value": "VLSPADKTNVKAAWGKVGAHA", "sequence_type": "protein" } }, "request_options": { "results_verbosity": "verbose" }, "return_type": "polymer_entity" } |
Search Response
Here's a mapping of how v1 search response maps to v2:
Faceted queries response
If you used faceted (aggregated) search queries, refer to this list of breaking changes:
drilldown
is renamed tofacets
groups
is renamed tobuckets
attribute
is renamed toname
distinct_count
is renamed tovalue
(cardinality facet response)
v1 | v2 |
---|---|
{ "drilldown": [ { "attribute": "Terms", "groups": [ { "label": "Bucket Key", "population": 100 } ] }, { "attribute": "Cardinality", "distinct_count": 10 } ] } |
{ "facets": [ { "name": "Terms", "buckets": [ { "label": "Bucket Key", "population": 100 } ] }, { "name": "Cardinality", "value": 10 } ] } |
Contact Us
Contact info@rcsb.org with questions or feedback about this service.