Erweiterung:ConfirmAccount

From MediaWiki.org
Jump to navigation Jump to search
This page is a translated version of the page Extension:ConfirmAccount and the translation is 42% complete.

Other languages:
Deutsch • ‎English • ‎català • ‎dansk • ‎español • ‎français • ‎italiano • ‎polski • ‎português • ‎português do Brasil • ‎sicilianu • ‎suomi • ‎中文 • ‎日本語
MediaWiki-Erweiterungen
Crystal Clear action run.svg
ConfirmAccount
Erscheinungsstatus: stabil
ConfirmAccounts.png
Einbindung User identity, Database, Special page
Beschreibung Erfordert den Antrag und Bestätigung von Benutzerkonten.
Autor(en) Aaron Schulztalk
MediaWiki 1.23+
Datenbankänderungen Ja
Tabellen account_requests
account_credentials
Lizenz GNU General Public License 2.0 or later
Herunterladen
README
Parameter

  • $wgMakeUserPageFromBio
  • $wgAutoUserBioText
  • $wgAutoWelcomeNewUsers
  • $wgRejectedAccountMaxAge
  • $wgConfirmAccountRejectAge
  • $wgAccountRequestThrottle
  • $wgAccountRequestWhileBlocked
  • $wgConfirmAccountRequestFormItems
  • $wgAccountRequestExts
  • $wgAccountRequestTypes
  • $wgConfirmAccountSortkey
  • $wgConfirmAccountSaveInfo
  • $wgConfirmAccountContact
  • $wgConfirmAccountCaptchas
  • $wgConfirmAccountFSRepos
  • $wgConfirmAccountNotice
Hinzugefügte Rechte

  • confirmaccount
  • requestips
  • lookupcredentials
Verwendete Hooks
LoadExtensionSchemaUpdates
PersonalUrls
UserCreateForm
UserLoginForm
BeforePageDisplay
AdminLinks
AuthChangeFormFields
Übersetze die ConfirmAccount Erweiterung wenn sie auf translatewiki.net verfügbar ist
Prüfe die Benutzungs- und Versionsmatrix.
Probleme Offene Aufgaben · Einen Fehler melden

Die Erweiterung ConfirmAccount deaktiviert direkte Benutzerkontenerstellung und erfordert die Bestätigung neuer Konten durch Administratoren (bureaucrat). Direkte Benutzerkontenerstellung kann noch über die Konfiguration der Benutzerrechte aktiviert werden (wenn Sysops/Bureaucrats direktes Erstellen ermöglicht werden soll).

Die Erweiterung ConfirmEdit kann (gemeinsam mit der ConfirmAccount Erweiterung) genutzt werden, um Captchas gegen Massenanfragen einzusetzen.

Installation

  • Füge folgenden Code am Ende deiner LocalSettings.php hinzu:
    require_once "$IP/extensions/ConfirmAccount/ConfirmAccount.php";
    
  • Führe das Aktualisierungsskript aus, welches automatisch die notwendigen Datenbanktabellen erstellt, die diese Erweiterung braucht.
  • Ensure the wiki has write permissions on $wgUploadDirectory, or manually set $wgFileStore ['accountreqs'] and $wgFileStore['accountcreds'] to a writable directory of your choice.
  • Yes Erledigt – Navigiere zu Special:Version in deinem Wiki (bei Einstellung auf deutsch nach Spezial:Version), um zu prüfen, dass die Erweiterung erfolgreich installiert ist.

Optionale Konfiguration

Es gibt mehrere Konfigurationsvariablen, die in LocalSettings.php angepasst werden können (nach der Zeile require_once, die ConfirmAccount.php enthält). Siehe ConfirmAccount.config.php für all die Variablen, die gesetzt werden können. (Die Standardwerte sind in ConfirmAccount.config.php, aber diese Datei sollte nicht verändert werden.)

For example, to set the person's bio as their userpage, set $wgMakeUserPageFromBio = true.

Standardmäßig wird eine Biographie, die mindestens 6 Wörter umfasst, verlangt, damit der neue Benutzer das Anforderungsformular absenden kann. Zur Anpassung dieses Werts ändere $wgConfirmAccountRequestFormItems['Biography']['minWords'] in LocalSettings.php, z.B. für 10 Wörter:
$wgConfirmAccountRequestFormItems['Biography']['minWords'] = 10;

To disable the biography, set $wgConfirmAccountRequestFormItems ['Biography']['enabled'] to false:

$wgConfirmAccountRequestFormItems['Biography']['enabled'] = false;
Administratoren (sysop) können noch immer Benutzerkonten direkt erstellen. Um dies zu deaktivieren, füge in LocalSettings.php hinzu:
$wgGroupPermissions['sysop']['createaccount'] = false;
Wenn nur angemeldeten Benutzern erlaubt ist, Seiten zu lesen, stelle sicher, dass die Antragsseite für ein neues Benutzerkonto der $wgWhitelistRead hinzugefügt ist. Zum Beispiel:
$wgWhitelistRead = array( 'Special:RequestAccount', 'Main Page' );
In anderen Sprachen musst du "Special" und "Main Page" mit den sprachspezifischen Worten ersetzen, wie "Spezial" und "Hauptseite" in einem deutschen Wiki – sonst wird niemand ein Benutzerkonto erstellen können.

Um Benutzer basierend auf ihren Interessen weiter zu kategorisieren, können MediaWiki:Requestaccount-areas eingerichtet werden. Das sollte in einem Format wie diesem passieren:

*Thema|Thema Wikiseite|Text, der allen Biographien interessierter Benutzer hinzugefügt wird|Text, der allen Biographien interessierter Benutzer in Gruppe0 hinzugefügt wird|Text, der allen Biographien interessierter Benutzer in Gruppe1 hinzugefügt wird|Text, der allen Biographien interessierter Benutzer in Gruppe2 hinzugefügt wird|…

Diese Gruppennummern basieren auf $wgAccountRequestTypes. Wenn also 0 der Index ist für 'Autoren', dann werden 'Autoren', die an diesem Thema interessiert sind, den Text für die Gruppe0 hinzugefügt bekommen. Das kann sinnvoll sein, etwa wenn Benutzer entweder als Autoren oder Bearbeiter bestätigt werden können. Autoren können die "Kategorie:X Autoren" haben, wo X das Thema ist (etwa "Mathematik") und Bearbeiter bekommen die "Kategorie:X Bearbeiter". Du kannst soviele Gruppen verwenden, wie du möchtest, aber du brauchts mindestens eine.

Mindesteinstellungen

To attempt to prevent spam, instead of captchas, blacklists and filters; manually moderate new user registrations, with a simpler Request account. Requesting only a username, email address and brief message. Add the following to LocalSettings.php after the line require_once "$IP/extensions/ConfirmAccount/ConfirmAccount.php";.

 $wgMakeUserPageFromBio = false;
 $wgAutoWelcomeNewUsers = false;
 $wgConfirmAccountRequestFormItems = array(
 	'UserName'        => array( 'enabled' => true ),
 	'RealName'        => array( 'enabled' => false ),
 	'Biography'       => array( 'enabled' => false, 'minWords' => 50 ),
 	'AreasOfInterest' => array( 'enabled' => false ),
 	'CV'              => array( 'enabled' => false ),
 	'Notes'           => array( 'enabled' => true ),
 	'Links'           => array( 'enabled' => false ),
 	'TermsOfService'  => array( 'enabled' => false ),
 );

Optionally tweak system messages: requestaccount-text, requestaccount-notes, requestaccount-ext-text, requestaccount-acc-text.

Verwendung

Confirming account requests on Special:ConfirmAccounts (beta form)
  1. As a bureaucrat (or other user with the confirmaccount permission), browse to Special:ConfirmAccounts
  2. Click Review
  3. You will see the whole form with the users' data. Carefully review the form, and proceed to creating the account or rejecting the request.
  4. If you chose to create the account, the user's biography will become their userpage and the userpage will be automatically created with the default summary of Creating user page with biography of new user.
  5. After an account is created, the data input by the user at the time of the request can be referred to by typing the username at Special:UserCredentials

Note: In order for bureaucrats to get notified of pending requests you need to set an email / mailing list in LocalSettings.php:

$wgConfirmAccountContact = 'Bureaucrat@domain.com';

Sending notification email to multiple users

This extension allows sending emails to multiple approvers to confirm the account if these users have the confirmaccount-notify permission. This is in addition/alternative to the $wgConfirmAccountContact setting.

This can be achieved (for instance for bureaucrats) by providing them this permission by adding the following to LocalSettings.php:

$wgGroupPermissions['bureaucrat']['confirmaccount-notify'] = true;

Enhancements

Pruning Frequency

To combat robot-requests, default settings prevent rejected email accounts from re-requesting an account for a random period of time after rejection. If you want rejected emails to be able to re-request accounts immediately after rejection, or after a fixed wait-time (days, weeks, months, or even years after rejection), apply the following 2 steps:

1) In LocalSettings.php, after required declaration, set Rejected-Age to 0 (for immediate expiration on rejection), or to your desired wait-time, in seconds:

require_once "$IP/extensions/ConfirmAccount/ConfirmAccount.php";
$wgRejectedAccountMaxAge = 0;

2) Add one line to the file /frontend/specialpages/actions/RequestAccount_body.php at the very end of the function showForm() which shows the Request form, to force pruning right before any new request:

original code:

$out->addWikiMsg( 'requestaccount-footer' );
}

new code:

$out->addWikiMsg( 'requestaccount-footer' );		
# PRUNE
ConfirmAccount::runAutoMaintenance();
}

"Request account" Link

Wenn du einen "Request account" Loginlink hinzufügen möchtest, füge das Folgende in der "LocalSettings.php" Datei hinzu:

$wgHooks['PersonalUrls'][] = 'onPersonalUrls';

function onPersonalUrls( array &$personal_urls, Title $title, SkinTemplate $skin  ) {
    // Add a link to Special:RequestAccount if a link exists for login
    if ( isset( $personal_urls['login'] ) || isset( $personal_urls['anonlogin'] ) ) {
            $personal_urls['createaccount'] = array(
                'text' => wfMessage( 'requestaccount' )->text(),
                'href' => SpecialPage::getTitleFor( 'RequestAccount' )->getFullURL()
            );
    }
    return true;
}

außerdem den Text "Request account" zur Seite "MediaWiki:Requestaccount".

Bekannte Probleme

  • Do not set $wgGroupPermissions['*']['createaccount'] to true in LocalSettings, it will override the request login and allow users to sign up without confirmation.
  • Do not set/create MediaWiki:Requestaccount-areas/xx where xx is a language code, the first part of each line is used as the keys to store in the DB for the items account requesters check.
  • Older versions of MediaWiki may not show the link to Special:RequestAccount at the user login form. You can edit MediaWiki:loginprompt to remedy this.
  • If your email client loses its mail data before sending it out, users will not get their passwords but may have an account. Since no one knows the passwords, you may want to use Extension:Password Reset or Special:ResetPassword to send them new ones.
  • If only a few people view the confirm accounts page, the randomly triggered pruning of old requests will not trigger often, so old rejected requests may persist. This prevents email addresses from re-requesting accounts for an unknown time period. You can override this behavior, and allow immediate re-requests, by forcing prune right before any new Request is submitted. Instructions here.
  • Integration with LDAP Authentication extension
  • For MW 1.26, this extension is partially incompatible with the ConfirmEdit extension - it only works for logged on users (obviously, this is not necessary), but for anonymous users it displays an empty screen, but works fine when ConfirmEdit is not used.

Troubleshooting

Notification emails do not get sent

If you are testing, note that a user must first confirm their email address through the link emailed to them, and then the email will be sent to the bureaucrat to confirm the account.

Make sure that setting(s) related to extension are introduced after the require_once line. Not before, otherwise extension doesn't see these settings and they fail silently. e.g.

require_once "$IP/extensions/ConfirmAccount/ConfirmAccount.php";
$wgConfirmAccountContact = "admin@example.com";

Also note that when using the 'confirmaccount-notify' setting, that each user in the group (e.g. sysop) will not receive notices unless their E-Mail-Optionen in Special:Preferences allow "Anderen Benutzern erlauben, E-Mails an mich zu senden." and that they have confirmed their email address within the same form.

Siehe auch

References