b0f143c3
Yarik
first commit
|
1
|
<?php
|
b95371cf
Yarik
test
|
2
|
namespace common\models;
|
b0f143c3
Yarik
first commit
|
3
|
|
4ed1f788
Yarik
test
|
4
5
|
use common\modules\comment\models\Comment;
use common\modules\comment\models\Rating;
|
b95371cf
Yarik
test
|
6
|
use Yii;
|
4ed1f788
Yarik
test
|
7
|
use yii\base\InvalidConfigException;
|
b95371cf
Yarik
test
|
8
9
|
use yii\base\NotSupportedException;
use yii\behaviors\TimestampBehavior;
|
e8236f44
Yarik
test
|
10
|
use yii\db\ActiveQuery;
|
b95371cf
Yarik
test
|
11
|
use yii\db\ActiveRecord;
|
e8236f44
Yarik
test
|
12
13
|
use yii\rbac\ManagerInterface;
use yii\rbac\Role;
|
b95371cf
Yarik
test
|
14
15
|
use yii\web\IdentityInterface;
use developeruz\db_rbac\interfaces\UserRbacInterface;
|
b0f143c3
Yarik
first commit
|
16
17
|
/**
|
b95371cf
Yarik
test
|
18
|
* User model
|
4ed1f788
Yarik
test
|
19
20
21
22
23
24
25
26
27
28
29
30
|
* @property integer $id
* @property string $username
* @property string $password_hash
* @property string $password_reset_token
* @property string $email
* @property string $auth_key
* @property integer $status
* @property integer $created_at
* @property integer $updated_at
* @property string $password write-only password
* @property string $type
* @property UserInfo $userInfo
|
b0f143c3
Yarik
first commit
|
31
|
*/
|
b95371cf
Yarik
test
|
32
|
class User extends ActiveRecord implements IdentityInterface, UserRbacInterface
|
b0f143c3
Yarik
first commit
|
33
|
{
|
4c9663e0
Yarik
test
|
34
|
|
b95371cf
Yarik
test
|
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
const STATUS_DELETED = 0;
const STATUS_ACTIVE = 10;
public $profile;
public $old_password;
public $new_password;
public $password_reply;
/**
* @inheritdoc
*/
public static function tableName()
{
return '{{%user}}';
}
/**
* @inheritdoc
*/
public function behaviors()
{
return [
TimestampBehavior::className(),
];
}
|
b95371cf
Yarik
test
|
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/**
* @inheritdoc
*/
public function rules()
{
return [
[
'status',
'default',
'value' => self::STATUS_ACTIVE,
],
[
'status',
'in',
'range' => [
self::STATUS_ACTIVE,
self::STATUS_DELETED,
],
],
[
[
'username',
'lastname',
'firstname',
'middlename',
],
'string',
'max' => 255,
],
[
|
b95371cf
Yarik
test
|
94
95
96
|
[
'specializationInput',
'paymentInput',
|
4ed1f788
Yarik
test
|
97
|
'type',
|
b95371cf
Yarik
test
|
98
99
100
|
],
'safe',
],
|
658a5f37
Yarik
test
|
101
102
103
104
|
[
'type',
'default',
'value' => 1,
|
4ed1f788
Yarik
test
|
105
|
],
|
b95371cf
Yarik
test
|
106
107
108
109
110
111
|
];
}
/**
* @inheritdoc
*/
|
3e86d3d1
Yarik
test
|
112
113
114
115
|
public function attributeLabels()
{
return [
'firstname' => Yii::t('app', 'Имя'),
|
4ed1f788
Yarik
test
|
116
117
|
'lastname' => Yii::t('app', 'Фамилия'),
'email' => Yii::t('app', 'Email'),
|
3e86d3d1
Yarik
test
|
118
119
120
121
122
123
|
];
}
/**
* @inheritdoc
*/
|
b95371cf
Yarik
test
|
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
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,
]);
|
b0f143c3
Yarik
first commit
|
142
|
}
|
b95371cf
Yarik
test
|
143
|
|
b0f143c3
Yarik
first commit
|
144
|
}
|
b95371cf
Yarik
test
|
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
|
/**
* @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);
|
b0f143c3
Yarik
first commit
|
168
|
}
|
b0f143c3
Yarik
first commit
|
169
|
|
b95371cf
Yarik
test
|
170
|
public $authKey;
|
b0f143c3
Yarik
first commit
|
171
|
|
b95371cf
Yarik
test
|
172
173
174
175
176
177
178
|
/**
* @inheritdoc
*/
public static function findIdentityByAccessToken($token, $type = NULL)
{
throw new NotSupportedException('"findIdentityByAccessToken" is not implemented.');
}
|
b0f143c3
Yarik
first commit
|
179
|
|
b95371cf
Yarik
test
|
180
181
182
183
184
185
186
187
188
189
190
191
192
193
|
/**
* Finds user by username
*
* @param string $username
*
* @return static|null
*/
public static function findByUsername($username)
{
return static::findOne([
'username' => $username,
'status' => self::STATUS_ACTIVE,
]);
}
|
b0f143c3
Yarik
first commit
|
194
|
|
b95371cf
Yarik
test
|
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
|
/**
* 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,
]);
|
b0f143c3
Yarik
first commit
|
212
213
|
}
|
b95371cf
Yarik
test
|
214
215
216
217
218
219
220
221
222
223
224
225
|
/**
* 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;
}
|
b0f143c3
Yarik
first commit
|
226
|
|
b95371cf
Yarik
test
|
227
228
229
|
$timestamp = (int) substr($token, strrpos($token, '_') + 1);
$expire = Yii::$app->params[ 'user.passwordResetTokenExpire' ];
return $timestamp + $expire >= time();
|
b0f143c3
Yarik
first commit
|
230
231
|
}
|
b95371cf
Yarik
test
|
232
233
234
235
236
237
238
|
/**
* @inheritdoc
*/
public function getId()
{
return $this->getPrimaryKey();
}
|
b0f143c3
Yarik
first commit
|
239
|
|
b95371cf
Yarik
test
|
240
241
242
243
244
245
246
|
/**
* @inheritdoc
*/
public function getAuthKey()
{
return $this->auth_key;
}
|
b0f143c3
Yarik
first commit
|
247
|
|
b95371cf
Yarik
test
|
248
249
250
251
252
253
254
|
/**
* @inheritdoc
*/
public function validateAuthKey($authKey)
{
return $this->getAuthKey() === $authKey;
}
|
b0f143c3
Yarik
first commit
|
255
|
|
b95371cf
Yarik
test
|
256
257
258
259
260
261
262
263
264
265
266
|
/**
* 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);
}
|
b0f143c3
Yarik
first commit
|
267
|
|
b95371cf
Yarik
test
|
268
269
270
271
272
273
274
275
276
|
/**
* 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);
}
|
b0f143c3
Yarik
first commit
|
277
|
|
b95371cf
Yarik
test
|
278
279
280
281
282
283
284
|
/**
* Generates "remember me" authentication key
*/
public function generateAuthKey()
{
$this->auth_key = Yii::$app->security->generateRandomString();
}
|
b0f143c3
Yarik
first commit
|
285
|
|
b95371cf
Yarik
test
|
286
287
288
289
290
291
292
|
/**
* Generates new password reset token
*/
public function generatePasswordResetToken()
{
$this->password_reset_token = Yii::$app->security->generateRandomString() . '_' . time();
}
|
b0f143c3
Yarik
first commit
|
293
|
|
b95371cf
Yarik
test
|
294
295
296
297
298
299
300
|
/**
* Removes password reset token
*/
public function removePasswordResetToken()
{
$this->password_reset_token = NULL;
}
|
b0f143c3
Yarik
first commit
|
301
|
|
e8236f44
Yarik
test
|
302
303
|
/**
* Returns name of the User
|
e8236f44
Yarik
test
|
304
305
|
* @return string
*/
|
b95371cf
Yarik
test
|
306
307
308
309
|
public function getUserName()
{
return $this->username;
}
|
b0f143c3
Yarik
first commit
|
310
|
|
e8236f44
Yarik
test
|
311
312
|
/**
* Return array of all User's roles
|
e8236f44
Yarik
test
|
313
314
|
* @return array
*/
|
b95371cf
Yarik
test
|
315
316
317
318
319
320
|
public function getRoles()
{
$auth = \Yii::$app->authManager;
$roles = $this->getRoleChildrenRecursive($auth->getRolesByUser($this->id), $auth);
return $roles;
}
|
b0f143c3
Yarik
first commit
|
321
|
|
e8236f44
Yarik
test
|
322
|
/**
|
4c9663e0
Yarik
test
|
323
324
325
326
|
* @param Role[] $roles User roles returned by
* [ManagerInterface]->[getRolesByUser($id)]
* @param ManagerInterface $auth Auth manager
* @param array $result
|
e8236f44
Yarik
test
|
327
328
329
|
*
* @return array
*/
|
b95371cf
Yarik
test
|
330
|
protected function getRoleChildrenRecursive($roles, $auth, $result = [ ])
|
b0f143c3
Yarik
first commit
|
331
|
{
|
b95371cf
Yarik
test
|
332
333
334
335
336
337
338
|
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);
|
b0f143c3
Yarik
first commit
|
339
|
}
|
b95371cf
Yarik
test
|
340
341
342
|
return $result;
} else {
return $result;
|
b0f143c3
Yarik
first commit
|
343
|
}
|
b0f143c3
Yarik
first commit
|
344
|
}
|
cd6bd007
Yarik
test
|
345
|
|
e8236f44
Yarik
test
|
346
347
|
/**
* Return UserInfo for this User
|
e8236f44
Yarik
test
|
348
349
|
* @return \yii\db\ActiveQuery
*/
|
b95371cf
Yarik
test
|
350
351
|
public function getUserInfo()
{
|
4ed1f788
Yarik
test
|
352
353
|
return $this->hasOne(UserInfo::className(), [ 'user_id' => 'id' ])
->inverseOf('user');
|
b95371cf
Yarik
test
|
354
|
}
|
51e0a262
Yarik
test
|
355
|
|
e8236f44
Yarik
test
|
356
357
|
/**
* Check if User is Performer
|
e8236f44
Yarik
test
|
358
|
* <i>currently in development mode</i>
|
e8236f44
Yarik
test
|
359
360
|
* @return bool
*/
|
b95371cf
Yarik
test
|
361
362
363
364
|
public function getIsPerformer()
{
return true;
}
|
033f9331
Administrator
09.02.16
|
365
|
|
e8236f44
Yarik
test
|
366
367
|
/**
* Return CompanyInfo for this User
|
e8236f44
Yarik
test
|
368
369
|
* @return \yii\db\ActiveQuery
*/
|
47559a4b
Yarik
test
|
370
371
372
373
|
public function getCompanyInfo()
{
return $this->hasOne(CompanyInfo::className(), [ 'user_id' => 'id' ]);
}
|
658d13d4
Administrator
09.02.16
|
374
|
|
e8236f44
Yarik
test
|
375
376
|
/**
* Return array of User's phones
|
e8236f44
Yarik
test
|
377
378
|
* @return array
*/
|
a02e2fdb
Yarik
test
|
379
380
381
|
public function getPhones()
{
return Fields::getData($this->id, self::className(), 'phone');
|
f6ea8941
Administrator
09.02.16
|
382
383
|
}
|
e8236f44
Yarik
test
|
384
385
|
/**
* Return array of User's site
|
e8236f44
Yarik
test
|
386
387
|
* @return array
*/
|
a02e2fdb
Yarik
test
|
388
389
390
|
public function getSite()
{
return Fields::getData($this->id, self::className(), 'site');
|
f6ea8941
Administrator
09.02.16
|
391
392
|
}
|
e8236f44
Yarik
test
|
393
394
|
/**
* Return full address of User in view like:
|
e8236f44
Yarik
test
|
395
396
397
|
* <code>{country}, {city}, {street}, {house}</code>
* @return string
*/
|
a02e2fdb
Yarik
test
|
398
399
400
|
public function getAddress()
{
return $this->userInfo->country . ', ' . $this->userInfo->city . ', ' . $this->companyInfo->street . ', ' . $this->companyInfo->house;
|
f6ea8941
Administrator
09.02.16
|
401
402
|
}
|
e8236f44
Yarik
test
|
403
404
|
/**
* Return relative interval of time from User registration date until now.
|
e8236f44
Yarik
test
|
405
406
|
* @return string
*/
|
47559a4b
Yarik
test
|
407
408
|
public function getLiveTime()
{
|
47559a4b
Yarik
test
|
409
410
|
$now = new \DateTime('now');
$date1 = new \DateTime(date('Y-m-d H:i:s', $this->created_at));
|
eb7e82fb
Administrator
29.02.16
|
411
412
|
$result = explode(',', \Yii::$app->formatter->asDuration($date1->diff($now)));
|
4ed1f788
Yarik
test
|
413
|
if($result >= 4) {
|
eb7e82fb
Administrator
29.02.16
|
414
415
416
|
array_splice($result, 2);
}
|
4ed1f788
Yarik
test
|
417
|
return implode(',', $result);
|
47559a4b
Yarik
test
|
418
|
}
|
b95371cf
Yarik
test
|
419
|
|
e8236f44
Yarik
test
|
420
421
|
/**
* Check if User is Customer
|
e8236f44
Yarik
test
|
422
|
* <i>currently in development</i>
|
e8236f44
Yarik
test
|
423
424
|
* @return bool
*/
|
b95371cf
Yarik
test
|
425
426
427
428
429
|
public function getIsCustomer()
{
return true;
}
|
e8236f44
Yarik
test
|
430
431
|
/**
* Return array of payments types accepted by the user.
|
e8236f44
Yarik
test
|
432
433
|
* @return ActiveQuery
*/
|
b95371cf
Yarik
test
|
434
435
436
437
438
439
|
public function getPayments()
{
return $this->hasMany(Payment::className(), [ 'payment_id' => 'payment_id' ])
->viaTable('user_payment', [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
440
441
|
/**
* Return array of Payment IDs, accepted by the user.
|
e8236f44
Yarik
test
|
442
443
|
* @return integer[]
*/
|
b95371cf
Yarik
test
|
444
445
446
447
448
449
450
|
public function getPaymentInput()
{
return $this->getPayments()
->asArray()
->column();
}
|
e8236f44
Yarik
test
|
451
452
453
454
455
|
/**
* Setter which allow to set User's payment ID's for further saving to the DB.
*
* @param integer[] $value
*/
|
b95371cf
Yarik
test
|
456
457
458
459
460
|
public function setPaymentInput($value)
{
$this->paymentInput = $value;
}
|
e8236f44
Yarik
test
|
461
462
|
/**
* Return array of Specializations in which the User works.
|
e8236f44
Yarik
test
|
463
464
|
* @return ActiveQuery
*/
|
b95371cf
Yarik
test
|
465
466
467
468
469
470
|
public function getSpecializations()
{
return $this->hasMany(Specialization::className(), [ 'specialization_id' => 'specialization_id' ])
->viaTable('user_specialization', [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
471
472
|
/**
* Return array of User's blogs
|
e8236f44
Yarik
test
|
473
474
|
* @return ActiveQuery
*/
|
376a557b
Administrator
09.02.16
|
475
476
477
478
479
|
public function getBlog()
{
return $this->hasMany(Blog::className(), [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
480
481
|
/**
* Return array of User's jobs.
|
e8236f44
Yarik
test
|
482
483
|
* @return ActiveQuery
*/
|
f6ea8941
Administrator
09.02.16
|
484
485
486
487
488
|
public function getJobs()
{
return $this->hasMany(Job::className(), [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
489
490
|
/**
* Return ActiveRecord of current User's place of work.
|
e8236f44
Yarik
test
|
491
492
493
494
|
* @return ActiveQuery
*/
public function getCurrentJob()
{
|
4c9663e0
Yarik
test
|
495
496
|
return $this->hasOne(Job::className(), [ 'user_id' => 'id' ])
->where([ 'current' => 1 ]);
|
e8236f44
Yarik
test
|
497
498
499
500
|
}
/**
* Return array of User's specialization IDs
|
e8236f44
Yarik
test
|
501
502
|
* @return integer[]
*/
|
b95371cf
Yarik
test
|
503
504
505
506
|
public function getSpecializationInput()
{
return $this->getSpecializations()
->asArray()
|
4c9663e0
Yarik
test
|
507
|
->indexBy('specialization_id')
|
b95371cf
Yarik
test
|
508
509
510
|
->column();
}
|
e8236f44
Yarik
test
|
511
512
513
514
515
|
/**
* Setter which allow to set User's specializations for further saving to the DB.
*
* @param integer[] $value
*/
|
b95371cf
Yarik
test
|
516
517
518
519
|
public function setSpecializationInput($value)
{
$this->specializationInput = $value;
}
|
51e0a262
Yarik
test
|
520
|
|
e8236f44
Yarik
test
|
521
522
|
/**
* Return array of User's portfolios.
|
e8236f44
Yarik
test
|
523
524
|
* @return ActiveQuery
*/
|
a02e2fdb
Yarik
test
|
525
526
527
528
529
|
public function getPortfolios()
{
return $this->hasMany(Portfolio::className(), [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
530
531
|
/**
* Return array of User's projects.
|
e8236f44
Yarik
test
|
532
533
|
* @return ActiveQuery
*/
|
a02e2fdb
Yarik
test
|
534
535
536
537
538
|
public function getProjects()
{
return $this->hasMany(Project::className(), [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
539
540
|
/**
* Return array of company's Team members.
|
e8236f44
Yarik
test
|
541
542
|
* @return ActiveQuery
*/
|
a02e2fdb
Yarik
test
|
543
544
545
546
547
|
public function getTeams()
{
return $this->hasMany(Team::className(), [ 'user_id' => 'id' ]);
}
|
e8236f44
Yarik
test
|
548
549
|
/**
* Return array of company's Vacancies.
|
e8236f44
Yarik
test
|
550
551
|
* @return ActiveQuery
*/
|
a02e2fdb
Yarik
test
|
552
553
|
public function getVacancies()
{
|
4ed1f788
Yarik
test
|
554
555
|
return $this->hasMany(Vacancy::className(), [ 'user_id' => 'id' ])
->inverseOf('user');
|
a02e2fdb
Yarik
test
|
556
557
|
}
|
2e35d6bd
Yarik
test
|
558
559
560
561
562
|
public function getGalleries()
{
return $this->hasMany(Gallery::className(), [ 'user_id' => 'id' ]);
}
|
3dc20ff7
Administrator
24.02.16
|
563
564
|
public function getOwner()
{
|
4ed1f788
Yarik
test
|
565
|
if($this->type == 2) {
|
3dc20ff7
Administrator
24.02.16
|
566
|
return $this->hasOne(CompanyInfo::className(), [ 'user_id' => 'id' ]);
|
4ed1f788
Yarik
test
|
567
568
|
} else {
return $this->hasOne(UserInfo::className(), [ 'user_id' => 'id' ]);
|
3dc20ff7
Administrator
24.02.16
|
569
|
}
|
3dc20ff7
Administrator
24.02.16
|
570
571
|
}
|
4ed1f788
Yarik
test
|
572
573
574
|
public function getName()
{
if($this->type == 2) {
|
3ea37908
Administrator
01.03.16
|
575
|
return $this->companyInfo->name;
|
4ed1f788
Yarik
test
|
576
577
|
} else {
return $this->firstname . ' ' . $this->lastname;
|
3ea37908
Administrator
01.03.16
|
578
|
}
|
4ed1f788
Yarik
test
|
579
|
}
|
3ea37908
Administrator
01.03.16
|
580
|
|
4ed1f788
Yarik
test
|
581
582
583
584
585
|
public function getComments()
{
$entity = 'user-' . $this->id;
$comments = (new Comment())->getComments($entity);
return $comments;
|
3dc20ff7
Administrator
24.02.16
|
586
587
|
}
|
4ed1f788
Yarik
test
|
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
|
public function getRatingPG()
{
if(\Yii::$app->db->driverName != 'pgsql') {
throw new InvalidConfigException('This method is available only in PostgreSQL');
}
$entity = 'user-' . $this->id;
$rating = (new Comment())->getComments($entity)
->select('ROUND(SUM("rating"."value")/COUNT("rating"."rating_id")::float) as rating')
->leftJoin(Rating::tableName(), "CONCAT('Comment-', \"comment\".\"comment_id\") = \"rating\".\"entity\"")
->andWhere([
'not',
[ 'rating.value' => NULL ],
])
->one();
return $rating;
}
|
3dc20ff7
Administrator
24.02.16
|
604
|
|
51e0a262
Yarik
test
|
605
|
}
|