self::STATUS_ACTIVE,
],
[
'status',
'in',
'range' => [
self::STATUS_ACTIVE,
self::STATUS_DELETED,
],
],
[
[
'username',
'lastname',
'firstname',
'middlename',
],
'string',
'max' => 255,
],
[
[
'specializationInput',
'paymentInput',
'type'
],
'safe',
],
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'firstname' => Yii::t('app', 'Имя'),
'lastname' => Yii::t('app', 'Фамилия'),
'email' => Yii::t('app', 'Email'),
];
}
/**
* @inheritdoc
*/
public static function findIdentity($id)
{
if(Yii::$app->getSession()
->has('user-' . $id)
) {
if(Yii::$app->getSession()
->has('user-' . $id)
) {
return new self(Yii::$app->getSession()
->get('user-' . $id));
} else {
return isset( self::$users[ $id ] ) ? new self(self::$users[ $id ]) : NULL;
}
} else {
return static::findOne([
'id' => $id,
'status' => self::STATUS_ACTIVE,
]);
}
}
/**
* @param \nodge\eauth\ServiceBase $service
*
* @return User
* @throws ErrorException
*/
public static function findByEAuth($service)
{
if(!$service->getIsAuthenticated()) {
throw new ErrorException('EAuth user should be authenticated before creating identity.');
}
$id = $service->getServiceName() . '-' . $service->getId();
$attributes = [
'id' => $id,
'username' => $service->getAttribute('name'),
'authKey' => md5($id),
'profile' => $service->getAttributes(),
];
$attributes[ 'profile' ][ 'service' ] = $service->getServiceName();
Yii::$app->getSession()
->set('user-' . $id, $attributes);
return new self($attributes);
}
public $authKey;
/**
* @inheritdoc
*/
public static function findIdentityByAccessToken($token, $type = NULL)
{
throw new NotSupportedException('"findIdentityByAccessToken" is not implemented.');
}
/**
* Finds user by username
*
* @param string $username
*
* @return static|null
*/
public static function findByUsername($username)
{
return static::findOne([
'username' => $username,
'status' => self::STATUS_ACTIVE,
]);
}
/**
* Finds user by password reset token
*
* @param string $token password reset token
*
* @return static|null
*/
public static function findByPasswordResetToken($token)
{
if(!static::isPasswordResetTokenValid($token)) {
return NULL;
}
return static::findOne([
'password_reset_token' => $token,
'status' => self::STATUS_ACTIVE,
]);
}
/**
* Finds out if password reset token is valid
*
* @param string $token password reset token
*
* @return boolean
*/
public static function isPasswordResetTokenValid($token)
{
if(empty( $token )) {
return false;
}
$timestamp = (int) substr($token, strrpos($token, '_') + 1);
$expire = Yii::$app->params[ 'user.passwordResetTokenExpire' ];
return $timestamp + $expire >= time();
}
/**
* @inheritdoc
*/
public function getId()
{
return $this->getPrimaryKey();
}
/**
* @inheritdoc
*/
public function getAuthKey()
{
return $this->auth_key;
}
/**
* @inheritdoc
*/
public function validateAuthKey($authKey)
{
return $this->getAuthKey() === $authKey;
}
/**
* 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_hash);
}
/**
* Generates password hash from password and sets it to the model
*
* @param string $password
*/
public function setPassword($password)
{
$this->password_hash = Yii::$app->security->generatePasswordHash($password);
}
/**
* Generates "remember me" authentication key
*/
public function generateAuthKey()
{
$this->auth_key = Yii::$app->security->generateRandomString();
}
/**
* Generates new password reset token
*/
public function generatePasswordResetToken()
{
$this->password_reset_token = Yii::$app->security->generateRandomString() . '_' . time();
}
/**
* Removes password reset token
*/
public function removePasswordResetToken()
{
$this->password_reset_token = NULL;
}
/**
* Returns name of the User
* @return string
*/
public function getUserName()
{
return $this->username;
}
/**
* Return array of all User's roles
* @return array
*/
public function getRoles()
{
$auth = \Yii::$app->authManager;
$roles = $this->getRoleChildrenRecursive($auth->getRolesByUser($this->id), $auth);
return $roles;
}
/**
* @param Role[] $roles User roles returned by
* [ManagerInterface]->[getRolesByUser($id)]
* @param ManagerInterface $auth Auth manager
* @param array $result
*
* @return array
*/
protected function getRoleChildrenRecursive($roles, $auth, $result = [ ])
{
if(is_array($roles) && !empty( $roles )) {
foreach($roles as $role => $item) {
if(!( $item instanceof \yii\rbac\Role )) {
continue;
}
$result[] = $role;
$result = self::getRoleChildrenRecursive($auth->getChildren($role), $auth, $result);
}
return $result;
} else {
return $result;
}
}
/**
* Return UserInfo for this User
* @return \yii\db\ActiveQuery
*/
public function getUserInfo()
{
return $this->hasOne(UserInfo::className(), [ 'user_id' => 'id' ])->inverseOf('user');
}
/**
* Check if User is Performer
* currently in development mode
* @return bool
*/
public function getIsPerformer()
{
return true;
}
/**
* Return CompanyInfo for this User
* @return \yii\db\ActiveQuery
*/
public function getCompanyInfo()
{
return $this->hasOne(CompanyInfo::className(), [ 'user_id' => 'id' ]);
}
/**
* Return array of User's phones
* @return array
*/
public function getPhones()
{
return Fields::getData($this->id, self::className(), 'phone');
}
/**
* Return array of User's site
* @return array
*/
public function getSite()
{
return Fields::getData($this->id, self::className(), 'site');
}
/**
* Return full address of User in view like:
* {country}, {city}, {street}, {house}
* @return string
*/
public function getAddress()
{
return $this->userInfo->country . ', ' . $this->userInfo->city . ', ' . $this->companyInfo->street . ', ' . $this->companyInfo->house;
}
/**
* Return relative interval of time from User registration date until now.
* @return string
*/
public function getLiveTime()
{
$now = new \DateTime('now');
$date1 = new \DateTime(date('Y-m-d H:i:s', $this->created_at));
$result = explode(',', \Yii::$app->formatter->asDuration($date1->diff($now)));
if($result >= 4){
array_splice($result, 2);
}
return implode(',',$result);
}
/**
* Check if User is Customer
* currently in development
* @return bool
*/
public function getIsCustomer()
{
return true;
}
/**
* Return array of payments types accepted by the user.
* @return ActiveQuery
*/
public function getPayments()
{
return $this->hasMany(Payment::className(), [ 'payment_id' => 'payment_id' ])
->viaTable('user_payment', [ 'user_id' => 'id' ]);
}
/**
* Return array of Payment IDs, accepted by the user.
* @return integer[]
*/
public function getPaymentInput()
{
return $this->getPayments()
->asArray()
->column();
}
/**
* Setter which allow to set User's payment ID's for further saving to the DB.
*
* @param integer[] $value
*/
public function setPaymentInput($value)
{
$this->paymentInput = $value;
}
/**
* Return array of Specializations in which the User works.
* @return ActiveQuery
*/
public function getSpecializations()
{
return $this->hasMany(Specialization::className(), [ 'specialization_id' => 'specialization_id' ])
->viaTable('user_specialization', [ 'user_id' => 'id' ]);
}
/**
* Return array of User's blogs
* @return ActiveQuery
*/
public function getBlog()
{
return $this->hasMany(Blog::className(), [ 'user_id' => 'id' ]);
}
/**
* Return array of User's jobs.
* @return ActiveQuery
*/
public function getJobs()
{
return $this->hasMany(Job::className(), [ 'user_id' => 'id' ]);
}
/**
* Return ActiveRecord of current User's place of work.
* @return ActiveQuery
*/
public function getCurrentJob()
{
return $this->hasOne(Job::className(), [ 'user_id' => 'id' ])
->where([ 'current' => 1 ]);
}
/**
* Return array of User's specialization IDs
* @return integer[]
*/
public function getSpecializationInput()
{
return $this->getSpecializations()
->asArray()
->indexBy('specialization_id')
->column();
}
/**
* Setter which allow to set User's specializations for further saving to the DB.
*
* @param integer[] $value
*/
public function setSpecializationInput($value)
{
$this->specializationInput = $value;
}
/**
* Return array of User's portfolios.
* @return ActiveQuery
*/
public function getPortfolios()
{
return $this->hasMany(Portfolio::className(), [ 'user_id' => 'id' ]);
}
/**
* Return array of User's projects.
* @return ActiveQuery
*/
public function getProjects()
{
return $this->hasMany(Project::className(), [ 'user_id' => 'id' ]);
}
/**
* Return array of company's Team members.
* @return ActiveQuery
*/
public function getTeams()
{
return $this->hasMany(Team::className(), [ 'user_id' => 'id' ]);
}
/**
* Return array of company's Vacancies.
* @return ActiveQuery
*/
public function getVacancies()
{
return $this->hasMany(Vacancy::className(), [ 'user_id' => 'id' ])->inverseOf('user');
}
public function getGalleries()
{
return $this->hasMany(Gallery::className(), [ 'user_id' => 'id' ]);
}
public function getOwner()
{
if($this->type == 1){
return $this->hasOne(UserInfo::className(), [ 'user_id' => 'id' ]);
} else if($this->type == 2) {
return $this->hasOne(CompanyInfo::className(), [ 'user_id' => 'id' ]);
}
}
public function getName(){
return $this->firstname. ' '.$this->lastname;
}
}