mirror of
https://github.com/flarum/framework.git
synced 2025-03-10 04:05:30 +08:00
85 lines
2.6 KiB
PHP
85 lines
2.6 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Flarum.
|
|
*
|
|
* For detailed copyright and license information, please view the
|
|
* LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Flarum\Extend;
|
|
|
|
use Flarum\Extension\Extension;
|
|
use Flarum\User\User as FlarumUser;
|
|
use Illuminate\Contracts\Container\Container;
|
|
|
|
class User implements ExtenderInterface
|
|
{
|
|
private $displayNameDrivers = [];
|
|
private $groupProcessors = [];
|
|
private $preferences = [];
|
|
|
|
/**
|
|
* Add a display name driver.
|
|
*
|
|
* @param string $identifier Identifier for display name driver. E.g. 'username' for UserNameDriver
|
|
* @param string $driver ::class attribute of driver class, which must implement Flarum\User\DisplayName\DriverInterface
|
|
*/
|
|
public function displayNameDriver(string $identifier, $driver)
|
|
{
|
|
$this->displayNameDrivers[$identifier] = $driver;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Dynamically process a user's list of groups when calculating permissions.
|
|
* This can be used to give a user permissions for groups they aren't actually in, based on context.
|
|
* It will not change the group badges displayed for the user.
|
|
*
|
|
* @param callable|string $callback
|
|
*
|
|
* The callable can be a closure or invokable class, and should accept:
|
|
* - \Flarum\User\User $user: the user in question.
|
|
* - array $groupIds: an array of ids for the groups the user belongs to.
|
|
*
|
|
* The callable should return:
|
|
* - array $groupIds: an array of ids for the groups the user belongs to.
|
|
*/
|
|
public function permissionGroups($callback)
|
|
{
|
|
$this->groupProcessors[] = $callback;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Register a new user preference.
|
|
*
|
|
* @param string $key
|
|
* @param callable $transformer
|
|
* @param $default
|
|
*/
|
|
public function registerPreference(string $key, callable $transformer = null, $default = null)
|
|
{
|
|
$this->preferences[$key] = compact('transformer', 'default');
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function extend(Container $container, Extension $extension = null)
|
|
{
|
|
$container->extend('flarum.user.display_name.supported_drivers', function ($existingDrivers) {
|
|
return array_merge($existingDrivers, $this->displayNameDrivers);
|
|
});
|
|
|
|
$container->extend('flarum.user.group_processors', function ($existingRelations) {
|
|
return array_merge($existingRelations, $this->groupProcessors);
|
|
});
|
|
|
|
foreach ($this->preferences as $key => $preference) {
|
|
FlarumUser::registerPreference($key, $preference['transformer'], $preference['default']);
|
|
}
|
|
}
|
|
}
|