343 lines
10 KiB
PHP
343 lines
10 KiB
PHP
<?php
|
|
namespace common\models;
|
|
|
|
use common\components\Helper;
|
|
use Yii;
|
|
use yii\base\Exception;
|
|
use yii\base\InvalidConfigException;
|
|
use yii\base\NotSupportedException;
|
|
use yii\web\IdentityInterface;
|
|
|
|
/**
|
|
* This is the model class for table "customer".
|
|
*
|
|
* @property integer $id_customer
|
|
* @property integer $id_customer_card
|
|
* @property integer $id_user
|
|
* @property integer $id_partner_card
|
|
* @property integer $id_proposer
|
|
* @property integer $id_image
|
|
* @property string $name
|
|
* @property string $email
|
|
* @property string $password
|
|
* @property string $phone
|
|
* @property integer $sex
|
|
* @property string $date_stundent_card_expire
|
|
* @property string $birthdate
|
|
* @property string $image
|
|
* @property string $description
|
|
* @property string $tax_number
|
|
* @property string $country
|
|
* @property string $zip
|
|
* @property string $city
|
|
* @property string $address
|
|
* @property string $created_at
|
|
* @property string $updated_at
|
|
* @property \common\models\Card card
|
|
* @property integer status
|
|
* @property integer towel_count
|
|
* @property \common\models\User user
|
|
* @property mixed bank_account
|
|
* @property string password_plain
|
|
* @property string password_hash
|
|
* @property string auth_key
|
|
*/
|
|
class Customer extends BaseFitnessActiveRecord implements IdentityInterface
|
|
{
|
|
|
|
const STATUS_DELETED = 0;
|
|
const STATUS_ACTIVE = 10;
|
|
|
|
const SEX_UNKNOWN = 0;
|
|
const SEX_MAN = 10;
|
|
const SEX_WOMAN = 20;
|
|
|
|
|
|
public static $ENABLED = 1;
|
|
|
|
public $photo_data;
|
|
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static function tableName()
|
|
{
|
|
return 'customer';
|
|
}
|
|
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function rules()
|
|
{
|
|
return [
|
|
[['id_customer_card', 'id_user', 'id_partner_card', 'id_proposer', 'sex'], 'integer'],
|
|
[['date_stundent_card_expire', 'birthdate', 'created_at', 'updated_at'], 'safe'],
|
|
[['name'], 'string', 'max' => 128],
|
|
[['email', 'image', 'description', 'address'], 'string', 'max' => 255],
|
|
[['password'], 'string', 'max' => 32],
|
|
[['phone', 'tax_number', 'country'], 'string', 'max' => 20],
|
|
[['zip'], 'string', 'max' => 8],
|
|
[['city'], 'string', 'max' => 30]
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function attributeLabels()
|
|
{
|
|
return [
|
|
'id_customer' => Yii::t('common/customer', 'Id Customer'),
|
|
'id_customer_card' => Yii::t('common/customer', 'Id Customer Card'),
|
|
'id_user' => Yii::t('common/customer', 'Id User'),
|
|
'id_partner_card' => Yii::t('common/customer', 'Id Partner Card'),
|
|
'id_proposer' => Yii::t('common/customer', 'Id Proposer'),
|
|
'name' => Yii::t('common/customer', 'Name'),
|
|
'email' => Yii::t('common/customer', 'Email'),
|
|
'password' => Yii::t('common/customer', 'Password'),
|
|
'phone' => Yii::t('common/customer', 'Phone'),
|
|
'sex' => Yii::t('common/customer', 'Sex'),
|
|
'date_stundent_card_expire' => Yii::t('common/customer', 'Date Stundent Card Expire'),
|
|
'birthdate' => Yii::t('common/customer', 'Birthdate'),
|
|
'image' => Yii::t('common/customer', 'Image'),
|
|
'description' => Yii::t('common/customer', 'Description'),
|
|
'tax_number' => Yii::t('common/customer', 'Tax Number'),
|
|
'country' => Yii::t('common/customer', 'Country'),
|
|
'zip' => Yii::t('common/customer', 'Zip'),
|
|
'city' => Yii::t('common/customer', 'City'),
|
|
'address' => Yii::t('common/customer', 'Address'),
|
|
'created_at' => Yii::t('common/customer', 'Created At'),
|
|
'updated_at' => Yii::t('common/customer', 'Updated At'),
|
|
'customerCardNumber' => Yii::t('common/customer', 'Card number'),
|
|
'cardNumber' => Yii::t('common/customer', 'Card number'),
|
|
'mother_name' => Yii::t('common/customer', 'Anyja neve'),
|
|
'birth_place' => Yii::t('common/customer', 'Születési hely'),
|
|
];
|
|
}
|
|
|
|
|
|
|
|
static function statuses() {
|
|
return [
|
|
self::STATUS_ACTIVE => Yii::t('common/account', 'Active'),
|
|
self::STATUS_DELETED => Yii::t('common/account', 'Inactive'),
|
|
];
|
|
}
|
|
|
|
public function getStatusHuman(){
|
|
$result = null;
|
|
$s = self::statuses( );
|
|
if ( array_key_exists($this->status, $s)){
|
|
$result = $s[$this->status];
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
static function sexes() {
|
|
return [
|
|
self::SEX_UNKNOWN => Yii::t('common/customer', 'Unknown sex'),
|
|
self::SEX_MAN => Yii::t('common/customer', 'Man'),
|
|
self::SEX_WOMAN => Yii::t('common/customer', 'Woman'),
|
|
];
|
|
}
|
|
|
|
public function getSexHuman(){
|
|
$result = null;
|
|
$s = self::sexes( );
|
|
if ( array_key_exists($this->sex, $s)){
|
|
$result = $s[$this->sex];
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function isInactive(){
|
|
return $this->status == self::STATUS_DELETED;
|
|
}
|
|
|
|
|
|
public function getCard(){
|
|
return $this->hasOne ( Card::className (), [
|
|
'id_card' => 'id_customer_card'
|
|
] );
|
|
}
|
|
public function getUser(){
|
|
return $this->hasOne ( User::className (), [
|
|
'id' => 'id_user'
|
|
] );
|
|
}
|
|
public function getImage1(){
|
|
return $this->hasOne ( Image::className (), [
|
|
'id_image' => 'id_image'
|
|
] );
|
|
}
|
|
|
|
public function getCustomerCardNumber(){
|
|
$result = null;
|
|
$card = $this->card;
|
|
if ( $card != null) {
|
|
$result = $card->number;
|
|
}
|
|
return $result;
|
|
}
|
|
public function getUsername(){
|
|
$result = null;
|
|
$user = $this->user;
|
|
if ( $user != null) {
|
|
$result = $user->username;
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function getFullAddress(){
|
|
$zip = $this->zip;
|
|
$city = $this->city;
|
|
$address = $this->address;
|
|
|
|
$result = $zip . " " .$city . ", ". $address;
|
|
return $result;
|
|
|
|
}
|
|
|
|
public function afterSave($insert, $changedAttributes){
|
|
if ( !$insert ){
|
|
Card::updateCardFlagTicket($this->id_customer_card);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Finds an identity by the given ID.
|
|
* @param string|integer $id the ID to be looked for
|
|
* @return Customer
|
|
* 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)
|
|
{
|
|
return self::findOne(['email' => $id]);
|
|
}
|
|
|
|
/**
|
|
* 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 void 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.)
|
|
* @throws NotSupportedException
|
|
*/
|
|
public static function findIdentityByAccessToken($token, $type = null)
|
|
{
|
|
throw new NotSupportedException('"findIdentityByAccessToken" is not implemented.');
|
|
}
|
|
|
|
/**
|
|
* Returns an ID that can uniquely identify a user identity.
|
|
* @return string|integer an ID that uniquely identifies a user identity.
|
|
*/
|
|
public function getId()
|
|
{
|
|
return $this->id_customer;
|
|
}
|
|
|
|
/**
|
|
* 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()
|
|
{
|
|
// todo: add authkey to customer
|
|
}
|
|
|
|
/**
|
|
* Validates the given auth key.
|
|
*
|
|
* This is required if [[User::enableAutoLogin]] is enabled.
|
|
* @param string $authKey the given auth key
|
|
* @return boolean whether the given auth key is valid.
|
|
* @see getAuthKey()
|
|
*/
|
|
public function validateAuthKey($authKey)
|
|
{
|
|
return $this->getAuthKey() === $authKey;
|
|
}
|
|
|
|
/**
|
|
* @param $password
|
|
* @return bool
|
|
* @throws \yii\base\InvalidConfigException
|
|
*/
|
|
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
|
|
* @throws Exception
|
|
* @throws \yii\base\InvalidConfigException
|
|
*/
|
|
public function setPassword($password)
|
|
{
|
|
$this->password_hash = Yii::$app->security->generatePasswordHash($password);
|
|
// \Yii::info("pwd", $this->password_hash);
|
|
// echo $this->password_hash;
|
|
}
|
|
|
|
/**
|
|
* Generates "remember me" authentication key
|
|
* @throws InvalidConfigException if OpenSSL extension is needed but not installed.*@throws \yii\base\Exception
|
|
* @throws Exception
|
|
*/
|
|
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;
|
|
}
|
|
|
|
|
|
/**
|
|
* @throws InvalidConfigException
|
|
* @throws Exception
|
|
*/
|
|
public function setDefaultPassword(){
|
|
$hasEmail = isset($this->email) && $this->email !== '';
|
|
$hasBirthday = isset($this->birthdate) ;
|
|
if ( $hasEmail && $hasBirthday){
|
|
$customerBirthDate = new \DateTime($this->birthdate);
|
|
$this->setPassword($customerBirthDate->format('Ymd'));
|
|
}
|
|
}
|
|
|
|
}
|