Extension:UserAgreement
UserAgreement Release status: stable |
|
---|---|
Implementation | User interface, API , Database |
Description | Render a user agreement before granting access to a Wiki. |
Author(s) | |
Latest version | 2.0.0 (2023-06-26) |
Compatibility policy | Master maintains backward compatibility. |
MediaWiki | 1.39+ |
Database changes | Yes |
License | MIT License |
Download | |
Mediawiki |
|
$wgUserAgreement_DaysToReaccept |
|
Quarterly downloads | 6 (Ranked 128th) |
Translate the UserAgreement extension if it is available at translatewiki.net | |
Issues | Open tasks · Report a bug |
Introduction
editUserAgreement adds the ability for administrators to specify a user agreement message and have it rendered to users for acknowledgement before granting access to a wiki's contents. This only applies to users who are logged in.
Users who have not yet acknowledged the current version of the user agreement will be presented with the agreement upon visiting any wiki page and will be unable to view any wiki content until they've acknowledged the user agreement. Users need only acknowledge the current version of the user agreement once to gain access to a wiki's content.
UserAgreement does not depend upon any other extension.
Installation
edit- Download and move the extracted
UserAgreement
folder to yourextensions/
directory.
Developers and code contributors should install the extension from Git instead, using:cd extensions/
git clone https://gerrit.wikimedia.org/r/mediawiki/extensions/UserAgreement - Add the following code at the bottom of your LocalSettings.php file:
wfLoadExtension( 'UserAgreement' );
- Run the update script which will automatically create the necessary database tables that this extension needs.
- Configure as required.
- Done – Navigate to Special:Version on your wiki to verify that the extension is successfully installed.
Configuration
editFlag | Default | Description |
---|---|---|
$wgUserAgreement_DaysToReaccept
|
0
|
The number of days after which the user needs to re-accept the agreement even if it has not changed. A value of 0 means that the user does not need to re-accept the agreement unless it has changed. A value of 365 means that the user needs to re-accept the agreement every year even if it has not changed. |
Usage
editTo specify a user agreement message for users to acknowledge, simply edit the page Mediawiki:Useragreement
(watch your capitalization) to contain exactly the message you would like presented to users in wikitext format.
Each time the Mediawiki:Useragreement
page is updated, all users will be required to acknowledge the updated user agreement before being able to continue accessing the wiki's content.
By default, the user agreement message is left blank and thus, no message is presented to users and they are not required to acknowledge anything before viewing a wiki's content.
Implementation Details
editUserAgreement adds a new database table called useragreement
with columns ua_user
and ua_user_accepted_timestamp
.
This table is used to record the timestamps corresponding to the last time each user acknowledged some version of the user agreement.
The logic governing user agreement display is simple.
If a user's ua_user_accepted_timestamp
value is greater than the revision timestamp of the Mediawiki:Useragreement
page's current revision (meaning the user accepted some version of the user agreement after the current version of the agreement was last edited), then that user is not required to view and acknowledge the current version of the user agreement before accessing the wiki's content.
Otherwise, the user will be presented with the current version of the user agreement upon visiting any wiki page and will not be granted access to any of the wiki's content until they have acknowledged the current version of the user agreement, which will then update the ua_user_accepted_timestamp
column for that user.
Version History
edit- Version 2.0.0
- added
$wgUserAgreement_DaysToReaccept
- code cleanup
- Version 1.0.1
- Added documentation url link on Special:Version page.
- Version 1.0.0
- Initial version