mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-03 16:08:19 +02:00
Summary: Ref T7303. This inches toward properly-behaved cluster logout. - Use IDs instead of PHIDs in URIs. - Slightly more modern code. - Fix some crumb stuff. Test Plan: Created, edited, viewed, deleted, showed secret for, authorized, test-auth'd an application. Reviewers: chad Reviewed By: chad Maniphest Tasks: T7303 Differential Revision: https://secure.phabricator.com/D15592
68 lines
2.1 KiB
PHP
68 lines
2.1 KiB
PHP
<?php
|
|
|
|
final class PhabricatorOAuthClientSecretController
|
|
extends PhabricatorOAuthClientController {
|
|
|
|
public function handleRequest(AphrontRequest $request) {
|
|
$viewer = $request->getUser();
|
|
|
|
$client = id(new PhabricatorOAuthServerClientQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($request->getURIData('id')))
|
|
->requireCapabilities(
|
|
array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
))
|
|
->executeOne();
|
|
if (!$client) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$view_uri = $client->getViewURI();
|
|
$token = id(new PhabricatorAuthSessionEngine())->requireHighSecuritySession(
|
|
$viewer,
|
|
$request,
|
|
$view_uri);
|
|
|
|
if ($request->isFormPost()) {
|
|
$secret = $client->getSecret();
|
|
|
|
$body = id(new PHUIFormLayoutView())
|
|
->appendChild(
|
|
id(new AphrontFormTextAreaControl())
|
|
->setLabel(pht('Plaintext'))
|
|
->setReadOnly(true)
|
|
->setHeight(AphrontFormTextAreaControl::HEIGHT_VERY_SHORT)
|
|
->setValue($secret));
|
|
|
|
return $this->newDialog()
|
|
->setWidth(AphrontDialogView::WIDTH_FORM)
|
|
->setTitle(pht('Application Secret'))
|
|
->appendChild($body)
|
|
->addCancelButton($view_uri, pht('Done'));
|
|
}
|
|
|
|
|
|
$is_serious = PhabricatorEnv::getEnvConfig('phabricator.serious-business');
|
|
|
|
if ($is_serious) {
|
|
$body = pht(
|
|
'The secret associated with this OAuth application will be shown in '.
|
|
'plain text on your screen.');
|
|
} else {
|
|
$body = pht(
|
|
'The secret associated with this OAuth application will be shown in '.
|
|
'plain text on your screen. Before continuing, wrap your arms around '.
|
|
'your monitor to create a human shield, keeping it safe from prying '.
|
|
'eyes. Protect company secrets!');
|
|
}
|
|
|
|
return $this->newDialog()
|
|
->setTitle(pht('Really show application secret?'))
|
|
->appendChild($body)
|
|
->addSubmitButton(pht('Show Application Secret'))
|
|
->addCancelButton($view_uri);
|
|
}
|
|
|
|
}
|