2018-02-28 01:27:35 +03:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace api\modules\oauth\models;
|
|
|
|
|
|
|
|
use api\modules\oauth\exceptions\InvalidOauthClientState;
|
|
|
|
use common\models\OauthClient;
|
|
|
|
use common\tasks\ClearOauthSessions;
|
2019-12-13 20:48:13 +03:00
|
|
|
use Webmozart\Assert\Assert;
|
2018-02-28 01:27:35 +03:00
|
|
|
use Yii;
|
|
|
|
use yii\helpers\Inflector;
|
|
|
|
|
|
|
|
class OauthClientForm {
|
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
private readonly OauthClient $client;
|
2018-02-28 01:27:35 +03:00
|
|
|
|
|
|
|
public function __construct(OauthClient $client) {
|
|
|
|
if ($client->type === null) {
|
|
|
|
throw new InvalidOauthClientState('client\'s type field must be set');
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->client = $client;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getClient(): OauthClient {
|
|
|
|
return $this->client;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function save(OauthClientTypeForm $form): bool {
|
|
|
|
if (!$form->validate()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$client = $this->getClient();
|
|
|
|
$form->applyToClient($client);
|
|
|
|
|
|
|
|
if ($client->isNewRecord) {
|
|
|
|
$baseId = $id = substr(Inflector::slug($client->name), 0, 250);
|
|
|
|
$i = 0;
|
|
|
|
while ($this->isClientExists($id)) {
|
|
|
|
$id = $baseId . ++$i;
|
|
|
|
}
|
|
|
|
|
|
|
|
$client->id = $id;
|
|
|
|
$client->generateSecret();
|
|
|
|
}
|
|
|
|
|
2019-12-13 20:48:13 +03:00
|
|
|
Assert::true($client->save(), 'Cannot save oauth client');
|
2018-02-28 01:27:35 +03:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function delete(): bool {
|
|
|
|
$transaction = Yii::$app->db->beginTransaction();
|
|
|
|
|
2019-12-14 00:16:05 +03:00
|
|
|
$client = $this->getClient();
|
2018-02-28 01:27:35 +03:00
|
|
|
$client->is_deleted = true;
|
2019-12-13 20:48:13 +03:00
|
|
|
Assert::true($client->save(), 'Cannot update oauth client');
|
2018-02-28 01:27:35 +03:00
|
|
|
|
|
|
|
Yii::$app->queue->push(ClearOauthSessions::createFromOauthClient($client));
|
|
|
|
|
|
|
|
$transaction->commit();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function reset(bool $regenerateSecret = false): bool {
|
|
|
|
$transaction = Yii::$app->db->beginTransaction();
|
|
|
|
|
2019-12-14 00:16:05 +03:00
|
|
|
$client = $this->getClient();
|
2018-02-28 01:27:35 +03:00
|
|
|
if ($regenerateSecret) {
|
|
|
|
$client->generateSecret();
|
2019-12-13 20:48:13 +03:00
|
|
|
Assert::true($client->save(), 'Cannot update oauth client');
|
2018-02-28 01:27:35 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
Yii::$app->queue->push(ClearOauthSessions::createFromOauthClient($client, time()));
|
|
|
|
|
|
|
|
$transaction->commit();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function isClientExists(string $id): bool {
|
2018-11-11 13:48:23 +03:00
|
|
|
return OauthClient::find()
|
|
|
|
->includeDeleted()
|
|
|
|
->andWhere(['id' => $id])
|
|
|
|
->exists();
|
2018-02-28 01:27:35 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|