GET Requests
An HTTP GET
returns existing Resource item(s). GET
must be an idempotent
operation. GET
is a required verb.
Request URLs
A GET
request can specify either a collection of items or a specific item:
-
GET /ed-fi/students
with or without query string parameters retrieves a list ("GET All" queries). -
GET /ed-fi/students/[identifier]
retrieves a specific student ("GET by ID").
If the natural key is provided as a query string, then the result will be a collection containing only one item.
An Ed-Fi API should support searching capabilities with the possible use of filters, paging, and ordering. These are discussed below. Information about all supported capabilities, their configurations, and their default values should be available to client applications via the Discovery API .
Search
An Ed-Fi API must support querying capabilities when searching a collection of
Resources. Query operators are applied to the query string using the following
format: {collectionURI}?{propertyName}={value}
. Additional
{propertyName}={value}
terms may be appended after an ampersand, &
.
For example, to search all available Students having the first name "John" and surname "Smith":
https://api.example.com/v3/ed-fi/students?firstName=john&lastSurname=Smith
Resources must be queryable by natural key, and should also be queryable by other properties on the root of the Resource. The Open API specification documents will show which properties are searchable.
When a searchable parameter is nested under another object in the JSON payload,
the Ed-Fi API specifications require the query string to use only the parameter
name without dereferencing the parent element name. For example, the JSON
document for a studentSchoolAssociation
includes schoolId
nested below
schoolReference
. In the JsonPath query language, the query for a particular
schoolId would then be ?schoolReference.schoolId=xyz
. However, the Ed-Fi API
specifications predate and do not use JsonPath. Instead, they make a simplifying
assumption that schoolId
by itself is uniquely searchable without
dereferencing the parent entity, schoolReference
. Thus, the correct HTTP query
term is therefore simply ?schoolId=xyz
.
Paging
Paging is a mechanism that restricts the number of results returned by an
operation and has proven critical to the efficient usage of Ed-Fi APIs. The
limit
parameter should be supported in the query string and allow the client
to set the maximum number of records to return. If no value is supplied, the
limit
parameter should default to 25.
The offset
parameter should be available to the client to specify how many
records to skip when getting the result set. The value for offset
should
default to 0.
When multiple records are being returned, the total count of all records should be returned, as part of the HTTP header information.
An Ed-Fi API must use the same sort order on all query requests, so that
repeated GET
requests with the same limit
and offset
parameters retrieve
the same records, unless the collection has been modified. If new records are
inserted or existing records are deleted, these modifications will necessarily
alter which records are included in the response.
Paging Examples
For example, the following request will retrieve the first 25 student records:
https://api.example.com/ed-fi/students
If the total-count
response header has a value greater than 25, then the
following request will retrieve the next set of students, up to 25. Note that
the offset
is zero based, which means the number 25 represents the 26th
record.
https://api.example.com/v1/students?offset=25
The next example increases the number of records requested to 100, instead of 25, and it starts with the 101st record in the collection.
https://api.example.com/v1/students?offset=100&limit=100
Alternate Paging Mechanisms
Many databases have known performance limitations when using offset
beyond
around 10,000 records. Before the fourth revision to these guidelines, support
for limit
/offset
queries was a required feature of an Ed-Fi API. This has
been relaxed to a recommended
feature, so that API hosts may disable use of
these parameters if they are concerned about potential impact of "deep" (beyond
10,000) queries on their databases.
Alternate approaches to paging could be implemented, for example using keyset or
cursor-based parameters. A common approach the resolves the performance
limitations is to set a lower boundary on a monotonically increasing field, such
as a numeric identifier or a date. For example, a resource could support paging
by using the _lastModifiedDate
metadata attribute instead of offset
. This
could be expressed in a query string as minModifiedDate
:
https://api.example.com/ed-fi/students?minModifiedDate=2024-03-29T18:23:57&limit=100
This query implies that the API will sort the students by a "modified date"
attribute or column, and return the next 100 records where that modification
date is strictly greater than 2024-03-29T18:23:57
. The API client would look
at the modified date of the 100th record in the response, and use that value as
the minModifiedDate
in the subsequent request.
As an experimental feature, this example is merely one possibility, rather than a prescribed approach.
Ordering
Ordering is a mechanism that sorts the objects returned by one or more of the fields returned. Ordering could be implemented with the use of URL query string parameters. If implemented, it must:
-
Take directionality as a parameter (ascending/descending).
-
Respect paging parameters.
-
Guarantee that repeated queries with the same order and paging parameters, when no data changes have occurred, reliably return the same sequence of objects.
For example, an Ed-Fi API could return all Student School Associations from smallest School Id to largest with the following URL fragment:
/ed-fi/studentSchoolAssociations?orderBy=SchoolId&direction=desc.
As an experimental feature, this example is merely one possibility, rather than a prescribed approach.
Request Body
GET
requests do not have a request body.
Request Headers
In general, there is no requirement that an Ed-Fi API support any special
request headers other than Authorization
. Specific implementations may use
request headers for special purposes; for example, the Ed-Fi ODS/API uses
special headers with the Profiles and Change Queries features.
An Ed-Fi API that supports etags
should support the If-Match
and
If-None-Match
header for supporting caches.
Response Body
A "GET by ID" request must return a single item if the identifier exists, or nothing if the identifier is not found. In the latter case, the request must use status code 404 (NotFound).
A "GET All" query must return a collection, even if the collection is empty.
In a JSON response, an empty collection is represented by []
.
Metadata
The items in a GET
response body could be modified to include the one or
more of the following metadata attributes:
-
_lastModifiedDate
, which is the datetime when one or more of the document's values were last modified. -
_etag
value -
_lineage
describing the source and/or modifications to the data. Recording the modifications may be useful for data that have been manipulated after receipt, for example an address that has been regularized by third party postal software. The two proposed timestamps are with respect to the API itself - not the source system. The format is a Unix timestamp. TheapiModifyTimestamp
is thus the same value as the_lastModifiedDate
; the new name provides a more compact format without breaking any existing integrations with_lastModifiedDate
.
The following example demonstrates all forms of metadata.
{
"id": "986a44e7cfcf4019b7b2ea4a640c6d20",
"schoolReference": {
"schoolId": 255901107
},
"schoolYearTypeReference": {
"schoolYear": 2022
},
"calendarCode": "2010605675",
"calendarTypeDescriptor": "uri://ed-fi.org/CalendarTypeDescriptor#Student Specific",
"gradeLevels": [],
"_etag": "5250159352800270276",
"_lastModifiedDate": "2024-03-29T18:23:57.2882372Z",
"_lineage": {
"sourceSystem": "Example SIS",
"apiCreateTimestamp": 1711754637,
"apiModifyTimestamp": 1711761837,
"modifications": []
}
}
At the time of publication, lineage is a new proposal that has not been implemented in any known Ed-Fi API applications. The example provided above is not a required format for optional lineage information.
Deprecation of Links
While not described in prior versions of these Guidelines, the Ed-Fi ODS/API
Platform inserts a link
metadata construct on all references when responding
to a GET
request. This property describes the relationship of the reference
and provides a locator that can be used to construct the full URL to the
referenced item.
If this element were required, systems that store JSON documents would be forced
to enrich the document with information not immediately available in the POST
or PUT
request pipeline, unlike the other metadata described above. Few client
applications utilize this feature, and alternatives exist. Therefore, it is not
recommended that new Ed-Fi API applications include this metadata element.
The Calendar
resource shown above is duplicated here, with inclusion of two
link
entries as provided by the Ed-Fi ODS/API Platform. To re-iterate,
inclusion of link
is not a preferred practice in new implementations.
{
"id": "986a44e7cfcf4019b7b2ea4a640c6d20",
"schoolReference": {
"schoolId": 255901107,
"link": {
"rel": "School",
"href": "/ed-fi/schools/2af36358c7824afe8b3b88aea077c172"
}
},
"schoolYearTypeReference": {
"schoolYear": 2022,
"link": {
"rel": "SchoolYearType",
"href": "/ed-fi/schoolYearTypes/337ea29f861b4ee88fa9714863cc0b98"
}
},
"calendarCode": "2010605675",
"calendarTypeDescriptor": "uri://ed-fi.org/CalendarTypeDescriptor#Student Specific",
"gradeLevels": [],
"_etag": "5250159352800270276",
"_lastModifiedDate": "2024-03-29T18:23:57.2882372Z"
}
A client application wishing to to look up information about the School
with
identifier 255901107
can read the exact path from the link
. Without this,
all clients can alternately perform a query, i.e. GET /ed-fi/schools?schoolId=255901107
. Examples with multiple part natural keys
also support direct queries, as the components of the natural key are always
queryable.
Response Headers
There is no restriction on the standard or custom response headers that may be
included in the response to a GET
request. A special header of note: an Ed-Fi
API should provide a query string option for retrieving a count of all items
in the collection, which is useful in determining if there are additional pages
of data to retrieve. The recommended approach is use query string
?totalCount=true
and respond with an additional header, total-count: [number]
(example: total-count: 1234
).
Standard Status Codes
The following status codes must be supported for GET
responses:
Status Code | Meaning | When to Use |
---|---|---|
200 | OK | All successful requests, including "GET All" when there are no results to list |
401 | Unauthorized | The request requires authentication. The OAuth bearer token was either not provided or is invalid. |
403 | Forbidden | The request cannot be completed in the current authorization context. |
404 | Not Found | The resource could not be found. If Use-Snapshot header is set to true, the snapshot may have been removed. |
500 | Server Error | An unhandled error occurred on the server. |
Code 304 (Not Modified) also must be supported if the application supports ETags. Other HTTP status codes may be used as needed for specific situations.