. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU Affero General Public License version 3. * * In accordance with Section 7(b) of the GNU Affero General Public License version 3, * these Appropriate Legal Notices must retain the display of the "EspoCRM" word. ************************************************************************/ namespace Espo\Controllers; use Espo\Core\Api\Request; use Espo\Core\Api\Response; use Espo\Core\Exceptions\BadRequest; use Espo\Core\Exceptions\Error; use Espo\Core\Exceptions\Forbidden; use Espo\Core\Exceptions\ForbiddenSilent; use Espo\Core\Utils\Json; use Espo\Tools\Oidc\Service; class Oidc { private Service $service; public function __construct(Service $service) { $this->service = $service; } /** * @throws Forbidden * @throws Error */ public function getActionAuthorizationData(Request $request, Response $response): void { $data = $this->service->getAuthorizationData(); $response->writeBody(Json::encode($data)); } /** * @throws BadRequest * @throws Forbidden */ public function postActionBackchannelLogout(Request $request, Response $response): void { $token = $request->getParsedBody()->logout_token ?? null; if (!$token || !is_string($token)) { throw new BadRequest(); } $this->service->backchannelLogout($token); $response->writeBody('true'); } }