Page MenuHomePhabricator

D15959.id38424.diff
No OneTemporary

D15959.id38424.diff

diff --git a/src/__phutil_library_map__.php b/src/__phutil_library_map__.php
--- a/src/__phutil_library_map__.php
+++ b/src/__phutil_library_map__.php
@@ -4134,6 +4134,7 @@
'UserEnableConduitAPIMethod' => 'applications/people/conduit/UserEnableConduitAPIMethod.php',
'UserFindConduitAPIMethod' => 'applications/people/conduit/UserFindConduitAPIMethod.php',
'UserQueryConduitAPIMethod' => 'applications/people/conduit/UserQueryConduitAPIMethod.php',
+ 'UserSearchConduitAPIMethod' => 'applications/people/conduit/UserSearchConduitAPIMethod.php',
'UserWhoAmIConduitAPIMethod' => 'applications/people/conduit/UserWhoAmIConduitAPIMethod.php',
),
'function' => array(
@@ -8311,6 +8312,7 @@
'PhabricatorFlaggableInterface',
'PhabricatorApplicationTransactionInterface',
'PhabricatorFulltextInterface',
+ 'PhabricatorConduitResultInterface',
),
'PhabricatorUserBlurbField' => 'PhabricatorUserCustomField',
'PhabricatorUserCardView' => 'AphrontTagView',
@@ -9026,6 +9028,7 @@
'UserEnableConduitAPIMethod' => 'UserConduitAPIMethod',
'UserFindConduitAPIMethod' => 'UserConduitAPIMethod',
'UserQueryConduitAPIMethod' => 'UserConduitAPIMethod',
+ 'UserSearchConduitAPIMethod' => 'PhabricatorSearchEngineAPIMethod',
'UserWhoAmIConduitAPIMethod' => 'UserConduitAPIMethod',
),
));
diff --git a/src/applications/people/conduit/UserSearchConduitAPIMethod.php b/src/applications/people/conduit/UserSearchConduitAPIMethod.php
new file mode 100644
--- /dev/null
+++ b/src/applications/people/conduit/UserSearchConduitAPIMethod.php
@@ -0,0 +1,18 @@
+<?php
+
+final class UserSearchConduitAPIMethod
+ extends PhabricatorSearchEngineAPIMethod {
+
+ public function getAPIMethodName() {
+ return 'user.search';
+ }
+
+ public function newSearchEngine() {
+ return new PhabricatorPeopleSearchEngine();
+ }
+
+ public function getMethodSummary() {
+ return pht('Read information about users.');
+ }
+
+}
diff --git a/src/applications/people/query/PhabricatorPeopleSearchEngine.php b/src/applications/people/query/PhabricatorPeopleSearchEngine.php
--- a/src/applications/people/query/PhabricatorPeopleSearchEngine.php
+++ b/src/applications/people/query/PhabricatorPeopleSearchEngine.php
@@ -22,51 +22,79 @@
id(new PhabricatorSearchStringListField())
->setLabel(pht('Usernames'))
->setKey('usernames')
- ->setAliases(array('username')),
+ ->setAliases(array('username'))
+ ->setDescription(pht('Find users by exact username.')),
id(new PhabricatorSearchTextField())
->setLabel(pht('Name Contains'))
- ->setKey('nameLike'),
+ ->setKey('nameLike')
+ ->setDescription(
+ pht('Find users whose usernames contain a substring.')),
id(new PhabricatorSearchThreeStateField())
->setLabel(pht('Administrators'))
->setKey('isAdmin')
->setOptions(
pht('(Show All)'),
pht('Show Only Administrators'),
- pht('Hide Administrators')),
+ pht('Hide Administrators'))
+ ->setDescription(
+ pht(
+ 'Pass true to find only administrators, or false to omit '.
+ 'administrators.')),
id(new PhabricatorSearchThreeStateField())
->setLabel(pht('Disabled'))
->setKey('isDisabled')
->setOptions(
pht('(Show All)'),
pht('Show Only Disabled Users'),
- pht('Hide Disabled Users')),
+ pht('Hide Disabled Users'))
+ ->setDescription(
+ pht(
+ 'Pass true to find only disabled users, or false to omit '.
+ 'disabled users.')),
id(new PhabricatorSearchThreeStateField())
->setLabel(pht('Bots'))
- ->setKey('isSystemAgent')
+ ->setKey('isBot')
+ ->setAliases(array('isSystemAgent'))
->setOptions(
pht('(Show All)'),
pht('Show Only Bots'),
- pht('Hide Bots')),
+ pht('Hide Bots'))
+ ->setDescription(
+ pht(
+ 'Pass true to find only bots, or false to omit bots.')),
id(new PhabricatorSearchThreeStateField())
->setLabel(pht('Mailing Lists'))
->setKey('isMailingList')
->setOptions(
pht('(Show All)'),
pht('Show Only Mailing Lists'),
- pht('Hide Mailing Lists')),
+ pht('Hide Mailing Lists'))
+ ->setDescription(
+ pht(
+ 'Pass true to find only mailing lists, or false to omit '.
+ 'mailing lists.')),
id(new PhabricatorSearchThreeStateField())
->setLabel(pht('Needs Approval'))
->setKey('needsApproval')
->setOptions(
pht('(Show All)'),
pht('Show Only Unapproved Users'),
- pht('Hide Unappproved Users')),
+ pht('Hide Unappproved Users'))
+ ->setDescription(
+ pht(
+ 'Pass true to find only users awaiting administrative approval, '.
+ 'or false to omit these users.')),
id(new PhabricatorSearchDateField())
->setKey('createdStart')
- ->setLabel(pht('Joined After')),
+ ->setLabel(pht('Joined After'))
+ ->setDescription(
+ pht('Find user accounts created after a given time.')),
id(new PhabricatorSearchDateField())
->setKey('createdEnd')
- ->setLabel(pht('Joined Before')),
+ ->setLabel(pht('Joined Before'))
+ ->setDescription(
+ pht('Find user accounts created before a given time.')),
+
);
}
@@ -115,8 +143,8 @@
$query->withIsMailingList($map['isMailingList']);
}
- if ($map['isSystemAgent'] !== null) {
- $query->withIsSystemAgent($map['isSystemAgent']);
+ if ($map['isBot'] !== null) {
+ $query->withIsSystemAgent($map['isBot']);
}
if ($map['needsApproval'] !== null) {
diff --git a/src/applications/people/storage/PhabricatorUser.php b/src/applications/people/storage/PhabricatorUser.php
--- a/src/applications/people/storage/PhabricatorUser.php
+++ b/src/applications/people/storage/PhabricatorUser.php
@@ -16,7 +16,8 @@
PhabricatorSSHPublicKeyInterface,
PhabricatorFlaggableInterface,
PhabricatorApplicationTransactionInterface,
- PhabricatorFulltextInterface {
+ PhabricatorFulltextInterface,
+ PhabricatorConduitResultInterface {
const SESSION_TABLE = 'phabricator_session';
const NAMETOKEN_TABLE = 'user_nametoken';
@@ -1378,4 +1379,68 @@
return new PhabricatorUserFulltextEngine();
}
+
+/* -( PhabricatorConduitResultInterface )---------------------------------- */
+
+
+ public function getFieldSpecificationsForConduit() {
+ return array(
+ id(new PhabricatorConduitSearchFieldSpecification())
+ ->setKey('username')
+ ->setType('string')
+ ->setDescription(pht("The user's username.")),
+ id(new PhabricatorConduitSearchFieldSpecification())
+ ->setKey('realName')
+ ->setType('string')
+ ->setDescription(pht("The user's real name.")),
+ id(new PhabricatorConduitSearchFieldSpecification())
+ ->setKey('roles')
+ ->setType('list<string>')
+ ->setDescription(pht('List of acccount roles.')),
+ );
+ }
+
+ public function getFieldValuesForConduit() {
+ $roles = array();
+
+ if ($this->getIsDisabled()) {
+ $roles[] = 'disabled';
+ }
+
+ if ($this->getIsSystemAgent()) {
+ $roles[] = 'bot';
+ }
+
+ if ($this->getIsMailingList()) {
+ $roles[] = 'list';
+ }
+
+ if ($this->getIsAdmin()) {
+ $roles[] = 'admin';
+ }
+
+ if ($this->getIsEmailVerified()) {
+ $roles[] = 'verified';
+ }
+
+ if ($this->getIsApproved()) {
+ $roles[] = 'approved';
+ }
+
+ if ($this->isUserActivated()) {
+ $roles[] = 'activated';
+ }
+
+ return array(
+ 'username' => $this->getUsername(),
+ 'realName' => $this->getRealName(),
+ 'roles' => $roles,
+ );
+ }
+
+ public function getConduitSearchAttachments() {
+ return array();
+ }
+
+
}
diff --git a/src/applications/search/engine/PhabricatorSearchEngineAPIMethod.php b/src/applications/search/engine/PhabricatorSearchEngineAPIMethod.php
--- a/src/applications/search/engine/PhabricatorSearchEngineAPIMethod.php
+++ b/src/applications/search/engine/PhabricatorSearchEngineAPIMethod.php
@@ -501,6 +501,7 @@
}
$table = id(new AphrontTableView($rows))
+ ->setNoDataString(pht('This call does not support any attachments.'))
->setHeaders(
array(
pht('Key'),
diff --git a/src/applications/search/field/PhabricatorSearchThreeStateField.php b/src/applications/search/field/PhabricatorSearchThreeStateField.php
--- a/src/applications/search/field/PhabricatorSearchThreeStateField.php
+++ b/src/applications/search/field/PhabricatorSearchThreeStateField.php
@@ -45,4 +45,8 @@
return null;
}
+ protected function newConduitParameterType() {
+ return new ConduitBoolParameterType();
+ }
+
}

File Metadata

Mime Type
text/plain
Expires
Fri, Mar 21, 1:34 PM (1 w, 6 d ago)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
7715511
Default Alt Text
D15959.id38424.diff (8 KB)

Event Timeline