| <?php␊ |
| /* -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */␊ |
| /*␊ |
| # ***** BEGIN LICENSE BLOCK *****␊ |
| # This file is part of InDefero, an open source project management application.␊ |
| # Copyright (C) 2008 CĂ©ondo Ltd and contributors.␊ |
| #␊ |
| # InDefero is free software; you can redistribute it and/or modify␊ |
| # it under the terms of the GNU General Public License as published by␊ |
| # the Free Software Foundation; either version 2 of the License, or␊ |
| # (at your option) any later version.␊ |
| #␊ |
| # InDefero is distributed in the hope that it will be useful,␊ |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of␊ |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the␊ |
| # GNU General Public License for more details.␊ |
| #␊ |
| # You should have received a copy of the GNU General Public License␊ |
| # along with this program; if not, write to the Free Software␊ |
| # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA␊ |
| #␊ |
| # ***** END LICENSE BLOCK ***** */␊ |
| ␊ |
| /**␊ |
| * API views.␊ |
| *␊ |
| * These are just small wrappers around the "normal" views. The normal␊ |
| * views are called with a third parameters $api set to true to return␊ |
| * JSON instead of HTML.␊ |
| *␊ |
| * A special precondition is used to set the $request->user from the␊ |
| * _login, _hash and _salt parameters. ␊ |
| */␊ |
| class IDF_Views_Api␊ |
| {␊ |
| /**␊ |
| * View list of issues for a given project.␊ |
| */␊ |
| public $issuesIndex_precond = array('IDF_Precondition::apiSetUser',␊ |
| 'IDF_Precondition::accessIssues');␊ |
| public function issuesIndex($request, $match)␊ |
| {␊ |
| $views = new IDF_Views_Issue();␊ |
| $p = $views->index($request, $match, true);␊ |
| $out = array(␊ |
| 'project' => $request->project->shortname,␊ |
| 'open' => $p['open'],␊ |
| 'closed' => $p['closed'],␊ |
| 'issues' => $p['issues']->render_array(),␊ |
| );␊ |
| return new Pluf_HTTP_Response_Json($out);␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Create a new issue.␊ |
| */␊ |
| public $issueCreate_precond = array('IDF_Precondition::apiSetUser',␊ |
| 'IDF_Precondition::accessIssues');␊ |
| public function issueCreate($request, $match)␊ |
| {␊ |
| $views = new IDF_Views_Issue();␊ |
| $p = $views->create($request, $match, true);␊ |
| $out = array();␊ |
| if ($request->method == 'GET') {␊ |
| // We give the details of the form␊ |
| $out['doc'] = 'A POST request against this url will allow you to create a new issue.';␊ |
| if ($request->user->hasPerm('IDF.project-owner', $request->project)␊ |
| or $request->user->hasPerm('IDF.project-member', $request->project)) {␊ |
| $out['status'] = array();␊ |
| foreach (self::getTags($request->project) as $tag) {␊ |
| $out['status'][] = $tag->name;␊ |
| }␊ |
| }␊ |
| ␊ |
| } else {␊ |
| // We need to give back the results of the creation␊ |
| if (is_object($p) and 'IDF_Issue' == get_class($p)) {␊ |
| $out['mess'] = 'success';␊ |
| $out['issue'] = $p->id;␊ |
| } else {␊ |
| $out['mess'] = 'error';␊ |
| $out['errors'] = $p['form']->errors;␊ |
| }␊ |
| }␊ |
| return new Pluf_HTTP_Response_Json($out);␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Get the list of tags to give them to the end users when doing a␊ |
| * GET request against a form. That way it is possible for them to␊ |
| * know which tags/labels are available.␊ |
| *␊ |
| * @param IDF_Project Current project␊ |
| * @param string Which tags to get ('issue-open')␊ |
| * @return ArrayObject Tags␊ |
| */␊ |
| ␊ |
| public static function getTags($project, $what='issue-open')␊ |
| {␊ |
| switch ($what) {␊ |
| case 'issue-open':␊ |
| $key = 'labels_issue_open';␊ |
| $default = IDF_Form_IssueTrackingConf::init_open;␊ |
| return $project->getTagsFromConfig($key, $default);␊ |
| case 'issue-closed':␊ |
| return $project->getTagIdsByStatus('closed');␊ |
| }␊ |
| return array();␊ |
| }␊ |
| } |