mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-14 10:52:41 +01:00
023dee0d3b
Summary: Ref T5655. Rename Conduit classes and provide a `getAPIMethodName` method to declare the API method. Test Plan: ``` > echo '{}' | arc --conduit-uri='http://phabricator.joshuaspence.com' call-conduit user.whoami Waiting for JSON parameters on stdin... {"error":null,"errorMessage":null,"response":{"phid":"PHID-USER-lioqffnwn6y475mu5ndb","userName":"josh","realName":"Joshua Spence","image":"http:\/\/phabricator.joshuaspence.com\/res\/1404425321T\/phabricator\/3eb28cd9\/rsrc\/image\/avatar.png","uri":"http:\/\/phabricator.joshuaspence.com\/p\/josh\/","roles":["admin","verified","approved","activated"]}} ``` Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: epriestley, Korvin, hach-que Maniphest Tasks: T5655 Differential Revision: https://secure.phabricator.com/D9991
108 lines
2.6 KiB
PHP
108 lines
2.6 KiB
PHP
<?php
|
|
|
|
final class PhameQueryPostsConduitAPIMethod extends PhameConduitAPIMethod {
|
|
|
|
public function getAPIMethodName() {
|
|
return 'phame.queryposts';
|
|
}
|
|
|
|
public function getMethodDescription() {
|
|
return 'Query phame posts.';
|
|
}
|
|
|
|
public function getMethodStatus() {
|
|
return self::METHOD_STATUS_UNSTABLE;
|
|
}
|
|
|
|
public function defineParamTypes() {
|
|
return array(
|
|
'ids' => 'optional list<int>',
|
|
'phids' => 'optional list<phid>',
|
|
'blogPHIDs' => 'optional list<phid>',
|
|
'bloggerPHIDs' => 'optional list<phid>',
|
|
'phameTitles' => 'optional list<string>',
|
|
'published' => 'optional bool',
|
|
'publishedAfter' => 'optional date',
|
|
'before' => 'optional int',
|
|
'after' => 'optional int',
|
|
'limit' => 'optional int',
|
|
);
|
|
}
|
|
|
|
public function defineReturnType() {
|
|
return 'list<dict>';
|
|
}
|
|
|
|
public function defineErrorTypes() {
|
|
return array(
|
|
);
|
|
}
|
|
|
|
protected function execute(ConduitAPIRequest $request) {
|
|
$query = new PhamePostQuery();
|
|
|
|
$query->setViewer($request->getUser());
|
|
|
|
$ids = $request->getValue('ids', array());
|
|
if ($ids) {
|
|
$query->withIDs($ids);
|
|
}
|
|
|
|
$phids = $request->getValue('phids', array());
|
|
if ($phids) {
|
|
$query->withPHIDs($phids);
|
|
}
|
|
|
|
$blog_phids = $request->getValue('blogPHIDs', array());
|
|
if ($blog_phids) {
|
|
$query->withBlogPHIDs($blog_phids);
|
|
}
|
|
|
|
$blogger_phids = $request->getValue('bloggerPHIDs', array());
|
|
if ($blogger_phids) {
|
|
$query->withBloggerPHIDs($blogger_phids);
|
|
}
|
|
|
|
$phame_titles = $request->getValue('phameTitles', array());
|
|
if ($phame_titles) {
|
|
$query->withPhameTitles($phame_titles);
|
|
}
|
|
|
|
$published = $request->getValue('published', null);
|
|
if ($published === true) {
|
|
$query->withVisibility(PhamePost::VISIBILITY_PUBLISHED);
|
|
} else if ($published === false) {
|
|
$query->withVisibility(PhamePost::VISIBILITY_DRAFT);
|
|
}
|
|
|
|
$published_after = $request->getValue('publishedAfter', null);
|
|
if ($published_after !== null) {
|
|
$query->withPublishedAfter($published_after);
|
|
}
|
|
|
|
$after = $request->getValue('after', null);
|
|
if ($after !== null) {
|
|
$query->setAfterID($after);
|
|
}
|
|
|
|
$before = $request->getValue('before', null);
|
|
if ($before !== null) {
|
|
$query->setBeforeID($before);
|
|
}
|
|
|
|
$limit = $request->getValue('limit', null);
|
|
if ($limit !== null) {
|
|
$query->setLimit($limit);
|
|
}
|
|
|
|
$posts = $query->execute();
|
|
|
|
$results = array();
|
|
foreach ($posts as $post) {
|
|
$results[] = $post->toDictionary();
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
}
|