mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-18 10:41:08 +01:00
Add a credential selection control to Passphrase
Summary: Ref T4122. Adds a control for choosing credentials. Test Plan: See screenshots. Reviewers: btrahan Reviewed By: btrahan CC: aran, lsave Maniphest Tasks: T4122 Differential Revision: https://secure.phabricator.com/D7617
This commit is contained in:
parent
7b718bb033
commit
8f715d8edf
6 changed files with 185 additions and 9 deletions
|
@ -1980,6 +1980,20 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'disk' => '/rsrc/js/application/owners/owners-path-editor.js',
|
'disk' => '/rsrc/js/application/owners/owners-path-editor.js',
|
||||||
),
|
),
|
||||||
|
'javelin-behavior-passphrase-credential-control' =>
|
||||||
|
array(
|
||||||
|
'uri' => '/res/b599c028/rsrc/js/application/passphrase/phame-credential-control.js',
|
||||||
|
'type' => 'js',
|
||||||
|
'requires' =>
|
||||||
|
array(
|
||||||
|
0 => 'javelin-behavior',
|
||||||
|
1 => 'javelin-dom',
|
||||||
|
2 => 'javelin-stratcom',
|
||||||
|
3 => 'javelin-workflow',
|
||||||
|
4 => 'javelin-util',
|
||||||
|
),
|
||||||
|
'disk' => '/rsrc/js/application/passphrase/phame-credential-control.js',
|
||||||
|
),
|
||||||
'javelin-behavior-persona-login' =>
|
'javelin-behavior-persona-login' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/128fdf56/rsrc/js/application/auth/behavior-persona-login.js',
|
'uri' => '/res/128fdf56/rsrc/js/application/auth/behavior-persona-login.js',
|
||||||
|
|
|
@ -946,6 +946,7 @@ phutil_register_library_map(array(
|
||||||
'PackageModifyMail' => 'applications/owners/mail/PackageModifyMail.php',
|
'PackageModifyMail' => 'applications/owners/mail/PackageModifyMail.php',
|
||||||
'PassphraseController' => 'applications/passphrase/controller/PassphraseController.php',
|
'PassphraseController' => 'applications/passphrase/controller/PassphraseController.php',
|
||||||
'PassphraseCredential' => 'applications/passphrase/storage/PassphraseCredential.php',
|
'PassphraseCredential' => 'applications/passphrase/storage/PassphraseCredential.php',
|
||||||
|
'PassphraseCredentialControl' => 'applications/passphrase/view/PassphraseCredentialControl.php',
|
||||||
'PassphraseCredentialCreateController' => 'applications/passphrase/controller/PassphraseCredentialCreateController.php',
|
'PassphraseCredentialCreateController' => 'applications/passphrase/controller/PassphraseCredentialCreateController.php',
|
||||||
'PassphraseCredentialDestroyController' => 'applications/passphrase/controller/PassphraseCredentialDestroyController.php',
|
'PassphraseCredentialDestroyController' => 'applications/passphrase/controller/PassphraseCredentialDestroyController.php',
|
||||||
'PassphraseCredentialEditController' => 'applications/passphrase/controller/PassphraseCredentialEditController.php',
|
'PassphraseCredentialEditController' => 'applications/passphrase/controller/PassphraseCredentialEditController.php',
|
||||||
|
@ -3329,6 +3330,7 @@ phutil_register_library_map(array(
|
||||||
0 => 'PassphraseDAO',
|
0 => 'PassphraseDAO',
|
||||||
1 => 'PhabricatorPolicyInterface',
|
1 => 'PhabricatorPolicyInterface',
|
||||||
),
|
),
|
||||||
|
'PassphraseCredentialControl' => 'AphrontFormControl',
|
||||||
'PassphraseCredentialCreateController' => 'PassphraseController',
|
'PassphraseCredentialCreateController' => 'PassphraseController',
|
||||||
'PassphraseCredentialDestroyController' => 'PassphraseController',
|
'PassphraseCredentialDestroyController' => 'PassphraseController',
|
||||||
'PassphraseCredentialEditController' => 'PassphraseController',
|
'PassphraseCredentialEditController' => 'PassphraseController',
|
||||||
|
|
|
@ -129,8 +129,16 @@ final class PassphraseCredentialEditController extends PassphraseController {
|
||||||
|
|
||||||
$credential->saveTransaction();
|
$credential->saveTransaction();
|
||||||
|
|
||||||
return id(new AphrontRedirectResponse())
|
if ($request->isAjax()) {
|
||||||
->setURI('/K'.$credential->getID());
|
return id(new AphrontAjaxResponse())->setContent(
|
||||||
|
array(
|
||||||
|
'phid' => $credential->getPHID(),
|
||||||
|
'name' => 'K'.$credential->getID().' '.$credential->getName(),
|
||||||
|
));
|
||||||
|
} else {
|
||||||
|
return id(new AphrontRedirectResponse())
|
||||||
|
->setURI('/K'.$credential->getID());
|
||||||
|
}
|
||||||
} catch (PhabricatorApplicationTransactionValidationException $ex) {
|
} catch (PhabricatorApplicationTransactionValidationException $ex) {
|
||||||
$credential->killTransaction();
|
$credential->killTransaction();
|
||||||
|
|
||||||
|
@ -151,8 +159,14 @@ final class PassphraseCredentialEditController extends PassphraseController {
|
||||||
|
|
||||||
$secret_control = $type->newSecretControl();
|
$secret_control = $type->newSecretControl();
|
||||||
|
|
||||||
$form = id(new AphrontFormView())
|
if ($request->isAjax()) {
|
||||||
->setUser($viewer)
|
$form = new PHUIFormLayoutView();
|
||||||
|
} else {
|
||||||
|
$form = id(new AphrontFormView())
|
||||||
|
->setUser($viewer);
|
||||||
|
}
|
||||||
|
|
||||||
|
$form
|
||||||
->appendChild(
|
->appendChild(
|
||||||
id(new AphrontFormTextControl())
|
id(new AphrontFormTextControl())
|
||||||
->setName('name')
|
->setName('name')
|
||||||
|
@ -197,11 +211,6 @@ final class PassphraseCredentialEditController extends PassphraseController {
|
||||||
->setLabel($type->getSecretLabel())
|
->setLabel($type->getSecretLabel())
|
||||||
->setValue($v_secret));
|
->setValue($v_secret));
|
||||||
|
|
||||||
$form->appendChild(
|
|
||||||
id(new AphrontFormSubmitControl())
|
|
||||||
->setValue(pht('Save'))
|
|
||||||
->addCancelButton($this->getApplicationURI()));
|
|
||||||
|
|
||||||
$crumbs = $this->buildApplicationCrumbs();
|
$crumbs = $this->buildApplicationCrumbs();
|
||||||
|
|
||||||
if ($is_new) {
|
if ($is_new) {
|
||||||
|
@ -222,6 +231,23 @@ final class PassphraseCredentialEditController extends PassphraseController {
|
||||||
->setName(pht('Edit')));
|
->setName(pht('Edit')));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($request->isAjax()) {
|
||||||
|
$dialog = id(new AphrontDialogView())
|
||||||
|
->setUser($viewer)
|
||||||
|
->setWidth(AphrontDialogView::WIDTH_FORM)
|
||||||
|
->setTitle($title)
|
||||||
|
->appendChild($form)
|
||||||
|
->addSubmitButton(pht('Create Credential'))
|
||||||
|
->addCancelButton($this->getApplicationURI());
|
||||||
|
|
||||||
|
return id(new AphrontDialogResponse())->setDialog($dialog);
|
||||||
|
}
|
||||||
|
|
||||||
|
$form->appendChild(
|
||||||
|
id(new AphrontFormSubmitControl())
|
||||||
|
->setValue(pht('Save'))
|
||||||
|
->addCancelButton($this->getApplicationURI()));
|
||||||
|
|
||||||
$box = id(new PHUIObjectBoxView())
|
$box = id(new PHUIObjectBoxView())
|
||||||
->setHeaderText($header)
|
->setHeaderText($header)
|
||||||
->setValidationException($validation_exception)
|
->setValidationException($validation_exception)
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PassphraseCredentialControl extends AphrontFormControl {
|
||||||
|
|
||||||
|
private $options;
|
||||||
|
private $credentialType;
|
||||||
|
|
||||||
|
public function setCredentialType($credential_type) {
|
||||||
|
$this->credentialType = $credential_type;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getCredentialType() {
|
||||||
|
return $this->credentialType;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setOptions(array $options) {
|
||||||
|
assert_instances_of($options, 'PassphraseCredential');
|
||||||
|
$this->options = $options;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getCustomControlClass() {
|
||||||
|
return 'passphrase-credential-control';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function renderInput() {
|
||||||
|
|
||||||
|
$options_map = array();
|
||||||
|
foreach ($this->options as $option) {
|
||||||
|
$options_map[$option->getPHID()] = pht(
|
||||||
|
"%s %s",
|
||||||
|
'K'.$option->getID(),
|
||||||
|
$option->getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
$disabled = $this->getDisabled();
|
||||||
|
if (!$options_map) {
|
||||||
|
$options_map[''] = pht('(No Existing Credentials)');
|
||||||
|
$disabled = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
Javelin::initBehavior('passphrase-credential-control');
|
||||||
|
|
||||||
|
$options = AphrontFormSelectControl::renderSelectTag(
|
||||||
|
$this->getValue(),
|
||||||
|
$options_map,
|
||||||
|
array(
|
||||||
|
'id' => $this->getControlID(),
|
||||||
|
'name' => $this->getName(),
|
||||||
|
'disabled' => $disabled ? 'disabled' : null,
|
||||||
|
'sigil' => 'passphrase-credential-select',
|
||||||
|
));
|
||||||
|
|
||||||
|
$button = javelin_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => '#',
|
||||||
|
'class' => 'button grey',
|
||||||
|
'sigil' => 'passphrase-credential-add',
|
||||||
|
'mustcapture' => true,
|
||||||
|
),
|
||||||
|
pht('Add Credential'));
|
||||||
|
|
||||||
|
return javelin_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'sigil' => 'passphrase-credential-control',
|
||||||
|
'meta' => array(
|
||||||
|
'type' => $this->getCredentialType(),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
$options,
|
||||||
|
$button,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -38,11 +38,22 @@ final class PhabricatorFormExample extends PhabricatorUIExample {
|
||||||
$null_value = $null_time->readValueFromRequest($request);
|
$null_value = $null_time->readValueFromRequest($request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$divider_control = new AphrontFormDividerControl();
|
||||||
|
|
||||||
|
$credentials = array();
|
||||||
|
$password_control = id(new PassphraseCredentialControl())
|
||||||
|
->setName('credentialPHID')
|
||||||
|
->setLabel(pht('Password'))
|
||||||
|
->setCredentialType('password')
|
||||||
|
->setOptions($credentials);
|
||||||
|
|
||||||
$form = id(new AphrontFormView())
|
$form = id(new AphrontFormView())
|
||||||
->setUser($user)
|
->setUser($user)
|
||||||
->appendChild($start_time)
|
->appendChild($start_time)
|
||||||
->appendChild($end_time)
|
->appendChild($end_time)
|
||||||
->appendChild($null_time)
|
->appendChild($null_time)
|
||||||
|
->appendChild($divider_control)
|
||||||
|
->appendChild($password_control)
|
||||||
->appendChild(
|
->appendChild(
|
||||||
id(new AphrontFormSubmitControl())
|
id(new AphrontFormSubmitControl())
|
||||||
->setValue('Submit'));
|
->setValue('Submit'));
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
/**
|
||||||
|
* @provides javelin-behavior-passphrase-credential-control
|
||||||
|
* @requires javelin-behavior
|
||||||
|
* javelin-dom
|
||||||
|
* javelin-stratcom
|
||||||
|
* javelin-workflow
|
||||||
|
* javelin-util
|
||||||
|
*/
|
||||||
|
|
||||||
|
JX.behavior('passphrase-credential-control', function(config) {
|
||||||
|
|
||||||
|
JX.Stratcom.listen(
|
||||||
|
'click',
|
||||||
|
'passphrase-credential-add',
|
||||||
|
function(e) {
|
||||||
|
var control = e.getNode('passphrase-credential-control');
|
||||||
|
var data = e.getNodeData('passphrase-credential-control');
|
||||||
|
|
||||||
|
new JX.Workflow('/passphrase/edit/?type=' + data.type)
|
||||||
|
.setHandler(JX.bind(null, onadd, control))
|
||||||
|
.start();
|
||||||
|
|
||||||
|
e.kill();
|
||||||
|
});
|
||||||
|
|
||||||
|
function onadd(control, response) {
|
||||||
|
var select = JX.DOM.find(control, 'select', 'passphrase-credential-select');
|
||||||
|
|
||||||
|
for (var ii = 0; ii < select.options.length; ii++) {
|
||||||
|
if (!select.options[ii].value) {
|
||||||
|
select.remove(ii);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
select.add(
|
||||||
|
JX.$N('option', {value: response.phid}, response.name),
|
||||||
|
select.options[0] || null);
|
||||||
|
|
||||||
|
select.value = response.phid;
|
||||||
|
select.disabled = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
Loading…
Reference in a new issue