Files
appwrite/app/controllers/api/edge.php
T
2022-10-23 18:10:49 +03:00

55 lines
1.5 KiB
PHP

<?php
use Ahc\Jwt\JWT;
use Ahc\Jwt\JWTException;
use Appwrite\Extend\Exception;
use Appwrite\Utopia\Request;
use Appwrite\Utopia\Response;
use Utopia\App;
use Utopia\Registry\Registry;
use Utopia\Validator\ArrayList;
use Utopia\Validator\Text;
use Utopia\Queue\Client;
App::init()
->groups(['edge'])
->inject('request')
->action(function (Request $request) {
$token = $request->getHeader('authorization');
$token = str_replace(["Bearer"," "], "", $token);
$jwt = new JWT(App::getEnv('_APP_OPENSSL_KEY_V1'), 'HS256', 600, 10);
try {
$payload = $jwt->decode($token);
} catch (JWTException $error) {
throw new Exception(Exception::USER_JWT_INVALID, 'Failed to verify JWT. ' . $error->getMessage());
}
});
App::post('/v1/edge/sync')
->desc('Purge cache keys')
->groups(['edge'])
->label('scope', 'public')
->param('keys', '', new ArrayList(new Text(100), 1000), 'Cache keys')
->inject('request')
->inject('response')
->inject('register')
->action(function (array $keys, Request $request, Response $response, Registry $register) {
if (empty($keys)) {
throw new Exception(Exception::KEY_NOT_FOUND);
}
$connection = $register
->get('queue');
$client = new Client('syncIn', $connection);
$client->enqueue(['value' => ['keys' => $keys]]);
$response
->setStatusCode(Response::STATUS_CODE_OK)
->send();
});