mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-03 22:30:31 +03:00
48 lines
1.5 KiB
PHP
48 lines
1.5 KiB
PHP
<?php
|
|
namespace frontend\controllers;
|
|
|
|
use yii\rest\ActiveController;
|
|
use yii\filters\AccessControl;
|
|
use yii\filters\auth\QueryParamAuth;
|
|
use yii;
|
|
use common\models\User;
|
|
|
|
class MinecraftController extends ActiveController
|
|
{
|
|
public function init()
|
|
{
|
|
Yii::$app->user->enableSession=false;
|
|
}
|
|
public $modelClass = 'common\models\User';
|
|
public function behaviors()
|
|
{
|
|
return [
|
|
'authenticator' => [
|
|
'class' => QueryParamAuth::className(),
|
|
],
|
|
];
|
|
}
|
|
|
|
public function actionLogin()
|
|
{
|
|
$this->checkAccess("login");
|
|
\Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
|
|
$postarr = json_decode(Yii::$app->getRequest()->getRawBody(), true);
|
|
if(!$postarr) return array('status' => 'ERROR','error' => "request incorrect");
|
|
$login = $postarr["login"];
|
|
$pass = $postarr["pass"];
|
|
$model = User::findByUsername($login);
|
|
if($model->validatePassword($pass))
|
|
{
|
|
if($model->status == User::STATUS_BANNED) return array('status' => 'ERROR','error' => "You Banned");
|
|
return array('status' => 'OK', "username" => $login);
|
|
}
|
|
else
|
|
return array('status' => 'ERROR','error' => "username or password incorrect");
|
|
}
|
|
public function checkAccess($action, $model = null, $params = [])
|
|
{
|
|
if (!\Yii::$app->user->can('checkuser'))
|
|
throw new \yii\web\ForbiddenHttpException('You can only MinecraftBot');
|
|
}
|
|
}
|