WikibaseReconcileEdit was created as a prototype API for the Open!Next project.
Such an API could also be relevant to OpenRefine and other projects in the future.
This code is currently work in progress and some things are thus known to not to work:
- 0.0.1/minimal statement value parsing options (such as language), could lead to "interesting" things
- Anything to do with references, qualifiers
- Statement ranks and sitelink badges may have an undetermined behavior
- The property lookup by name feature is not working yet with Federated Properties. See below.
- Not fully tested, so there could be other bugs...
Provides simple reconciliation of Item edits.
Initial reconciliation is urlReconcile
which allows for simple reconciliation against a single statement value that is a URL.
The default initial behavior is:
- Merge: Labels, Descriptions, Aliases
- Set: Statements, SiteLinks
- Not Supported: Qualifiers, References, NoValues, SomeValues
This means that:
- Labels, Descriptions, Aliases will never be removed, and any new values provided will be added or replace existing values
- Statements that want to continue existing should ALWAYS be provided in the input.
Reconciliation payload 0.0.1 should look like this:
{
"wikibasereconcileedit-version":"0.0.1",
"urlReconcile": "P23"
}
A couple of different input formats are allowed.
Inspired by but not necessarily the same as a minimal format used in maxlath/wikibase-edit see here.
{
"wikibasereconcileedit-version": "0.0.1/minimal",
"labels": {
"en": "Item #3 to reconcile with"
},
"statements": [
{
"property": "P23",
"value": "https://github.com/addshore/test3"
}
]
}
The API supports request where the property
parameter either is specified by its PropertyId or the english label of that property.
This means that the following payloads would work, given that P23
has a label named identifier
.
{
"wikibasereconcileedit-version": "0.0.1/minimal",
"statements": [
{
"property": "identifier", // P23
"value": "https://github.com/addshore/test3"
}
]
}
Note: This functionality is currently not supported when using federated properties
Statements on the item to reconcile of type wikibase-item
also support reconciliation against other items.
This means the following payloads would generate the following results.
const reconcile = {
"wikibasereconcileedit-version":"0.0.1",
"urlReconcile": "P23"
}
const entity = {
"wikibasereconcileedit-version": "0.0.1/minimal",
"statements": [
{
"property": "P23",
"value": "https://github.com/addshore/test3"
},
{
"property": "P12",
"value": "https://github.com/addshore/test4"
}
]
}
const payload = {
reconcile: reconcile,
entity: entity
}
In this example P12
is of type wikibase-item
.
P23
would reconcile against the item with a statement value set to https://github.com/addshore/test3
.
The second statement of the entity would make the API look for an item with the reconciliation property P23
set to https://github.com/addshore/test4
.
If no existing item was found, it would get created and be saved with a P23
statement having the value https://github.com/addshore/test4
Initially we use JSON that matches regular Entity serialization.
Edit payload 0.0.1/full
should look like this:
{
"wikibasereconcileedit-version": "0.0.1/full",
"type": "item",
"labels": {
"en": {
"language": "en",
"value": "Item #3 to reconcile with"
}
},
"descriptions": {},
"aliases": {},
"claims": {
"P23": [
{
"mainsnak": {
"snaktype": "value",
"property": "P23",
"datavalue": {
"value": "https://github.com/addshore/test3",
"type": "string"
},
"datatype": "url"
},
"type": "statement",
"rank": "normal"
}
]
},
"sitelinks": {}
}
Note: that you do not need to provide statement GUIDs or any hashes.
Provides batch reconciliation of Item edits.
Batch payload looks very similar to the edit payload but requires an entities
parameter rather than a single entity
.
{
"reconcile": {
"wikibasereconcileedit-version": "0.0.1",
"urlReconcile": "P1"
},
"entities": [
{
"wikibasereconcileedit-version": "0.0.1/minimal",
"statements": [
{
"property": "identifier",
"value": "https://gitlab.com/OSEGermany/ohloom/1"
},
{
"property": "name",
"value": "OHLOOM-1"
},
{
"property": "bill of materials",
"value": "https://gitlab.com/OSEGermany/ohbroom/something-something/sBoM.csv"
}
]
},
{
"wikibasereconcileedit-version": "0.0.1/minimal",
"statements": [
{
"property": "identifier",
"value": "https://gitlab.com/OSEGermany/ohloom/2"
},
{
"property": "name",
"value": "OHLOOM-2"
},
{
"property": "bill of materials",
"value": "https://gitlab.com/OSEGermany/ohbroom/something-something/sBoM.csv"
}
]
}
],
"token": ""
}
Example output:
{
success: true,
result: [
{ entityId: 'Q2', revisionId: 13 },
{ entityId: 'Q3', revisionId: 14 }
]
}
In order to make requests they need to be authenticated and with an edit token supplied in the request payload. Authentication can either be done by using the action api or OAuth.
OAuth requires the OAuth Extension to be installed and a OAuth consumer created via the wiki/Special:OAuthConsumerRegistration/propose
page.
Follow the instructions here on how to create a OAuth owner-only consumer.
For an example on how to request a edit token and make an authenticated request using OAuth see the example python script.
Copy .api-testing.config.json.template to .api-testing.config.json
and fill out required parameters.
Run the tests
npm run api-testing
Lint the tests
npm run api-testing-lint
Fix the linting issues
npm run api-testing-lint-fix