. /** * This page updates the users profile information then redirects to * account_prof_menu_page.php * @package MantisBT * @copyright Copyright (C) 2000 - 2002 Kenzaburo Ito - kenito@300baud.org * @copyright Copyright (C) 2002 - 2014 MantisBT Team - mantisbt-dev@lists.sourceforge.net * @link http://www.mantisbt.org */ /** * MantisBT Core API's */ require_once( 'core.php' ); require_once( 'profile_api.php' ); form_security_validate('profile_update'); auth_ensure_user_authenticated(); current_user_ensure_unprotected(); $f_action = gpc_get_string('action'); if( $f_action != 'add') { $f_profile_id = gpc_get_int( 'profile_id' ); # Make sure user did select an existing profile from the list if( $f_action != 'make_default' && $f_profile_id == 0 ) { error_parameters( lang_get( 'select_profile' ) ); trigger_error( ERROR_EMPTY_FIELD, ERROR ); } } switch ( $f_action ) { case 'edit': form_security_purge('profile_update'); print_header_redirect( 'account_prof_edit_page.php?profile_id=' . $f_profile_id ); break; case 'add': $f_platform = gpc_get_string( 'platform' ); $f_os = gpc_get_string( 'os' ); $f_os_build = gpc_get_string( 'os_build' ); $f_description = gpc_get_string( 'description' ); $t_user_id = gpc_get_int( 'user_id' ); if ( ALL_USERS != $t_user_id ) { $t_user_id = auth_get_current_user_id(); } if ( ALL_USERS == $t_user_id ) { access_ensure_global_level( config_get( 'manage_global_profile_threshold' ) ); } else { access_ensure_global_level( config_get( 'add_profile_threshold' ) ); } profile_create( $t_user_id, $f_platform, $f_os, $f_os_build, $f_description ); form_security_purge('profile_update'); if ( ALL_USERS == $t_user_id ) { print_header_redirect( 'manage_prof_menu_page.php' ); } else { print_header_redirect( 'account_prof_menu_page.php' ); } break; case 'update': $f_platform = gpc_get_string( 'platform' ); $f_os = gpc_get_string( 'os' ); $f_os_build = gpc_get_string( 'os_build' ); $f_description = gpc_get_string( 'description' ); if ( profile_is_global( $f_profile_id ) ) { access_ensure_global_level( config_get( 'manage_global_profile_threshold' ) ); profile_update( ALL_USERS, $f_profile_id, $f_platform, $f_os, $f_os_build, $f_description ); form_security_purge('profile_update'); print_header_redirect( 'manage_prof_menu_page.php' ); } else { profile_update( auth_get_current_user_id(), $f_profile_id, $f_platform, $f_os, $f_os_build, $f_description ); form_security_purge('profile_update'); print_header_redirect( 'account_prof_menu_page.php' ); } break; case 'delete': if ( profile_is_global( $f_profile_id ) ) { access_ensure_global_level( config_get( 'manage_global_profile_threshold' ) ); profile_delete( ALL_USERS, $f_profile_id ); form_security_purge('profile_update'); print_header_redirect( 'manage_prof_menu_page.php' ); } else { profile_delete( auth_get_current_user_id(), $f_profile_id ); form_security_purge('profile_update'); print_header_redirect( 'account_prof_menu_page.php' ); } break; case 'make_default': current_user_set_pref( 'default_profile', $f_profile_id ); form_security_purge('profile_update'); print_header_redirect( 'account_prof_menu_page.php' ); break; }