2013-11-20 18:13:35 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PassphraseCredentialDestroyController
|
|
|
|
extends PassphraseController {
|
|
|
|
|
2015-07-27 18:06:01 +02:00
|
|
|
public function handleRequest(AphrontRequest $request) {
|
|
|
|
$viewer = $request->getViewer();
|
|
|
|
$id = $request->getURIData('id');
|
2013-11-20 18:13:35 +01:00
|
|
|
|
|
|
|
$credential = id(new PassphraseCredentialQuery())
|
|
|
|
->setViewer($viewer)
|
2015-07-27 18:06:01 +02:00
|
|
|
->withIDs(array($id))
|
2013-11-20 18:13:35 +01:00
|
|
|
->requireCapabilities(
|
|
|
|
array(
|
|
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
|
|
))
|
|
|
|
->executeOne();
|
|
|
|
if (!$credential) {
|
|
|
|
return new Aphront404Response();
|
|
|
|
}
|
|
|
|
|
|
|
|
$type = PassphraseCredentialType::getTypeByConstant(
|
|
|
|
$credential->getCredentialType());
|
|
|
|
if (!$type) {
|
|
|
|
throw new Exception(pht('Credential has invalid type "%s"!', $type));
|
|
|
|
}
|
|
|
|
|
|
|
|
$view_uri = '/K'.$credential->getID();
|
|
|
|
|
|
|
|
if ($request->isFormPost()) {
|
|
|
|
|
|
|
|
$xactions = array();
|
|
|
|
$xactions[] = id(new PassphraseCredentialTransaction())
|
|
|
|
->setTransactionType(PassphraseCredentialTransaction::TYPE_DESTROY)
|
|
|
|
->setNewValue(1);
|
|
|
|
|
|
|
|
$editor = id(new PassphraseCredentialTransactionEditor())
|
|
|
|
->setActor($viewer)
|
|
|
|
->setContinueOnMissingFields(true)
|
|
|
|
->setContentSourceFromRequest($request)
|
|
|
|
->applyTransactions($credential, $xactions);
|
|
|
|
|
|
|
|
return id(new AphrontRedirectResponse())->setURI($view_uri);
|
|
|
|
}
|
|
|
|
|
2014-05-03 03:05:19 +02:00
|
|
|
return $this->newDialog()
|
2013-11-20 18:13:35 +01:00
|
|
|
->setUser($viewer)
|
|
|
|
->setTitle(pht('Really destroy credential?'))
|
|
|
|
->appendChild(
|
|
|
|
pht(
|
|
|
|
'This credential will be deactivated and the secret will be '.
|
2014-05-03 03:05:19 +02:00
|
|
|
'unrecoverably destroyed. Anything relying on this credential '.
|
|
|
|
'will cease to function. This operation can not be undone.'))
|
2013-11-20 18:13:35 +01:00
|
|
|
->addSubmitButton(pht('Destroy Credential'))
|
|
|
|
->addCancelButton($view_uri);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|