Description:
As tool builder I want to read data of all sitelinks of a particular wiki on an item so that I can use them in my tool.
Acceptance criteria:
- Following endpoint is developed:
GET /entities/items/{item_id}/sitelinks/{site_id}
- Following error cases have to be considered:
HTTP response code | response payload | |
---|---|---|
Item does not exist | 404 | "code": "item-not-found" "message": "Could not find an item with the ID: {item_id}" |
Invalid item ID | 400 | "code": "invalid-item-id" "message": "Not a valid item ID: <ITEM_ID>" |
Sitelink not defined for item | 404 | "code": "sitelink-not-defined" "message": "No sitelink found for the ID: {item_id} for the site {site_id}" |
Invalid site ID | 400 | "code": "invalid-site-id" "message": "Not a valid site ID: <SITE_ID>" |
Notes:
- Handle HTTP conditional request headers as in GET /entities/items/{item_id}/statements
- Handle user authentication/authorization like in GET /entities/items/{item_id}/statements
- Items that have been redirected should be handled like GET /entities/items/labels/en
Possibly relevant pointers:
- Suggestion in 2020 Wikibase REST API proposal: https://wmde.github.io/wikibase-rest-api-proposal/
- How Wikibase Action API handles this: https://www.wikidata.org/w/api.php?action=wbgetentities&ids=Q42&props=sitelinks
Task breakdown notes
- add GET /entities/items/{item_id}/sitelinks/{site_id} to OAS
- create SiteLinkRetriever interface and implementation
- interface method signature SiteLinkRetriever::getSiteLink( ItemId $id, string $siteId ): SiteLink
- using SiteLinkLookup and SiteLinksReadModelConverter
- happy path
- validation
- create a site id request validator. SiteList::getGlobalIdentifiers() might be a good place to get the list of valid sites from
- item existence check and redirect handling
- respond 404 if the site link for the requested site does not exist
- apply middlewares to the get sitelink route + e2e tests and RouteHandlersTest
- spec tests
- mark ready for prod