2016-04-23 21:44:10 +03:00
|
|
|
<?php
|
2020-06-12 00:27:02 +03:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2016-04-23 21:44:10 +03:00
|
|
|
namespace common\models;
|
|
|
|
|
|
|
|
use yii\behaviors\TimestampBehavior;
|
2020-06-12 00:27:02 +03:00
|
|
|
use yii\db\ActiveQuery;
|
2016-04-23 21:44:10 +03:00
|
|
|
use yii\db\ActiveRecord;
|
|
|
|
|
|
|
|
/**
|
2019-07-15 01:59:56 +03:00
|
|
|
* Fields:
|
2020-06-12 00:27:02 +03:00
|
|
|
* @property int $id
|
|
|
|
* @property string $username
|
|
|
|
* @property int|null $account_id
|
|
|
|
* @property int $applied_in
|
2016-04-23 21:44:10 +03:00
|
|
|
*
|
2019-07-15 01:59:56 +03:00
|
|
|
* Relations:
|
2020-06-12 00:27:02 +03:00
|
|
|
* @property-read Account $account
|
2016-04-23 21:44:10 +03:00
|
|
|
*
|
2019-07-15 01:59:56 +03:00
|
|
|
* Behaviors:
|
2016-04-23 21:44:10 +03:00
|
|
|
* @mixin TimestampBehavior
|
|
|
|
*/
|
|
|
|
class UsernameHistory extends ActiveRecord {
|
|
|
|
|
2020-06-12 00:27:02 +03:00
|
|
|
public static function tableName(): string {
|
|
|
|
return 'usernames_history';
|
2016-04-23 21:44:10 +03:00
|
|
|
}
|
|
|
|
|
2020-06-12 00:27:02 +03:00
|
|
|
public function behaviors(): array {
|
2016-04-23 21:44:10 +03:00
|
|
|
return [
|
|
|
|
[
|
|
|
|
'class' => TimestampBehavior::class,
|
|
|
|
'createdAtAttribute' => 'applied_in',
|
|
|
|
'updatedAtAttribute' => false,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2020-06-12 00:27:02 +03:00
|
|
|
public function getAccount(): ActiveQuery {
|
2016-04-23 21:44:10 +03:00
|
|
|
return $this->hasOne(Account::class, ['id' => 'account_id']);
|
|
|
|
}
|
|
|
|
|
2016-09-21 11:13:43 +03:00
|
|
|
/**
|
2020-06-12 00:27:02 +03:00
|
|
|
* Find the username after the current of the account.
|
|
|
|
*
|
2016-09-21 11:13:43 +03:00
|
|
|
* @param int $afterTime
|
|
|
|
* @return UsernameHistory|null
|
|
|
|
*/
|
2020-06-12 00:27:02 +03:00
|
|
|
public function findNextOwnerUsername(int $afterTime = null): ?self {
|
2016-09-21 11:13:43 +03:00
|
|
|
return self::find()
|
|
|
|
->andWhere(['account_id' => $this->account_id])
|
|
|
|
->andWhere(['>', 'applied_in', $afterTime ?: $this->applied_in])
|
|
|
|
->orderBy(['applied_in' => SORT_ASC])
|
|
|
|
->one();
|
|
|
|
}
|
|
|
|
|
2016-04-23 21:44:10 +03:00
|
|
|
}
|