2016-11-23 23:41:33 +03:00
|
|
|
<?php
|
|
|
|
namespace console\controllers;
|
|
|
|
|
2017-09-29 02:04:16 +03:00
|
|
|
use common\models\AccountSession;
|
2017-03-07 20:14:54 +03:00
|
|
|
use common\models\EmailActivation;
|
2018-02-28 01:27:35 +03:00
|
|
|
use common\models\OauthClient;
|
|
|
|
use common\tasks\ClearOauthSessions;
|
2017-11-15 00:03:38 +03:00
|
|
|
use Yii;
|
2016-11-23 23:41:33 +03:00
|
|
|
use yii\console\Controller;
|
2018-02-28 01:27:35 +03:00
|
|
|
use yii\console\ExitCode;
|
2016-11-23 23:41:33 +03:00
|
|
|
|
|
|
|
class CleanupController extends Controller {
|
|
|
|
|
2018-02-28 01:27:35 +03:00
|
|
|
public function actionEmailKeys(): int {
|
2024-12-02 15:10:55 +05:00
|
|
|
$query = EmailActivation::find()
|
|
|
|
->andWhere(['<', 'created_at', time() - 60 * 60 * 24 * 14]); // 14d
|
2017-11-15 00:03:38 +03:00
|
|
|
foreach ($query->each(100, Yii::$app->unbufferedDb) as $email) {
|
2017-11-14 19:49:51 +03:00
|
|
|
/** @var EmailActivation $email */
|
2017-03-07 20:14:54 +03:00
|
|
|
$email->delete();
|
|
|
|
}
|
|
|
|
|
2018-02-28 01:27:35 +03:00
|
|
|
return ExitCode::OK;
|
2017-03-07 20:14:54 +03:00
|
|
|
}
|
|
|
|
|
2017-09-29 02:04:16 +03:00
|
|
|
/**
|
2019-07-15 01:59:56 +03:00
|
|
|
* Sessions that have not been refreshed for 90 days and those
|
|
|
|
* that have not been refreshed since they were issued more than 2 weeks ago
|
|
|
|
* should be deleted.
|
2017-09-29 02:04:16 +03:00
|
|
|
*
|
2019-07-15 01:59:56 +03:00
|
|
|
* The AccountSession model doesn't have any relations,
|
|
|
|
* so the records can be deleted just with mass delete operation.
|
2017-09-29 02:04:16 +03:00
|
|
|
*/
|
2018-02-28 01:27:35 +03:00
|
|
|
public function actionWebSessions(): int {
|
2017-09-29 02:04:16 +03:00
|
|
|
AccountSession::deleteAll([
|
|
|
|
'OR',
|
|
|
|
['<', 'last_refreshed_at', time() - 7776000], // 90 days
|
|
|
|
[
|
|
|
|
'AND',
|
|
|
|
'created_at = last_refreshed_at',
|
|
|
|
['<', 'created_at', time() - 1209600], // 2 weeks
|
|
|
|
],
|
|
|
|
]);
|
|
|
|
|
2018-02-28 01:27:35 +03:00
|
|
|
return ExitCode::OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function actionOauthClients(): int {
|
|
|
|
/** @var OauthClient[] $clients */
|
|
|
|
$clients = OauthClient::find()
|
|
|
|
->onlyDeleted()
|
|
|
|
->all();
|
|
|
|
foreach ($clients as $client) {
|
|
|
|
if ($client->getSessions()->exists()) {
|
|
|
|
Yii::$app->queue->push(ClearOauthSessions::createFromOauthClient($client));
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$client->delete();
|
|
|
|
}
|
|
|
|
|
|
|
|
return ExitCode::OK;
|
2017-09-29 02:04:16 +03:00
|
|
|
}
|
|
|
|
|
2016-11-23 23:41:33 +03:00
|
|
|
}
|