Skip to main content

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 .

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.

note

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.
note

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. The apiModifyTimestamp 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": []
}
}
note

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.

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 CodeMeaningWhen to Use
200OKAll successful requests, including "GET All" when there are no results to list
401UnauthorizedThe request requires authentication. The OAuth bearer token was either not provided or is invalid.
403ForbiddenThe request cannot be completed in the current authorization context.
404Not FoundThe resource could not be found. If Use-Snapshot header is set to true, the snapshot may have been removed.
500Server ErrorAn 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.