registration fix

This commit is contained in:
Kavalar 2024-02-05 23:58:48 +03:00
parent 5cfd591140
commit eb1abd41e5
13 changed files with 83 additions and 10 deletions

View File

@ -138,6 +138,7 @@ class UserCardController extends Controller
public function actionCreate() public function actionCreate()
{ {
$model = new UserCard(); $model = new UserCard();
$model->scenario = UserCard::SCENARIO_CREATE_FROM_ADMIN;
if ($model->load(Yii::$app->request->post()) && $model->save()) { if ($model->load(Yii::$app->request->post()) && $model->save()) {
UserCard::generateUserForUserCard($model->id); UserCard::generateUserForUserCard($model->id);

View File

@ -39,7 +39,7 @@ return [
'marginBottom' => 5, // Margin bottom pixel 'marginBottom' => 5, // Margin bottom pixel
'quality' => 95, // JPEG image save quality 'quality' => 95, // JPEG image save quality
'transparency' => 70, // Water mark image transparency ( other than PNG ) 'transparency' => 70, // Water mark image transparency ( other than PNG )
'targetType' => IMG_GIF | IMG_JPG | IMG_PNG | IMG_WBMP, // Target image formats ( bit-field ) //'targetType' => IMG_GIF | IMG_JPG | IMG_PNG | IMG_WBMP, // Target image formats ( bit-field )
'targetMinPixel' => 200 // Target image minimum pixel size 'targetMinPixel' => 200 // Target image minimum pixel size
] ]
] ]

View File

@ -4,7 +4,7 @@
/* @var $user common\models\User */ /* @var $user common\models\User */
?> ?>
Hello <?= $user->username ?>, <p>Здравствуйте, <b><?= $user->username ?></b></p> ,
You have successfully registered! Благодорим за регистрацию.

View File

@ -4,7 +4,7 @@
/* @var $user common\models\User */ /* @var $user common\models\User */
?> ?>
Hello <?= $user->username ?>, Здравствуйте, <?= $user->username ?>,
You have successfully registered! Благодорим за регистрацию.

View File

@ -34,7 +34,7 @@ class Manager extends \yii\db\ActiveRecord
[['user_id'], 'integer'], [['user_id'], 'integer'],
[['user_id'], 'required'], [['user_id'], 'required'],
['user_id', 'unique', 'message' => 'Уже является менеджером'], ['user_id', 'unique', 'message' => 'Уже является менеджером'],
[['user_id'], 'exist', 'skipOnError' => true, 'targetClass' => UserCard::className(), 'targetAttribute' => ['user_id' => 'id']], [['user_id'], 'exist', 'skipOnError' => true, 'targetClass' => User::class, 'targetAttribute' => ['user_id' => 'id']],
]; ];
} }

View File

@ -72,4 +72,9 @@ class Status extends \yii\db\ActiveRecord
{ {
return $this->hasMany(UserCard::class, ['status' => 'id']); return $this->hasMany(UserCard::class, ['status' => 'id']);
} }
public static function getByName($name)
{
return Status::find()->where(['name' => $name])->one()->id ?? false;
}
} }

View File

@ -240,8 +240,31 @@ class User extends ActiveRecord implements IdentityInterface, UserRbacInterface
return $this->hasOne(UserCard::class, ['id_user' => 'id']); return $this->hasOne(UserCard::class, ['id_user' => 'id']);
} }
public function getProjectUser() public function getProjectUser(): \yii\db\ActiveQuery
{ {
return $this->hasMany(ProjectUser::class, ['user_id' => 'id']); return $this->hasMany(ProjectUser::class, ['user_id' => 'id']);
} }
/**
* @param string $email
* @param int $status
* @return UserCard|false
*/
public static function createSimpleProfile(string $email, int $status = 18): UserCard | bool
{
$user = User::find()->where(['email' => $email])->one();
if ($user) {
$profile = new UserCard();
$profile->id_user = $user->id;
$profile->status = $status;
$profile->fio = $email;
if ($profile->save()) {
return $profile;
}
return false;
}
return false;
}
} }

View File

@ -62,6 +62,8 @@ class UserCard extends \yii\db\ActiveRecord
const SCENARIO_UPDATE_RESUME_TEXT = 'update_resume_text'; const SCENARIO_UPDATE_RESUME_TEXT = 'update_resume_text';
const SCENARIO_DOWNLOAD_RESUME = 'download_resume_text'; const SCENARIO_DOWNLOAD_RESUME = 'download_resume_text';
const SCENARIO_CREATE_FROM_ADMIN = 'create_from_admin';
const AT_PROJECT_BUSY = 1; const AT_PROJECT_BUSY = 1;
const AT_PROJECT_FREE = 0; const AT_PROJECT_FREE = 0;
@ -114,7 +116,8 @@ class UserCard extends \yii\db\ActiveRecord
public function rules() public function rules()
{ {
return [ return [
[['fio', 'status', 'gender', 'email', 'level', 'position_id'], 'required'], [['fio', 'status', ], 'required'],
[['gender', 'email', 'level', 'position_id'], 'required', 'on' => self::SCENARIO_CREATE_FROM_ADMIN],
[['gender', 'status', 'position_id', 'id_user', 'level', 'years_of_exp', 'resume_tariff', 'at_project'], 'integer'], [['gender', 'status', 'position_id', 'id_user', 'level', 'years_of_exp', 'resume_tariff', 'at_project'], 'integer'],
[['dob', 'created_at', 'updated_at', 'deleted_at', 'vc_text', 'vc_text_short', 'test_task_getting_date', 'test_task_complete_date'], 'safe'], [['dob', 'created_at', 'updated_at', 'deleted_at', 'vc_text', 'vc_text_short', 'test_task_getting_date', 'test_task_complete_date'], 'safe'],
['email', 'unique', 'message'=>'Почтовый адрес уже используется'], ['email', 'unique', 'message'=>'Почтовый адрес уже используется'],

View File

@ -13,7 +13,7 @@ class RegistrationEmail extends Email
public function __construct(User $user) public function __construct(User $user)
{ {
$this->sendTo = $user->email; $this->sendTo = $user->email;
$this->subject = 'Account registration at ' . Yii::$app->name; $this->subject = 'Регистрация в ' . Yii::$app->name;
$this->mailLayout = ['html' => 'signup-html', 'text' => 'signup-text']; $this->mailLayout = ['html' => 'signup-html', 'text' => 'signup-text'];
$this->params = ['user' => $user]; $this->params = ['user' => $user];
} }

View File

@ -14,7 +14,7 @@
}, },
"minimum-stability": "stable", "minimum-stability": "stable",
"require": { "require": {
"php": ">=7.4.0", "php": ">=8.0",
"yiisoft/yii2": "~2.0.6", "yiisoft/yii2": "~2.0.6",
"yiisoft/yii2-bootstrap": "~2.0.0", "yiisoft/yii2-bootstrap": "~2.0.0",
"yiisoft/yii2-swiftmailer": "~2.0.0 || ~2.1.0", "yiisoft/yii2-swiftmailer": "~2.0.0 || ~2.1.0",

View File

@ -5,12 +5,32 @@ namespace console\controllers;
use common\models\Reports; use common\models\Reports;
use common\models\User;
use common\models\UserCard; use common\models\UserCard;
use Yii; use Yii;
use yii\console\Controller; use yii\console\Controller;
class SqlController extends Controller class SqlController extends Controller
{ {
public $email = "";
/**
* @param $actionID
* @return string[]
*/
public function options($actionID)
{
return ['email'];
}
/**
* @return string[]
*/
public function optionAliases()
{
return ['e' => 'email'];
}
public function actionSalary() public function actionSalary()
{ {
$sql = "UPDATE user_card SET salary=REPLACE( `salary`, ' ', '' )"; $sql = "UPDATE user_card SET salary=REPLACE( `salary`, ' ', '' )";
@ -50,4 +70,14 @@ class SqlController extends Controller
echo "script completed successfully\n"; echo "script completed successfully\n";
} }
public function actionCreateProfile()
{
if ($profile = User::createSimpleProfile($this->email, 17)) {
echo "Профиль $profile->id успешно создан\n";
return;
}
echo "Пользователь $this->email не найден\n";
}
} }

View File

@ -2,6 +2,7 @@
namespace frontend\models; namespace frontend\models;
use common\classes\Debug; use common\classes\Debug;
use common\models\Status;
use Yii; use Yii;
use yii\base\Model; use yii\base\Model;
use common\models\User; use common\models\User;
@ -14,6 +15,7 @@ class SignupForm extends Model
public $username; public $username;
public $email; public $email;
public $password; public $password;
public $is_partner = 0;
/** /**
@ -35,6 +37,8 @@ class SignupForm extends Model
['password', 'required'], ['password', 'required'],
['password', 'string', 'min' => 6], ['password', 'string', 'min' => 6],
['is_partner', 'integer']
]; ];
} }
@ -60,6 +64,8 @@ class SignupForm extends Model
$authorRole = $auth->getRole('user'); $authorRole = $auth->getRole('user');
$auth->assign($authorRole, $user->id); $auth->assign($authorRole, $user->id);
User::createSimpleProfile($user->email, $this->is_partner ? Status::getByName("Партнер") : Status::getByName("Аутстафинг"));
return $user->save() ? $user : null; return $user->save() ? $user : null;
} }
} }

View File

@ -57,6 +57,11 @@ class RegisterController extends ApiController
* type="string", * type="string",
* description="Пароль пользователя", * description="Пароль пользователя",
* ), * ),
* @OA\Property(
* property="is_partner",
* type="integer",
* description="Является ли пользователь Партнером. Возможные значения 0 или 1. По умолчанию 0",
* ),
* ), * ),
* ), * ),
* ), * ),