www.gusucode.com > Flarum PHP论坛 中文版 v0.1 beta7源码程序 > FlarumChina-master/vendor/flarum/core/src/Api/Controller/UpdateUserController.php
<?php /* * This file is part of Flarum. * * (c) Toby Zerner <toby.zerner@gmail.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Flarum\Api\Controller; use Flarum\Core\Command\EditUser; use Flarum\Core\Exception\PermissionDeniedException; use Illuminate\Contracts\Bus\Dispatcher; use Psr\Http\Message\ServerRequestInterface; use Tobscure\JsonApi\Document; class UpdateUserController extends AbstractResourceController { /** * {@inheritdoc} */ public $serializer = 'Flarum\Api\Serializer\CurrentUserSerializer'; /** * {@inheritdoc} */ public $include = ['groups']; /** * @var Dispatcher */ protected $bus; /** * @param Dispatcher $bus */ public function __construct(Dispatcher $bus) { $this->bus = $bus; } /** * {@inheritdoc} */ protected function data(ServerRequestInterface $request, Document $document) { $id = array_get($request->getQueryParams(), 'id'); $actor = $request->getAttribute('actor'); $data = array_get($request->getParsedBody(), 'data', []); // Require the user's current password if they are attempting to change // their own email address. if (isset($data['attributes']['email']) && $actor->id == $id) { $password = array_get($request->getParsedBody(), 'meta.password'); if (! $actor->checkPassword($password)) { throw new PermissionDeniedException; } } return $this->bus->dispatch( new EditUser($id, $actor, $data) ); } }