starcitizenwiki / mediawikiapi
该包的最新版本(1.0.3)没有可用的许可证信息。
Laravel 包,用于通过 API 与 Mediawiki 安装进行交互,通过 OAuth 进行身份验证
1.0.3
2023-05-26 10:14 UTC
Requires
- php: >=7.4
- guzzlehttp/guzzle: ^6.0||^7.0.1
- mediawiki/oauthclient: ^1.1.0||^2.0
Requires (Dev)
- mockery/mockery: ~1.0
- phpunit/phpunit: ^9.2.6
This package is auto-updated.
Last update: 2024-09-26 14:06:10 UTC
README
Laravel 包,用于通过 API 与 Mediawiki 安装进行交互,通过 OAuth 进行身份验证。
composer require starcitizenwiki/mediawikiapi
安装
发布配置 php artisan vendor:publish
。
选择 StarCitizenWiki\MediaWikiApi\ApiServiceProvider
如果通过 API 编辑页面,则目标维基需要注册 OAuth 应用程序。
外观
通过 MediaWikiApi
访问。
登录
$manager = app('mediawikiapi.manager'); $manager->setConsumerFromCredentials( 'ConsumerToken', 'ConsumerSecret' ); $manager->setTokenFromCredentials( 'AccessToken', 'AccessSecret' );
基础请求
每个请求对象都扩展了 BaseRequest 类。
基础请求类包含以下方法
$request->queryParams(); // Returns the query params as an array $request->json(); // Set the request format to 'json' $request->csrfToken('TOKEN'); // Set the csrf token for this request $request->formatVersion('latest'); // Set the formatversion. Valid values are 1, 2, 'latest' $request->withTimestamp(); // Set the 'curtimestamp' param to 1 $request->addParam('key', 'value'); $request->request(); // Send the request, returns a MediaWikiResponse $request->request([ 'timeout' => 10, ]); // Send the request with additional GuzzleClient options
查询
方法
$query = MediaWikiApi::query(); // Add meta params $query->meta('tokens'); // Param meta is now 'tokens' $query->meta('siteinfo')->meta('...'); // Param meta is now 'tokens|siteinfo|...' // Add prop params $query->prop('categories'); // Param prop is now 'categories' // Set the pages to work on $query->titles('Title1|Title2'); // Or $query->titles('Title1')->titles('Title2'); // Set a category limit if prop('categories') was set $query->cllimit(-1); // return 'max' $query->cllimit(100); // return 100 // Force authentication $query->withAuthentication();
请求 CSRF 令牌
$response = MediaWikiApi::query()->meta('tokens')->request(); // True if request was not successful $response->hasErrors(); // boolean $response->getErrors(); // array // True if request has warnings $response->hasWarnings(); // boolean $response->getWarnings(); // array $token = $response->getQuery()['tokens'];
解析
方法
$parse = MediaWikiApi::parse(); // Set a page to parse $parse->page('Example'); // Add prop params $parse->prop('text'); // Param prop is now 'text'
编辑
方法
$edit = MediaWikiApi::edit(); // Set the page title to edit // Unsets a previously set page ID! $edit->title('Example'); // Or use a page ID // Unsets a previously set title! $edit->pageId(1); // Add text to the page // Automatically sets the md5 hash $edit->text('Content'); // Edit an existing section $edit->section(1); // Add a new section $edit->section(); // Set the section title $edit->sectionTitle('Title'); // Set an edit summary $edit->summary('This was an API edit'); // Set mode to create only $edit->createOnly(); // Set edit to minor // Unsets not minor $edit->minor(); // Set edit to notminor // Unsets minor $edit->notMinor(); // Set edit as bot edit $edit->markBotEdit(); // Set the CSRF Token $edit->csrfToken('token');
操作
请求任意 API 操作的通用类
// Creates an action object with ?action=action-name, request method to 'GET' and auth to false $action = MediaWikiApi::action('action-name'); // Creates an action object with ?action=foo, request method to 'POST' and auth to true $actionPostAuth = MediaWikiApi::action('foo', 'POST', true); // Creates an action object with ?action=bar $actionBar = MediaWikiApi::action('bar'); $actionBar->withAuthentication(); // auth is now true // Adding parameters $action->addParam('name', 'value'); // &name=value $action->addParam('delete', true); // &delete=true