/
pages_rest.php
48 lines (41 loc) · 1.76 KB
/
pages_rest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<?php
# MantisBT - A PHP based bugtracking system
# MantisBT 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.
#
# MantisBT 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 MantisBT. If not, see <http://www.gnu.org/licenses/>.
/**
* A webservice interface to Mantis Bug Tracker
*
* @package MantisBT
* @copyright Copyright MantisBT Team - mantisbt-dev@lists.sourceforge.net
* @link http://www.mantisbt.org
*/
use Mantis\Exceptions\ClientException;
$g_app->group('/pages', function() use ( $g_app ) {
$g_app->get( '/issues/view/{id}/', 'rest_pages_issue_view' );
$g_app->get( '/issues/view/{id}', 'rest_pages_issue_view' );
});
/**
* Get information necessary about an issue to render an issue view page.
*
* @param \Slim\Http\Request $p_request The request.
* @param \Slim\Http\Response $p_response The response.
* @param array $p_args Arguments
* @return \Slim\Http\Response The augmented response.
*/
function rest_pages_issue_view( \Slim\Http\Request $p_request, \Slim\Http\Response $p_response, array $p_args ) {
$t_issue_id = isset( $p_args['id'] ) ? $p_args['id'] : $p_request->getParam( 'id' );
$t_data = array( 'query' => array( 'id' => $t_issue_id ) );
$t_command = new IssueViewPageCommand( $t_data );
$t_result = $t_command->execute();
return $p_response->withStatus( HTTP_STATUS_SUCCESS )->withJson( $t_result );
}