0

我已经设法创建 jwtauth 以将我的移动应用程序连接到 octobercms 后端,但last_login 字段始终为空,我相信这不是默认设置的。这是我拥有的经过身份验证的功能

use Tymon\JWTAuth\JWTAuth;

public function __construct(JWTAuth $auth)
{
    $this->auth = $auth;
}

public function authenticate(Request $request)
{
    try {
        if (! $token = $this->auth->attempt($request->only('email', 'password'))) {
            return response()->json([
                'errors' => [
                    'root' => 'Could not sign you in with those details.',
                ],
            ], 401);
        }
    } catch (JWTException $e) {
        return response()->json([
            'errors' => [
                'root' => 'Failed.',
            ],
        ], $e->getStatusCode());
    }

    return response()->json([
        'data' => $request->user(),
        'meta' => [
            'token' => $token,
        ],
    ]);
} 

它是由 jwtauth 文件夹中的 route.php 调用的

Route::group(['prefix' => 'api'], function () {
Route::post('auth/login','Autumn\JWTAuth\Http\Controllers\AuthController@authenticate');
Route::post('auth/register', 'Autumn\JWTAuth\Http\Controllers\AuthController@register');
Route::post('auth/logout', 'Autumn\JWTAuth\Http\Controllers\AuthController@logout');    

Route::group(['middleware' => 'jwt.auth'], function () {
    Route::get('auth/me', 'Autumn\JWTAuth\Http\Controllers\AuthController@user');        
});    

我们如何设置用户 last_login 时间戳?我希望我的问题很清楚。

添加了plugin.php,我按照@HardikSatasiya 的要求扩展了用户插件,因为我在执行他的建议时遇到了异常

use System\Classes\PluginBase;
use Rainlab\User\Controllers\Users as UsersController;
use Rainlab\User\Models\User as UserModels;
use Event;

class Plugin extends PluginBase
{
  public function registerComponents()
  {
  }

  public function registerSettings()
  {
  }

  public function boot()
  {
    UserModels::extend(function($model){

        $model->bindEvent('model.beforeSave',function() use ($model) {

            $users = \BackendAuth::getUser();               
            $model->backend_users_id = $users->id;              
            //above line result exception when calling method as @HardikSatasiya suggested          
            if(!empty($model->avatar)){
                $model->image_path = $model->avatar->getPath();
            }
            if(!empty($model->groups)){
                $model->membership = $model->groups[0]['name'];
            }
        });

        $model->addJsonable('users_detail','membership');
    }); 



    UsersController::extendFormFields(function($form,$model,$context){

        $form->addTabFields([
            'users_detail[0][gender]' => [
                'label' => 'Jenis Kelamin',
                'span' => 'left',
                'tab' => 'User Profile',
                'type' => 'radio',
                'options' => [
                    'Pria' => 'Pria',
                    'Wanita' => 'Wanita'
                ] 
            ],
            'users_detail[0][ttl]' => [
                'label' => 'Tempat/Tanggal Lahir',
                'type' => 'text',
                'span' => 'left',
                'tab' => 'User Profile'
            ],           
        ]);  
    });
  }

我通过这个单独的插件向用户表添加了额外的字段..

4

1 回答 1

1

好的,可能是因为这个插件在外部登录用户时没有调用内部钩子。

可能是我们需要手动调用,这个代码片段可以做到,code登录成功后就放给定。

// this will fire hooks and update `last_login`
// get authenticated user from the jwt authmanager
$user = $this->auth->authenticate($token);
$user->afterLogin();

在下面的代码中添加。

public function authenticate(Request $request)
{
    try {
        if (! $token = $this->auth->attempt($request->only('email', 'password'))) {
            return response()->json([
                'errors' => [
                    'root' => 'Could not sign you in with those details.',
                ],
            ], 401);
        }
    } catch (JWTException $e) {
        return response()->json([
            'errors' => [
                'root' => 'Failed.',
            ],
        ], $e->getStatusCode());
    }

    // this will fire hooks and update `last_login`
    // get authenticated user from the jwt authmanager
    $user = $this->auth->authenticate($token);
    $user->afterLogin();
    // ^ this code

    return response()->json([
        'data' => $request->user(),
        'meta' => [
            'token' => $token,
        ],
    ]);
}

此代码段将按last_login预期更新。我没有测试它,但它会正常工作。

如果有任何疑问或问题,请发表评论。

于 2018-10-06T09:07:13.717 回答