2013-11-20 18:13:35 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PassphraseCredentialSearchEngine
|
|
|
|
extends PhabricatorApplicationSearchEngine {
|
|
|
|
|
2014-06-12 22:22:20 +02:00
|
|
|
public function getResultTypeDescription() {
|
|
|
|
return pht('Passphrase Credentials');
|
|
|
|
}
|
|
|
|
|
2014-05-09 21:25:52 +02:00
|
|
|
public function getApplicationClassName() {
|
2014-07-23 02:03:09 +02:00
|
|
|
return 'PhabricatorPassphraseApplication';
|
2014-05-09 21:25:52 +02:00
|
|
|
}
|
|
|
|
|
2013-11-20 18:13:35 +01:00
|
|
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
|
|
|
$saved = new PhabricatorSavedQuery();
|
|
|
|
|
|
|
|
$saved->setParameter(
|
|
|
|
'isDestroyed',
|
|
|
|
$this->readBoolFromRequest($request, 'isDestroyed'));
|
|
|
|
|
|
|
|
return $saved;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function buildQueryFromSavedQuery(PhabricatorSavedQuery $saved) {
|
|
|
|
$query = id(new PassphraseCredentialQuery());
|
|
|
|
|
|
|
|
$destroyed = $saved->getParameter('isDestroyed');
|
|
|
|
if ($destroyed !== null) {
|
|
|
|
$query->withIsDestroyed($destroyed);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $query;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function buildSearchForm(
|
|
|
|
AphrontFormView $form,
|
|
|
|
PhabricatorSavedQuery $saved_query) {
|
|
|
|
|
|
|
|
$form->appendChild(
|
|
|
|
id(new AphrontFormSelectControl())
|
|
|
|
->setName('isDestroyed')
|
|
|
|
->setLabel(pht('Status'))
|
|
|
|
->setValue($this->getBoolFromQuery($saved_query, 'isDestroyed'))
|
|
|
|
->setOptions(
|
|
|
|
array(
|
|
|
|
'' => pht('Show All Credentials'),
|
|
|
|
'false' => pht('Show Only Active Credentials'),
|
|
|
|
'true' => pht('Show Only Destroyed Credentials'),
|
|
|
|
)));
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getURI($path) {
|
|
|
|
return '/passphrase/'.$path;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getBuiltinQueryNames() {
|
2014-07-23 02:03:09 +02:00
|
|
|
return array(
|
2013-11-20 18:13:35 +01:00
|
|
|
'active' => pht('Active Credentials'),
|
|
|
|
'all' => pht('All Credentials'),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function buildSavedQueryFromBuiltin($query_key) {
|
|
|
|
$query = $this->newSavedQuery();
|
|
|
|
$query->setQueryKey($query_key);
|
|
|
|
|
|
|
|
switch ($query_key) {
|
|
|
|
case 'all':
|
|
|
|
return $query;
|
|
|
|
case 'active':
|
|
|
|
return $query->setParameter('isDestroyed', false);
|
|
|
|
}
|
|
|
|
|
|
|
|
return parent::buildSavedQueryFromBuiltin($query_key);
|
|
|
|
}
|
|
|
|
|
2014-05-09 21:25:52 +02:00
|
|
|
protected function renderResultList(
|
|
|
|
array $credentials,
|
|
|
|
PhabricatorSavedQuery $query,
|
|
|
|
array $handles) {
|
|
|
|
assert_instances_of($credentials, 'PassphraseCredential');
|
|
|
|
|
|
|
|
$viewer = $this->requireViewer();
|
|
|
|
|
|
|
|
$list = new PHUIObjectItemListView();
|
|
|
|
$list->setUser($viewer);
|
|
|
|
foreach ($credentials as $credential) {
|
|
|
|
|
|
|
|
$item = id(new PHUIObjectItemView())
|
|
|
|
->setObjectName('K'.$credential->getID())
|
|
|
|
->setHeader($credential->getName())
|
|
|
|
->setHref('/K'.$credential->getID())
|
|
|
|
->setObject($credential);
|
|
|
|
|
|
|
|
$item->addAttribute(
|
|
|
|
pht('Login: %s', $credential->getUsername()));
|
|
|
|
|
|
|
|
if ($credential->getIsDestroyed()) {
|
2014-05-19 01:10:54 +02:00
|
|
|
$item->addIcon('fa-ban', pht('Destroyed'));
|
2014-05-09 21:25:52 +02:00
|
|
|
$item->setDisabled(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
$type = PassphraseCredentialType::getTypeByConstant(
|
|
|
|
$credential->getCredentialType());
|
|
|
|
if ($type) {
|
2014-05-19 01:10:54 +02:00
|
|
|
$item->addIcon('fa-wrench', $type->getCredentialTypeName());
|
2014-05-09 21:25:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$list->addItem($item);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $list;
|
|
|
|
}
|
|
|
|
|
2013-11-20 18:13:35 +01:00
|
|
|
}
|