Extension:CentralAuth/uk

CentralAuth дозволяє розділяти глобальні облікові записи між проєктами. Це розширення додає наступні нові спеціальні сторінки: Special:CentralAuth, Special:CentralLogin ( unlisted special page ), Special:CentralAutoLogin ( unlisted special page ), Special:CreateLocalAccount, Special:MergeAccount, Special:GlobalGroupMembership, Special:GlobalGroupPermissions, Special:WikiSets, Special:GlobalUsers, Special:MultiLock, Special:GlobalRenameUser, Special:GlobalRenameProgress

Рекомендується завантажувати ту версію CentralAuth, що відповідає вашій версії MediaWiki.

Встановлення
Передумови використання CentralAuth див. у розділі встановлення нижче. Тоді слідуйте цими інструкціями, коли будете готові активувати CentralAuth:


 * 1) Завантажте останній зняток і розпакуйте його у свою директорію.
 * 2) Оберіть базу даних і створіть таблиці CentralAuth. Можна використати наявну базу даних або створити нову; розширення за замовчуванням використовує базу даних на ім'я   (див. нижче ). Використайте цю базу даних, потім виконайте.
 * 3) * Якщо ви використовуєте, то вам потрібно створити глобальну таблицю  (для блокування нових імен користувачів, схожих на наявні в будь-якій вікі). Один зі способів зробити це — вивантажити таблицю   з бази даних локальної вікі й імпортувати її у нову.
 * 4) Додайте до  для кожної своєї вікі, чи в інший файл PHP, який включено до   кожної з ваших вікі.
 * 5) Тепер розширення повинно бути активним.

Тут приклад команд оболонки й SQL для створення бази даних centralauth, копіювання таблиці spoofuser і міграції наявних користувачів до неї. Замініть $wgDBname і $wgDBuser значеннями для інсталяції вашої власної вікі.

Створіть нову базу даних (пам'ятайте, що цей крок необов'язковий, можна натомість використати одну з наявних баз даних, у цьому випадку пропустіть до кроку створення таблиць):

Наступне припускає, що ваша теперішня робоча директорія є інсталяцією вашого MediaWiki (а не директорією CentralAuth). Створіть таблиці центральної авторизації (бажано з використанням . За відсутність доступу до оболонки, можна також імпортувати   через інструменти адміністрування бази даних, як-от PHPMyAdmin):

Якщо інстальований AntiSpoof, то створіть таблицю через (Альтернативно, можете скопіювати наявну таблицю AntiSpoof, якщо бажаєте зберегти попередні записи):

Виконайте сценарії міграції користувачів

Наскрізний контроль — дружніше до користувача встановлення за вищенаведені інструкції.

Встановлення
Спершу, вам потрібно сконфігурувати свою вікі-родину, використовуючи, або CentralAuth не зможе використовуватися для вашої вікі-родини. This includes setting and assigning it to, and  (minimum is ,  and ). Follow the examples carefully. Make sure that you put the configuration code after the line in. If you are creating a new wiki family, bear in mind that it may be easier if the databases for the wikis in each group have the same suffix (e.g. hypothetical databases,  ,  , etc., pertaining to wikis belonging to the same group, all have the suffix " ").

After installing the extension, you have to gather some data in the CentralAuth database. In order to retroactively set up global accounts, you will have to run the and  scripts. The first one stores information about your wikis in the CentralAuth database, while the second one uses automatic migration heuristics to generate global accounts. A user can merge their accounts manually via Special:MergeAccount. Dry runs can be used for testing purposes.

To enable global groups, you will have to make an entry into the  table in your CentralAuth database, with   and (for access to the group management interface). A sample query that is recommended to use is:. Then, run  to promote local stewards to global steward status.

There are various settings you may wish to modify (e.g. whether to provide single sign-on across a whole domain) listed in. In particular, you will want to override the default value of if your CentralAuth database is named something other than. Make sure you put such settings after the  line in , e.g.:

"SUL2" behavior
In July 2013 WMF changed its approach to logging users into multiple wikis. When configured for this new approach, after successful login and account creation CentralAuth redirects to  on a "central login wiki", which sets cookies on that wiki and then redirects back to the logged-into wiki. It omits the "login/account creation success" page, instead redirecting back to the "returnto" page that the user was originally on. It places 1x1 pixel images in the footer of that page, in place of the icons formerly used on the "login/account creation success" page.

The settings for this are, roughly,

is the id (usually the database-name) of the wiki to which CentralAuth will redirect on login and create account.

means account creation will create a new global account (this parameter was deleted from MediaWiki 1.27).

Simulating SUL2 behavior on a single-instance development machine
You can simulate this new behavior on a single-instance development machine. You can set  so CentralAuth makes its HTTP redirect requests to your same local wiki. This will not exercise central login properly, but will activate its " " behavior. CentralAuth will still use its own  database to store global user names.

To determine the URL on the login wiki, CentralAuth uses WikiMap which assumes a wiki farm has been configured using. Configuration setup (in ) is very flexible; one way to set up a dummy single-wiki  in   is:

This is in addition to the settings in #"SUL2" behavior above.

Cache issues
For best results, it is recommended to use memcached. If you have only a single server, accelerator caches like APCu can also work, but do not use them if you have multiple servers. If you have no cache set up (i.e. ) for, or are using  , then you need to make sure all your wikis use the same caching table.

By default, each wiki in your wiki farm will use the  table in its own database (with its own db prefix) when  is set to   or.

To make this work with CentralAuth, we need to tell the wikis to use a central cache table.

If you want to make a central caching table in the  database (and assuming one of your existing wikis has a database name of  ), run code like the following to copy the table to your other database:

Then add the following config to all wikis to tell them to use the central table instead of their own table:

Use
Allows for a single-user login (SUL) system using MediaWiki's AuthPlugin system. User creation and login is done globally using one central user table across all wikis. Note that local user accounts are automatically created on account creation/login however.

This extension also implements global user groups, to which global accounts can belong to.

User rights
CentralAuth defines several new user rights:

Single-user login (SUL)
A user with an account on more than one wiki may use Special:MergeAccount to create their global user account, which can then be used on any wiki. Users with the  permission (given to stewards by default) can undo a merging of a global account, where the passwords are all reset back to the pre-merge setting. User accounts can now also be renamed globally.

Locking and hiding global users
A global account can be locked or hidden by a user with the  and   permissions, respectively, given to the local group 'stewards' by default. A locked global account will be immediately logged out of any session on any wiki it is currently logged in to. A hidden global account's username is not visible in any logs except the global account log.

Wiki sets
A wiki set is a group of wikis specified by a user with the  right. Sets can be opt-in (wikis are not in it by default) or opt-out (wikis are in it unless opted out).

Global user groups
Once you have enabled global user groups as described in the installation section, a migrated steward can use the Special:GlobalGroupPermissions interface to configure global user groups, and their rights. A global user group is active on all wikis (the users in it have its rights on all the wikis) by default, unless the group has been specified to only be active on a specific wiki set (the users in the group only have the rights if they are on a wiki in the set). Global group permissions are not listed at Special:ListUsers, but instead Special:GlobalUsers. They are assigned by a user with the  permission (by default the global group  ), and give the specified rights to the user even if the local rights defined by  do not do so.

Licensing and downloads
The extension is available under the GNU General Public License 2.0 or later, and can be downloaded from Git, or accessed via the.

The software is provided as-is. Updates will be made according to the needs of Wikimedia wikis; or where critical vulnerabilities are discovered.

API
See.