SOAP API: do not try to unserialize an invalid filter
[mantis.git] / manage_proj_ver_add.php
blob9bda0774eb0fca4ddc69d5f23995dd0aa30f77be
1 <?php
2 # MantisBT - A PHP based bugtracking system
4 # MantisBT is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU General Public License as published by
6 # the Free Software Foundation, either version 2 of the License, or
7 # (at your option) any later version.
9 # MantisBT is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
14 # You should have received a copy of the GNU General Public License
15 # along with MantisBT. If not, see <http://www.gnu.org/licenses/>.
17 /**
18 * @package MantisBT
19 * @copyright Copyright (C) 2000 - 2002 Kenzaburo Ito - kenito@300baud.org
20 * @copyright Copyright (C) 2002 - 2011 MantisBT Team - mantisbt-dev@lists.sourceforge.net
21 * @link http://www.mantisbt.org
23 * @uses core.php
24 * @uses access_api.php
25 * @uses authentication_api.php
26 * @uses config_api.php
27 * @uses constant_inc.php
28 * @uses event_api.php
29 * @uses form_api.php
30 * @uses gpc_api.php
31 * @uses html_api.php
32 * @uses lang_api.php
33 * @uses print_api.php
34 * @uses utility_api.php
35 * @uses version_api.php
38 /**
39 * MantisBT Core API's
41 require_once( 'core.php' );
42 require_api( 'access_api.php' );
43 require_api( 'authentication_api.php' );
44 require_api( 'config_api.php' );
45 require_api( 'constant_inc.php' );
46 require_api( 'event_api.php' );
47 require_api( 'form_api.php' );
48 require_api( 'gpc_api.php' );
49 require_api( 'html_api.php' );
50 require_api( 'lang_api.php' );
51 require_api( 'print_api.php' );
52 require_api( 'utility_api.php' );
53 require_api( 'version_api.php' );
55 form_security_validate( 'manage_proj_ver_add' );
57 auth_reauthenticate();
59 $f_project_id = gpc_get_int( 'project_id' );
60 $f_version = gpc_get_string( 'version' );
61 $f_add_and_edit = gpc_get_bool( 'add_and_edit_version' );
63 access_ensure_project_level( config_get( 'manage_project_threshold' ), $f_project_id );
65 if ( is_blank( $f_version ) ) {
66 trigger_error( ERROR_EMPTY_FIELD, ERROR );
69 # We reverse the array so that if the user enters multiple versions
70 # they will likely appear with the last item entered at the top of the list
71 # (i.e. in reverse chronological order). Unless we find a way to make the
72 # date_order fields different for each one, however, this is fragile, since
73 # the DB may actually pull the rows out in any order
74 $t_versions = array_reverse( explode( '|', $f_version ) );
75 $t_version_count = count( $t_versions );
77 foreach ( $t_versions as $t_version ) {
78 if ( is_blank( $t_version ) ) {
79 continue;
82 $t_version = trim( $t_version );
83 if ( version_is_unique( $t_version, $f_project_id ) ) {
84 $t_version_id = version_add( $f_project_id, $t_version );
85 event_signal( 'EVENT_MANAGE_VERSION_CREATE', array( $t_version_id ) );
86 } else if ( 1 == $t_version_count ) {
87 # We only error out on duplicates when a single value was
88 # given. If multiple values were given, we just add the
89 # ones we can. The others already exist so it isn't really
90 # an error.
92 trigger_error( ERROR_VERSION_DUPLICATE, ERROR );
96 form_security_purge( 'manage_proj_ver_add' );
98 if ( true == $f_add_and_edit ) {
99 $t_redirect_url = 'manage_proj_ver_edit_page.php?version_id='.$t_version_id;
100 } else {
101 $t_redirect_url = 'manage_proj_edit_page.php?project_id=' .$f_project_id;
104 html_page_top( null, $t_redirect_url );
107 <br />
108 <div>
109 <?php
110 echo lang_get( 'operation_successful' ) . '<br />';
112 print_bracket_link( $t_redirect_url, lang_get( 'proceed' ) );
114 </div>
116 <?php
117 html_page_bottom();