64], [['password'], 'string', 'max' => 256], ]; } /** * {@inheritdoc} */ public function attributeLabels() { return [ 'id' => 'ID', 'user_id' => 'User ID', 'store_id' => 'Store ID', 'username' => 'Username', 'password' => 'Password', 'user_type' => 'User Type', 'is_delete' => 'Is Delete', 'deleted_at' => 'Deleted At', 'status' => 'Status', 'created_at' => 'Created At', 'updated_at' => 'Updated At', ]; } /** * Validates password * * @param string $password password to validate * @return boolean if password provided is valid for current user */ public function validatePassword($password) { return Yii::$app->security->validatePassword($password, $this->password); } /** * Finds an identity by the given ID. * @param string|int $id the ID to be looked for * @return IdentityInterface the identity object that matches the given ID. * Null should be returned if such an identity cannot be found * or the identity is not in an active state (disabled, deleted, etc.) */ public static function findIdentity($id) { $admin = self::findOne([ "id" => $id, "is_delete" => 0 ]); return $admin; } /** * Finds an identity by the given token. * @param mixed $token the token to be looked for * @param mixed $type the type of the token. The value of this parameter depends on the implementation. * For example, [[\yii\filters\auth\HttpBearerAuth]] will set this parameter to be `yii\filters\auth\HttpBearerAuth`. * @return IdentityInterface the identity object that matches the given token. * Null should be returned if such an identity cannot be found * or the identity is not in an active state (disabled, deleted, etc.) */ public static function findIdentityByAccessToken($token, $type = null) { $user_token = UserToken::find() ->where([ 'is_delete' => 0, 'token' => $token, ]) ->andFilterWhere([ 'type' => $type, ])->one(); if ($user_token && $user_token->expire_time > time()) { return static::findOne([ 'id' => $user_token->user_id, 'is_delete' => 0, 'status' => 0, ]); } return static::findOne([ 'id' => 0, 'is_delete' => 0, 'status' => 0, ]); } public function setPassword($password) { $user = StoreUser::findOne([ "user_id" => $this->user_id, "is_delete" => 0, "status" => User::STATUS_NORMAL ]); if ($user != null) { $user->password = Yii::$app->security->generatePasswordHash($password); } return $user->save(); } /** * Returns an ID that can uniquely identify a user identity. * @return string|int an ID that uniquely identifies a user identity. */ public function getId() { return $this->id; } /** * Returns a key that can be used to check the validity of a given identity ID. * * The key should be unique for each individual user, and should be persistent * so that it can be used to check the validity of the user identity. * * The space of such keys should be big enough to defeat potential identity attacks. * * This is required if [[User::enableAutoLogin]] is enabled. * @return string a key that is used to check the validity of a given identity ID. * @see validateAuthKey() */ public function getAuthKey() { $user = User::findOne([ "id" => $this->user_id, "is_delete" => 0, "status" => User::STATUS_NORMAL ]); if ($user != null) { return $user->auth_key; } return null; } /** * Validates the given auth key. * * This is required if [[User::enableAutoLogin]] is enabled. * @param string $authKey the given auth key * @return bool whether the given auth key is valid. * @see getAuthKey() */ public function validateAuthKey($authKey) { return $this->getAuthKey() === $authKey; } public static function lastLogin($user_id, $is_pass = 1, $err_msg = null) { return log\UserLoginLog::logger($user_id, $is_pass, $err_msg); } }