addwiki / wikibase-api
Wikibase API library
Requires
- php: >=8.1
- addwiki/mediawiki-api-base: ^3.1
- addwiki/mediawiki-datamodel: ^3.1
- addwiki/wikibase-datamodel: ^3.1
- serialization/serialization: ~3.2||~4.0
- wikibase/data-model: ~9.2||~8.0
- wikibase/data-model-serialization: ~2.0
- wikibase/data-model-services: ~4.0
Requires (Dev)
- data-values/common: ~0.4.0
- data-values/data-values: ~2.0
- data-values/geo: ~4.0
- data-values/number: ~0.10.0
- data-values/serialization: ~1.0
- data-values/time: ~1.0
- data-values/validators: ~0.1.0
- mediawiki/mediawiki-codesniffer: ~38.0
- php-parallel-lint/php-parallel-lint: ^1.2
- phpunit/phpunit: ~9
README
Issue tracker: https://github.com/addwiki/addwiki/issues
Installation
Use composer to install the library and all its dependencies:
composer require "addwiki/wikibase-api:~3.0"
Example Usage
The library provides users with a large collection of Services. These services should be retrieved from the WikibaseFactory class.
Below you will find some more examples using various services. Each example follows on from the previous example (so as not to repeat the first steps). Note: this library uses namespaces so please remember to add the relevant use clauses.
Load & General Setup
require_once( __DIR__ . '/vendor/autoload.php' ); $api = new MediawikiApi( 'http://localhost/w/api.php', new UserAndPassword( 'username', 'password' ) ); // Create our Factory, All services should be used through this! // You will need to add more or different datavalues here. // In the future Wikidata / Wikibase defaults will be provided in a separate library. $dataValueClasses = array( 'unknown' => 'DataValues\UnknownValue', 'string' => 'DataValues\StringValue', 'boolean' => 'DataValues\BooleanValue', 'number' => 'DataValues\NumberValue', 'globecoordinate' => 'DataValues\Geo\Values\GlobeCoordinateValue', 'monolingualtext' => 'DataValues\MonolingualTextValue', 'multilingualtext' => 'DataValues\MultilingualTextValue', 'quantity' => 'DataValues\QuantityValue', 'time' => 'DataValues\TimeValue', 'wikibase-entityid' => 'Addwiki\Wikibase\DataModel\Entity\EntityIdValue', ); $wbFactory = new WikibaseFactory( $api, new Addwiki\Wikibase\DataModel\DataModelFactory( new DataValues\Deserializers\DataValueDeserializer( $dataValueClasses ), new DataValues\Serializers\DataValueSerializer() ) );
Create an empty entity
Create a new empty item.
$saver = $wbFactory->newRevisionSaver(); $edit = new Revision( new ItemContent( Item::newEmpty() ) ); $resultingItem = $saver->save( $edit ); // You can get the ItemId object of the created item by doing the following $itemId = $resultingItem->getId()
Set a label
Set an English label on the item Q87 assuming it exists, using a custom summary.
$getter = $wbFactory->newRevisionGetter(); $entityRevision = $getter->getFromId( 'Q87' ); $entityRevision->getContent()->getData()->setDescription( 'en', 'I am A description' ); $saver->save( $entityRevision, new EditInfo( 'Custom edit summary' ) );
Create a new statement
Create a new string statement on item Q777 if a statement for the property doesn't already exist.
$statementCreator = $wbFactory->newStatementCreator(); $revision = $getter->getFromId( 'Q777' ); $item = $revision->getContent()->getData(); $statementList = $item->getStatements(); if( $statementList->getByPropertyId( PropertyId::newFromNumber( 1320 ) )->isEmpty() ) { $statementCreator->create( new PropertyValueSnak( PropertyId::newFromNumber( 1320 ), new StringValue( 'New String Value' ) ), 'Q777' ); }
Remove a statement using a GUID
Remove the statement with the given claim (if it exists)
$statementRemover = $wbFactory->newStatementRemover(); $statementRemover->remove( 'Q123$f12bd80f-415a-c37e-9e18-234b9e19eece' );
Add a reference to a statement
$statementSetter = $wbFactory->newStatementSetter(); $revision = $getter->getFromId( 'Q9956' ); $item = $revision->getContent()->getData(); $statementList = $item->getStatements(); $referenceSnaks = array( new PropertyValueSnak( new PropertyId( 'P44' ), new StringValue( 'bar' ) ), ); foreach( $statementList->getByPropertyId( PropertyId::newFromNumber( 99 ) )->getIterator() as $statement ) { if( $statement->getReferences()->isEmpty() ) { $statement->addNewReference( $referenceSnaks ); } }
Attempt to merge 2 items
Try to merge Q999 and Q888 if possible, catch any errors.
try{ $wbFactory->newItemMerger()->merge( 'Q999', 'Q888' ); } catch( UsageException $e ) { echo "Oh no! I failed to merge!"; }
Simple Lookups
Easily lookup an item object, an individual label and redirect sources.
$itemId = new ItemId( 'Q555' ) $itemLookup = $wbFactory->newItemLookup(); $termLookup = $wbFactory->newTermLookup(); $entityRedirectLookup = $wbFactory->newEntityRedirectLookup(); $item = $itemLookup->getItemForId( $itemId ); $enLabel = $termLookup->getLabel( $itemId, 'en' ); $redirectSources = $entityRedirectLookup->getRedirectIds( $itemId );