Release status: stable
|Implementation||User interface, API, Database|
|Description||Render a user agreement before granting access to a Wiki.|
|Latest version||2.0.0 (2023-06-26)|
|Compatibility policy||Master maintains backward compatibility.|
|Quarterly downloads||7 (Ranked 152nd)|
|Translate the UserAgreement extension if it is available at translatewiki.net|
|Issues||Open tasks · Report a bug|
UserAgreement 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.
- Download and place the file(s) in a directory called
- 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.
||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.|
To 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 Edit
UserAgreement adds a new database table called
useragreement with columns
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
- code cleanup
- Version 1.0.1
- Added documentation url link on Special:Version page.
- Version 1.0.0
- Initial version