Exemplo n.º 1
0
 /**
  * @param string $get_array
  * @throws SampleIDMissingException
  */
 public static function get_sample_menu($get_array)
 {
     global $user;
     if ($get_array) {
         $_GET = unserialize($get_array);
     }
     if ($_GET['sample_id']) {
         $sample_security = new SampleSecurity($_GET['sample_id']);
         if ($sample_security->is_access(1, false)) {
             $sample = new Sample($_GET['sample_id']);
             $template = new HTMLTemplate("sample/ajax/detail_menu.html");
             if ($sample->get_availability() == true) {
                 $template->set_var("new_status", "not available");
             } else {
                 $template->set_var("new_status", "available");
             }
             if ($sample->get_owner_id() == $user->get_user_id() or $user->is_admin() == true) {
                 $template->set_var("is_owner", true);
             } else {
                 $template->set_var("is_owner", false);
             }
             if ($user->is_admin() == true) {
                 $template->set_var("is_admin", true);
             } else {
                 $template->set_var("is_admin", false);
             }
             if ($sample_security->is_access(2)) {
                 $sample_template = new SampleTemplate($sample->get_template_id());
                 $current_requirements = $sample->get_requirements();
                 $result = array();
                 $counter = 0;
                 if (is_array($current_requirements) and count($current_requirements) >= 1) {
                     foreach ($current_requirements as $key => $value) {
                         switch ($value['element_type']) {
                             case "item":
                                 $paramquery = array();
                                 $paramquery['username'] = $_GET['username'];
                                 $paramquery['session_id'] = $_GET['session_id'];
                                 $paramquery['nav'] = "sample";
                                 $paramquery['sample_id'] = $_GET['sample_id'];
                                 require_once "core/modules/item/common/item_common.io.php";
                                 $menu_element_array = ItemCommonIO::get_menu_element($value, $key, $counter, $paramquery, "Sample", $_GET['sample_id']);
                                 $result = array_merge($result, $menu_element_array[0]);
                                 $counter = $menu_element_array[1];
                                 break;
                             case "extension":
                                 // Extension implementation in Sample
                                 break;
                         }
                     }
                 }
                 $template->set_var("action", $result);
             } else {
                 $template->set_var("action", "");
             }
             $move_paramquery = $_GET;
             $move_paramquery['run'] = "move";
             unset($move_paramquery['nextpage']);
             $move_params = http_build_query($move_paramquery, '', '&');
             $template->set_var("move_params", $move_params);
             $availability_paramquery = $_GET;
             $availability_paramquery['run'] = "set_availability";
             unset($availability_paramquery['nextpage']);
             $availability_params = http_build_query($availability_paramquery, '', '&');
             $template->set_var("availability_params", $availability_params);
             $rename_paramquery = $_GET;
             $rename_paramquery['run'] = "rename";
             unset($rename_paramquery['nextpage']);
             $rename_params = http_build_query($rename_paramquery, '', '&');
             $template->set_var("rename_params", $rename_params);
             $user_permissions_paramquery = $_GET;
             $user_permissions_paramquery['run'] = "admin_permission_user";
             unset($user_permissions_paramquery['nextpage']);
             $user_permissions_params = http_build_query($user_permissions_paramquery, '', '&');
             $template->set_var("user_permissions_params", $user_permissions_params);
             $ou_permissions_paramquery = $_GET;
             $ou_permissions_paramquery['run'] = "admin_permission_ou";
             unset($ou_permissions_paramquery['nextpage']);
             $ou_permissions_params = http_build_query($ou_permissions_paramquery, '', '&');
             $template->set_var("ou_permissions_params", $ou_permissions_params);
             $delete_paramquery = $_GET;
             $delete_paramquery['run'] = "delete";
             unset($delete_paramquery['nextpage']);
             $delete_params = http_build_query($delete_paramquery, '', '&');
             $template->set_var("delete_params", $delete_params);
             $add_subsample_paramquery = $_GET;
             $add_subsample_paramquery['run'] = "new_subsample";
             unset($add_subsample_paramquery['nextpage']);
             $add_subsample_params = http_build_query($add_subsample_paramquery, '', '&');
             $template->set_var("add_subsample_params", $add_subsample_params);
             $template->output();
         }
     } else {
         throw new SampleIDMissingException();
     }
 }
Exemplo n.º 2
0
 /**
  * @param string $role
  * @throws ItemParentIDMissingException
  * @throws ItemPositionIDMissingException
  * @throws BaseModuleDialogMethodNotFoundException
  * @throws BaseModuleDialogClassNotFoundException
  * @throws BaseModuleDialogFileNotFoundException
  * @throws BaseModuleDialogNotFoundException
  * @throws SampleSecurityAccessDeniedException
  * @throws BaseModuleDialogMissingException
  */
 public static function item_add_edit_handler($role = "add")
 {
     if ($_GET['dialog']) {
         if (!is_numeric($_GET['parent_id'])) {
             throw new ItemParentIDMissingException();
         }
         if (!is_numeric($_GET['key'])) {
             throw new ItemPositionIDMissingException();
         }
         $sample = new Sample($_GET['parent_id']);
         $sample_security = new SampleSecurity($_GET['parent_id']);
         if ($sample_security->is_access(2, false) == true) {
             if ($role == "add") {
                 $module_dialog = ModuleDialog::get_by_type_and_internal_name("item_add", $_GET['dialog']);
             } elseif ($role == "edit") {
                 $module_dialog = ModuleDialog::get_by_type_and_internal_name("item_edit", $_GET['dialog']);
             }
             if (is_array($module_dialog) and $module_dialog['class_path']) {
                 if (file_exists($module_dialog['class_path'])) {
                     require_once $module_dialog['class_path'];
                     if (class_exists($module_dialog['class'])) {
                         if (method_exists($module_dialog['class'], $module_dialog['method'])) {
                             $sample_item = new SampleItem($_GET['parent_id']);
                             $sample_item->set_gid($_GET['key']);
                             $current_requirements = $sample->get_requirements();
                             if ($role == "add") {
                                 $module_dialog['class']::$module_dialog['method']($current_requirements[$_GET['key']]['type_id'], $current_requirements[$_GET['key']]['category_id'], "Sample", $_GET['parent_id'], $_GET['key']);
                             } elseif ($role == "edit") {
                                 $module_dialog['class']::$module_dialog['method']($current_requirements[$_GET['key']]['fulfilled'][0]['item_id']);
                             }
                         } else {
                             throw new BaseModuleDialogMethodNotFoundException();
                         }
                     } else {
                         throw new BaseModuleDialogClassNotFoundException();
                     }
                 } else {
                     throw new BaseModuleDialogFileNotFoundException();
                 }
             } else {
                 throw new BaseModuleDialogNotFoundException();
             }
         } else {
             throw new SampleSecurityAccessDeniedException();
         }
     } else {
         throw new BaseModuleDialogMissingException();
     }
 }