mediawiki / guzzle-json-auth
Authenticate with a JSON endpoint using a configurable Guzzle client
Installs: 23
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 5
Type:mediawiki-extension
Requires
- php: >=5.4.0
- composer/installers: ^1.0.1
- guzzlehttp/guzzle: ^5.2.0
Requires (Dev)
- phpunit/phpunit: ^4.0.0
- scrutinizer/ocular: ^1.1.0
- squizlabs/php_codesniffer: ^2.1.0
This package is auto-updated.
Last update: 2024-10-22 06:03:22 UTC
README
Authenticate your MediaWiki with a JSON endpoint using a configurable Guzzle client
Install
Requirements
- PHP >= 5.4
- Composer
- MediaWiki 1.22
Via Composer
$ composer require mediawiki/guzzle-json-auth
Usage
To Setup the authentication, add the following lines to your LocalSettings.php and change the values to your needs:
# Setup GuzzleJsonAuth $wgGuzzleJsonAuthUrl = 'http://yourapplication.com/your_json_endpoint'; $wgGuzzleJsonRequestBaseKey = 'User'; $wgGuzzleJsonRequestUsernameKey = 'username'; $wgGuzzleJsonRequestPasswordKey = 'password'; $wgGuzzleJsonResponseBaseKey = 'user'; $wgGuzzleJsonResponseUsernameKey = 'username'; $wgGuzzleJsonResponseRealNameKey = 'real_name'; $wgGuzzleJsonResponseEmailKey = 'email'; // Load and initialize the GuzzleJsonAuth extension require_once("$IP/extensions/GuzzleJsonAuth/GuzzleJsonAuth.php"); $wgAuth = new \MediaWiki\GuzzleJsonAuth\GuzzleJsonAuth();
Authenticated users will be created in your Wikis database, but without password.
The authentication endpoint needs to return at least tne username, real name and email of the authenticated user as result. If the authentication failed, it must not return the username, otherwise it the user will be logged in nonetheless.
This extension will fall back to local authentication, if the user could not be authenticated externally.
Change log
Please see CHANGELOG.md for more information what has changed recently.
Testing
$ phpunit
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email ravage@bluewin.ch instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.