mirror of
https://github.com/flarum/core.git
synced 2025-10-19 10:46:06 +02:00
Very rough implementation of forgot password
This commit is contained in:
@@ -3,6 +3,8 @@
|
||||
use Closure;
|
||||
use Flarum\Api\Request;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\Response;
|
||||
use Illuminate\Database\Eloquent\ModelNotFoundException;
|
||||
use Flarum\Core\Exceptions\ValidationFailureException;
|
||||
use Flarum\Core\Exceptions\PermissionDeniedException;
|
||||
|
||||
@@ -29,7 +31,9 @@ abstract class JsonApiAction implements ActionInterface
|
||||
}
|
||||
return new JsonResponse(['errors' => $errors], 422);
|
||||
} catch (PermissionDeniedException $e) {
|
||||
return new JsonResponse(null, 401);
|
||||
return new Response(null, 401);
|
||||
} catch (ModelNotFoundException $e) {
|
||||
return new Response(null, 404);
|
||||
}
|
||||
}
|
||||
|
||||
|
38
src/Api/Actions/Users/ForgotAction.php
Normal file
38
src/Api/Actions/Users/ForgotAction.php
Normal file
@@ -0,0 +1,38 @@
|
||||
<?php namespace Flarum\Api\Actions\Users;
|
||||
|
||||
use Flarum\Api\Request;
|
||||
use Flarum\Api\Actions\JsonApiAction;
|
||||
use Flarum\Core\Repositories\UserRepositoryInterface;
|
||||
use Flarum\Core\Commands\RequestPasswordResetCommand;
|
||||
use Illuminate\Http\Response;
|
||||
use Illuminate\Contracts\Bus\Dispatcher;
|
||||
|
||||
class ForgotAction extends JsonApiAction
|
||||
{
|
||||
protected $users;
|
||||
|
||||
protected $bus;
|
||||
|
||||
public function __construct(UserRepositoryInterface $users, Dispatcher $bus)
|
||||
{
|
||||
$this->users = $users;
|
||||
$this->bus = $bus;
|
||||
}
|
||||
|
||||
/**
|
||||
* Log in and return a token.
|
||||
*
|
||||
* @param \Flarum\Api\Request $request
|
||||
* @return \Flarum\Api\Response
|
||||
*/
|
||||
public function respond(Request $request)
|
||||
{
|
||||
$email = $request->get('email');
|
||||
|
||||
$this->bus->dispatch(
|
||||
new RequestPasswordResetCommand($email)
|
||||
);
|
||||
|
||||
return new Response;
|
||||
}
|
||||
}
|
@@ -37,6 +37,12 @@ Route::group(['prefix' => 'api', 'middleware' => 'Flarum\Api\Middleware\LoginWit
|
||||
'uses' => $action('Flarum\Api\Actions\TokenAction')
|
||||
]);
|
||||
|
||||
// Send forgot password email
|
||||
Route::post('forgot', [
|
||||
'as' => 'flarum.api.forgot',
|
||||
'uses' => $action('Flarum\Api\Actions\Users\ForgotAction')
|
||||
]);
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Users
|
||||
@@ -73,11 +79,13 @@ Route::group(['prefix' => 'api', 'middleware' => 'Flarum\Api\Middleware\LoginWit
|
||||
'uses' => $action('Flarum\Api\Actions\Users\DeleteAction')
|
||||
]);
|
||||
|
||||
// Upload avatar
|
||||
Route::post('users/{id}/avatar', [
|
||||
'as' => 'flarum.api.users.avatar.upload',
|
||||
'uses' => $action('Flarum\Api\Actions\Users\UploadAvatarAction')
|
||||
]);
|
||||
|
||||
// Remove avatar
|
||||
Route::delete('users/{id}/avatar', [
|
||||
'as' => 'flarum.api.users.avatar.delete',
|
||||
'uses' => $action('Flarum\Api\Actions\Users\DeleteAvatarAction')
|
||||
|
Reference in New Issue
Block a user