|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548 |
- <?php
-
-
-
- namespace common\models;
-
- use yii\web\IdentityInterface;
- use yii\db\Query ;
- use common\components\ActiveRecordCommon ;
-
- class User extends ActiveRecordCommon implements IdentityInterface
- {
-
- const STATUS_DELETED = 0;
- const STATUS_ACTIVE = 10;
- const STATUS_PRODUCER = 11;
- const STATUS_ADMIN = 13;
-
- const ID_USER_SYSTEM = 0 ;
-
- var $password_old;
- var $password_new;
- var $password_new_confirm;
-
-
-
- public static function tableName()
- {
- return '{{%user}}';
- }
-
-
-
- public function behaviors()
- {
- return [
- TimestampBehavior::className(),
- ];
- }
-
-
-
- public function rules()
- {
- return [
- ['confiance', 'default', 'value' => 1],
- [['no_mail', 'mail_prod_lundi', 'mail_prod_mardi', 'mail_prod_mercredi', 'mail_prod_jeudi', 'mail_prod_vendredi', 'mail_prod_samedi', 'mail_prod_dimanche'], 'boolean'],
- [['nom', 'prenom', 'telephone', 'adresse'], 'string'],
- [['nom', 'prenom'], 'required', 'message' => 'Ce champs ne peut être vide'],
- ['email', 'email', 'message' => 'Cette adresse email n\'est pas valide'],
- ['email', 'verifyEmail'],
- ['status', 'default', 'value' => self::STATUS_ACTIVE],
- ['status', 'in', 'range' => [self::STATUS_ACTIVE, self::STATUS_DELETED, self::STATUS_ADMIN, self::STATUS_BOULANGER]],
- ['password_old', 'verifyPasswordOld'],
- ['password_new', 'verifyPasswordNew'],
- ['password_new_confirm', 'verifyPasswordNewConfirm'],
- [['date_derniere_connexion', 'password_old', 'password_new', 'password_new_confirm', 'password_hash'], 'safe'],
- ];
- }
-
- public function attributeLabels()
- {
- return [
- 'id' => 'ID',
- 'username' => 'Identifiant',
- 'password' => 'Mot de passe',
- 'rememberMe' => 'Se souvenir de moi',
- 'confiance' => 'De confiance',
- 'no_mail' => 'Ne pas recevoir d\'email de la part du Chat des Noisettes',
- 'mail_prod_lundi' => 'Lundi',
- 'mail_prod_mardi' => 'Mardi',
- 'mail_prod_mercredi' => 'Mercredi',
- 'mail_prod_jeudi' => 'Jeudi',
- 'mail_prod_vendredi' => 'Vendredi',
- 'mail_prod_samedi' => 'Samedi',
- 'mail_prod_dimanche' => 'Dimanche',
- 'password_old' => 'Ancien mot de passe',
- 'password_new' => 'Nouveau mot de passe',
- 'password_new_confirm' => 'Confirmation du nouveau mot de passe',
- 'prix_libre' => 'Prix libre',
- ];
- }
-
-
-
- public static function defaultOptionsSearch() {
- return [
- 'with' => [],
- 'join_with' => ['userEtablissement'],
- 'orderby' => 'user.name ASC, user.lastname ASC',
- 'attribute_id_producer' => ''
- ] ;
- }
-
-
-
- public function verifyPasswordOld($attribute, $params)
- {
- if (strlen($this->password_old)) {
- if (!$this->validatePassword($this->password_old)) {
- $this->addError($attribute, 'Mot de passe invalide.');
- }
- }
-
- if (!strlen($this->password_old) && (strlen($this->password_new) || strlen($this->password_new_confirm))) {
- $this->addError($attribute, 'Ce champs ne peut être vide');
- }
-
- if (!strlen($this->password_new) && (strlen($this->password_old) || strlen($this->password_new_confirm))) {
- $this->addError('password_new', 'Ce champs ne peut être vide');
- }
-
- if (!strlen($this->password_new_confirm) && (strlen($this->password_old) || strlen($this->password_new))) {
- $this->addError('password_new_confirm', 'Ce champs ne peut être vide');
- }
- }
-
-
-
- public function verifyPasswordNew($attribute, $params)
- {
- if (strlen($this->password_new) < 6) {
- $this->addError($attribute, 'Votre mot de passe doit comporter au moins 6 caractères.');
- }
- }
-
-
-
- public function verifyPasswordNewConfirm($attribute, $params)
- {
- if ($this->password_new != $this->password_new_confirm) {
- $this->addError($attribute, 'Les deux mots de passe doivent être identiques');
- }
- }
-
-
-
- public function verifyEmail($attribute, $params)
- {
- $user = User::find()->where("email LIKE :email AND id != :id")->params(array(':email' => '%' . $this->email . '%', ':id' => $this->id))->one();
-
- if ($user) {
- $this->addError($attribute, 'Cette adresse email est déjà utilisée par un autre utilisateur ');
- }
- }
-
-
-
-
- public function getUserProducer()
- {
- return $this->hasMany(UserProducer::className(), ['id_user' => 'id']);
- }
-
-
-
- public static function findIdentity($id)
- {
- return static::findOne(['id' => $id]);
- }
-
-
-
- public static function findIdentityByAccessToken($token, $type = null)
- {
- throw new NotSupportedException('"findIdentityByAccessToken" is not implemented.');
- }
-
-
-
- public static function findByUsername($username)
- {
- return static::findOne(['username' => $username]);
- }
-
-
-
- public static function findByEmail($email)
- {
- return static::findOne(['email' => $email]);
- }
-
-
-
- public static function findByPasswordResetToken($token)
- {
- if (!static::isPasswordResetTokenValid($token)) {
- return null;
- }
-
- return static::findOne([
- 'password_reset_token' => $token,
- ]);
- }
-
-
-
- public static function findBy($params = [])
- {
- if (!isset($params['id_producer'])) {
- $params['id_producer'] = Producer::getId() ;
- }
-
- $query = (new Query())
- ->select(['user.id AS user_id', 'user.name', 'user.lastname', 'user.phone', 'user.email', 'user.created_at', 'user.date_last_connection', 'user_producer.*'])
- ->from('user');
-
- $active = (isset($params['inactive']) && $params['inactive']) ? 0 : 1 ;
- $query->innerJoin('user_producer','user.id = user_producer.id_user AND user_producer.active = '.$active.' AND user_producer.id_producer = :id_producer', [':id_producer' => $params['id_producer']]) ;
-
- if(isset($params['id_point_sale']) && $params['id_point_sale']) {
- $point_sale = PointSale::findOne(['id' => $params['id_point_sale']]) ;
- if($point_sale->restricted_access) {
- $query->innerJoin('user_point_sale','user.id = user_point_sale.id_user AND user_point_sale.id_point_sale = :id_point_sale',[':id_point_sale' => $params['id_point_sale']]) ;
- }
- else {
- $query->innerJoin(
- 'order',
- 'user.id = order.id_user AND order.id_point_sale = :id_point_sale',
- [':id_point_sale' => $params['id_point_sale']]
- )->groupBy('user.id') ;
- }
- }
-
- if(isset($params['inactive']) && $params['inactive']) {
- $query->innerJoin(
- 'order',
- 'user.id = order.id_user'
- )
- ->groupBy('user.id');
- }
-
- if (isset($params['name'])) {
- $query->andFilterWhere(['like', 'name', $params['name']]);
- }
-
- if (isset($params['lastname'])) {
- $query->andFilterWhere(['like', 'lastname', $params['lastname']]);
- }
-
- if (isset($params['email'])) {
- $query->andFilterWhere(['like', 'email', $params['email']]);
- }
-
- if (isset($params['phone'])) {
- $query->andFilterWhere(['like', 'phone', $params['phone']]);
- }
-
- return $query;
- }
-
-
-
- public static function isPasswordResetTokenValid($token)
- {
- if (empty($token)) {
- return false;
- }
- $expire = Yii::$app->params['user.passwordResetTokenExpire'];
- $parts = explode('_', $token);
- $timestamp = (int) end($parts);
- return $timestamp + $expire >= time();
- }
-
-
-
- public function getId()
- {
- return $this->getPrimaryKey();
- }
-
-
-
- public function getAuthKey()
- {
- return $this->auth_key;
- }
-
-
-
- public function validateAuthKey($authKey)
- {
- return $this->getAuthKey() === $authKey;
- }
-
-
-
- public function validatePassword($password)
- {
- return Yii::$app->security->validatePassword($password, $this->password_hash);
- }
-
-
-
- public function setPassword($password)
- {
- $this->password_hash = Yii::$app->security->generatePasswordHash($password);
- }
-
-
-
- public function generateAuthKey()
- {
- $this->auth_key = Yii::$app->security->generateRandomString();
- }
-
-
-
- public function generatePasswordResetToken()
- {
- $this->password_reset_token = Yii::$app->security->generateRandomString() . '_' . time();
- }
-
-
-
- public function removePasswordResetToken()
- {
- $this->password_reset_token = null;
- }
-
-
-
- public function isProducer()
- {
- return ($this->status == User::STATUS_ADMIN || $this->status == User::STATUS_PRODUCER) && $this->id_producer;
- }
-
-
-
- public function getNameProducer()
- {
- $producer = Producer::findOne($this->id_producer);
- return $producer->name;
- }
-
-
-
- public function getBookmarkedProducers()
- {
- $producers = (new \yii\db\Query())
- ->select('*')
- ->from(['user_producer', 'producer'])
- ->where('user_producer.id_producer = producer.id')
- ->andWhere(['user_producer.id_user' => $this->id])
- ->andWhere(['user_producer.active' => 1])
- ->all();
-
- return $producers;
- }
-
-
-
- public function getCredit($idProducer)
- {
- $userProducer = UserProducer::searchOne([
- 'id_user' => $this->id
- ]) ;
-
- if ($userProducer) {
- return $userProducer->credit;
- }
-
- return 0;
- }
-
-
-
- public function updateLastConnection()
- {
- $this->date_last_connection = date('Y-m-d H:i:s');
- $this->save();
- }
-
-
-
- public function sendMailWelcome($password)
- {
- if (strlen($this->email)) {
- $producer = Producer::findOne(Producer::getId());
- Yii::$app->mailer->compose();
- $mail = Yii::$app->mailer->compose(
- ['html' => 'createUserAdmin-html', 'text' => 'createUserAdmin-text'], ['user' => $this, 'producer' => $producer, 'password' => $password]
- )
- ->setTo($this->email)
- ->setFrom(['contact@laboiteapain.net' => 'La boîte à pain'])
- ->setSubject('[La boîte à pain] Inscription')
- ->send();
- }
- }
-
-
-
- public static function getId() {
- if(!Yii::$app->user->isGuest) {
- return Yii::$app->user->identity->id ;
- }
-
- return false ;
- }
-
-
-
- public static function getStatus()
- {
- if(!Yii::$app->user->isGuest) {
- return Yii::$app->user->identity->status ;
- }
-
- return false ;
- }
-
- public static function hasAccessBackend()
- {
- return User::getStatus() == USER::STATUS_ADMIN || User::getStatus() == USER::STATUS_PRODUCER;
- }
-
- }
|