This endpoint allows the receiving HEI to suggest updates to specific Learning Agreement fields, stored on the sending HEI's servers.
It is required to implement this endpoint, but servers are allowed to support only a subset of its update types (there are some updates types and more can be added in the future).
An "update request" can be looked at in two different ways. At first, we expect for EWP partners to perceive it as a set suggestions:
-
The client will sometimes send them, sometimes not. Some IRO staff will still prefer to use "the old way", and send their data by emails.
-
The server will receive them, but it will treat them as suggestions only. It will respond something like "Thank you! We will review your suggestion".
However, if adoption of EWP goes well, then the users and developers will begin to get used to the new data flow, and the meaning of "update request" will shift:
-
The client will send them often. Sending these "suggestions" will gradually become a requirement for the receiving institution. IRO staff members will prefer to use this API than sending an email.
-
The server might begin to put more trust in both EWP and the partner. It might consider saving updates without having a human review them. As this continues, the server will begin responding with "Your update has been received and approved automatically".
Initially, the features of this endpoint were covered by multiple separate APIs (one API for each type of change). However, we quickly discovered major similarities between these APIs: similar request parameters, the same content of the response, etc. So we chose to merge them into the existing API, and allow servers to specify which updates they support.
We also introduced a simple versioning on update types. As you see, each update
type has the -v1
suffix. If, in the future, we decide that some type of an
update should require more request parameters, then we will release -v2
of
this update type, while allowing the previous versions to work in a
backward-compatible manner. This system is not as flexible as EWP's API
versioning is, but it should be flexible enough.
-
Requests MUST be made with HTTP POST method. Servers SHOULD reject all other request methods.
-
The body of the request MUST contain a raw XML element described in the update-request.xsd schema. The request SHOULD also contain a matching
Content-Type
header (such astext/xml
).(This endpoint is NOT using the regular
application/x-www-form-urlencoded
request format which most of other EWP endpoints do.) -
The are various types of update requests described in the update-request.xsd schema. The server is NOT REQUIRED to support all of them. Clients MUST check if the server supports certain type of update request before sending it.
-
The server is REQUIRED to publish the list of supported update requests in its manifest entry.
-
General error handling rules apply.
-
If some of the required parameters (the ones with
minOccurs="1"
) are missing, or are passed in an invalid format, then the server MUST respond with HTTP 400 error response. -
If the request contains unknown parameters (extra elements not allowed in the schema), then the server MUST ignore such parameters, and continue with processing the request.
-
If updated learning agreement does not exist, or the requester does not cover the receiving HEI of the mobility, then server MUST respond with HTTP 400 error response.
-
If
<sending-hei-id>
doesn't match<omobility-id>
's sending HEI, then the server MUST respond with HTTP 400 error response. -
More requirements - in context of specific types of updates - are described in the update-request.xsd file.
Edit conflicts are special cases of bad requests. Such conflicts can always happen (they cannot be completely avoided), and both server and client implementers MUST be aware of them.
In context of this particular API, edit conflicts occur when the receiving HEI attempts to change something, which has been concurrently changed on the sending HEI's servers. For example:
- it tries to approve a version of the LA which is no longer the "latest draft" version,
- or, it tries to delete a course from the list of the components, but the course no longer exists on this list,
- etc.
Some edit conflicts MAY be automatically resolved be the server (the sending HEI), but most won't be. They must be detected though. For this reason:
-
The server (the sending HEI) is REQUIRED to perform some additional assertions to make sure that the client (the receiving HEI) had up-to-date data before it made the request. If it turns out that the client didn't have to up-to-date data, then the server will respond - as instructed by the general EWP error handling rules - with the HTTP 409 Conflict error.
-
The client (the receiving HEI) is REQUIRED to expect these HTTP 409 responses, and deal with them "appropriately". Usually this means that you need to fetch the fresh data from the server and ask your user to repeat his action once again. For example, you can display a message of this sort:
Sorry, it turns out that a new version of the LA has been published by the sending HEI just before you clicked 'Approve'. It seems that someone else is doing modifications to this LA in the same time you were viewing it, and he made his change "first", so your approval couldn't be saved. Please review this new version and, if it's still okay with you, click 'Approve' again!
Every update type generates edit conflicts of its own. That's why we don't explain all possible conflicts here - instead, we do that in the update-request.xsd file. (BTW - this is often true for all other EWP specifications too - many vital EWP requirements are described in the XSD annotations! You MUST read those. Always.)
Servers MUST respond with a valid XML document described by the update-response.xsd schema. See the schema annotations for further information.