module_srl]; if($check_flag == 'remove') unset($flag_list[$document_srl]); else $flag_list[$document_srl] = true; $_SESSION['document_management'][$this->module_srl] = $flag_list; } /** * @brief 세션에 담긴 선택글의 이동/ 삭제 **/ function procBoardAdminManageCheckedDocument() { $type = Context::get('type'); $module_srl = Context::get('target_board'); $message_content = Context::get('message_content'); if($message_content) $message_content = nl2br($message_content); $flag_list = $_SESSION['document_management'][$this->module_srl]; $document_srl_list = array_keys($flag_list); $document_srl_count = count($document_srl_list); // 쪽지 발송 if($message_content) { $oMemberController = &getController('member'); $oDocumentModel = &getModel('document'); $logged_info = Context::get('logged_info'); $title = cut_str($message_content,10,'...'); $sender_member_srl = $logged_info->member_srl; for($i=0;$i<$document_srl_count;$i++) { $document_srl = $document_srl_list[$i]; $oDocument = $oDocumentModel->getDocument($document_srl); if(!$oDocument->get('member_srl') || $oDocument->get('member_srl')==$sender_member_srl) continue; if($type=='move') $purl = sprintf("%s", $oDocument->getPermanentUrl(), $oDocument->getPermanentUrl()); else $purl = ""; $content .= sprintf("
%s

%s
%s
%s",$message_content, $purl, $oDocument->getTitleText(), $oDocument->getContent()); $oMemberController->sendMessage($sender_member_srl, $oDocument->get('member_srl'), $title, $content, false); } } if($type == 'move') { $oDocumentAdminController = &getAdminController('document'); if(!$module_srl) return new Object(-1, 'fail_to_move'); else { $output = $oDocumentAdminController->moveDocumentModule($document_srl_list, $module_srl, $this->module_srl); if(!$output->toBool()) return new Object(-1, 'fail_to_move'); $msg_code = 'success_moved'; $_SESSION['document_management'] = null; } } elseif($type =='delete') { $oDB = &DB::getInstance(); $oDB->begin(); $oDocumentController = &getController('document'); for($i=0;$i<$document_srl_count;$i++) { $document_srl = $document_srl_list[$i]; $output = $oDocumentController->deleteDocument($document_srl, true); if(!$output->toBool()) return new Object(-1, 'fail_to_delete'); } $oDB->commit(); $msg_code = 'success_deleted'; $_SESSION['document_management'] = null; } $this->setMessage($msg_code); } /** * @brief 권한 추가 **/ function procBoardAdminInsertGrant() { $module_srl = Context::get('module_srl'); // 현 모듈의 권한 목록을 가져옴 $grant_list = $this->xml_info->grant; if(count($grant_list)) { foreach($grant_list as $key => $val) { $group_srls = Context::get($key); if($group_srls) $arr_grant[$key] = explode('|@|',$group_srls); } $grants = serialize($arr_grant); } $oModuleController = &getController('module'); $oModuleController->updateModuleGrant($module_srl, $grants); $this->add('module_srl',Context::get('module_srl')); $this->setMessage('success_registed'); } /** * @brief 스킨 정보 업데이트 **/ function procBoardAdminUpdateSkinInfo() { // module_srl에 해당하는 정보들을 가져오기 $module_srl = Context::get('module_srl'); $oModuleModel = &getModel('module'); $module_info = $oModuleModel->getModuleInfoByModuleSrl($module_srl); $skin = $module_info->skin; // 스킨의 정보를 구해옴 (extra_vars를 체크하기 위해서) $skin_info = $oModuleModel->loadSkinInfo($this->module_path, $skin); // 입력받은 변수들을 체크 (mo, act, module_srl, page등 기본적인 변수들 없앰) $obj = Context::getRequestVars(); unset($obj->act); unset($obj->module_srl); unset($obj->page); // 원 skin_info에서 extra_vars의 type이 image일 경우 별도 처리를 해줌 if($skin_info->extra_vars) { foreach($skin_info->extra_vars as $vars) { if($vars->type!='image') continue; $image_obj = $obj->{$vars->name}; // 삭제 요청에 대한 변수를 구함 $del_var = $obj->{"del_".$vars->name}; unset($obj->{"del_".$vars->name}); if($del_var == 'Y') { @unlink($module_info->{$vars->name}); continue; } // 업로드 되지 않았다면 이전 데이터를 그대로 사용 if(!$image_obj['tmp_name']) { $obj->{$vars->name} = $module_info->{$vars->name}; continue; } // 정상적으로 업로드된 파일이 아니면 무시 if(!is_uploaded_file($image_obj['tmp_name'])) { unset($obj->{$vars->name}); continue; } // 이미지 파일이 아니어도 무시 if(!eregi("\.(jpg|jpeg|gif|png)$", $image_obj['name'])) { unset($obj->{$vars->name}); continue; } // 경로를 정해서 업로드 $path = sprintf("./files/attach/images/%s/", $module_srl); // 디렉토리 생성 if(!FileHandler::makeDir($path)) return false; $filename = $path.$image_obj['name']; // 파일 이동 if(!move_uploaded_file($image_obj['tmp_name'], $filename)) { unset($obj->{$vars->name}); continue; } // 변수를 바꿈 unset($obj->{$vars->name}); $obj->{$vars->name} = $filename; } } // serialize하여 저장 $skin_vars = serialize($obj); $oModuleController = &getController('module'); $oModuleController->updateModuleSkinVars($module_srl, $skin_vars); $this->setLayoutPath('./common/tpl'); $this->setLayoutFile('default_layout.html'); $this->setTemplatePath($this->module_path.'tpl'); $this->setTemplateFile("top_refresh.html"); } /** * @brief 게시판 추가 **/ function procBoardAdminInsertBoard($args = null) { // 일단 입력된 값들을 모두 받아서 db 입력항목과 그외 것으로 분리 if(!$args) { $args = Context::gets('module_srl','module_category_srl','board_name','layout_srl','skin','browser_title','description','is_default','header_text','footer_text','admin_id','open_rss'); } $args->module = 'board'; $args->mid = $args->board_name; unset($args->board_name); if($args->is_default!='Y') $args->is_default = 'N'; // 기본 값외의 것들을 정리 $extra_var = delObjectVars(Context::getRequestVars(), $args); if($extra_var->use_category!='Y') $extra_var->use_category = 'N'; unset($extra_var->act); unset($extra_var->page); unset($extra_var->board_name); unset($extra_var->module_srl); // 확장변수(20개로 제한된 고정 변수) 체크 $user_defined_extra_vars = array(); foreach($extra_var as $key => $val) { if(substr($key,0,11)!='extra_vars_') continue; preg_match('/^extra_vars_([0-9]+)_(.*)$/i', $key, $matches); if(!$matches[1] || !$matches[2]) continue; $user_defined_extra_vars[$matches[1]]->{$matches[2]} = $val; unset($extra_var->{$key}); } for($i=1;$i<=20;$i++) if(!$user_defined_extra_vars[$i]->name) unset($user_defined_extra_vars[$i]); $extra_var->extra_vars = $user_defined_extra_vars; // module_srl이 넘어오면 원 모듈이 있는지 확인 if($args->module_srl) { $oModuleModel = &getModel('module'); $module_info = $oModuleModel->getModuleInfoByModuleSrl($args->module_srl); // 만약 원래 모듈이 없으면 새로 입력하기 위한 처리 if($module_info->module_srl != $args->module_srl) unset($args->module_srl); } // $extra_var를 serialize $args->extra_vars = serialize($extra_var); // module 모듈의 controller 객체 생성 $oModuleController = &getController('module'); // is_default=='Y' 이면 if($args->is_default=='Y') $oModuleController->clearDefaultModule(); // module_srl의 값에 따라 insert/update if(!$args->module_srl) { $output = $oModuleController->insertModule($args); $msg_code = 'success_registed'; // 파일업로드, 댓글 파일업로드, 관리에 대한 권한 지정 if($output->toBool()) { $oMemberModel = &getModel('member'); $admin_group = $oMemberModel->getAdminGroup(); $admin_group_srl = $admin_group->group_srl; $module_srl = $output->get('module_srl'); $grants = serialize(array('fileupload'=>array($admin_group_srl), 'comment_fileupload'=>array($admin_group_srl), 'manager'=>array($admin_group_srl))); $oModuleController->updateModuleGrant($module_srl, $grants); } } else { $output = $oModuleController->updateModule($args); $msg_code = 'success_updated'; } if(!$output->toBool()) return $output; $this->add('page',Context::get('page')); $this->add('module_srl',$output->get('module_srl')); $this->setMessage($msg_code); } /** * @brief 게시판 삭제 **/ function procBoardAdminDeleteBoard() { $module_srl = Context::get('module_srl'); // 원본을 구해온다 $oModuleController = &getController('module'); $output = $oModuleController->deleteModule($module_srl); if(!$output->toBool()) return $output; $this->add('module','board'); $this->add('page',Context::get('page')); $this->setMessage('success_deleted'); } /** * @brief 카테고리 추가 **/ function procBoardAdminInsertCategory() { // 일단 입력된 값들을 모두 받아서 db 입력항목과 그외 것으로 분리 $module_srl = Context::get('module_srl'); $category_title = Context::get('category_title'); // module_srl이 있으면 원본을 구해온다 $oDocumentController = &getAdminController('document'); $output = $oDocumentController->insertCategory($module_srl, $category_title); if(!$output->toBool()) return $output; $this->add('page',Context::get('page')); $this->add('module_srl',$module_srl); $this->setMessage('success_registed'); } /** * @brief 카테고리의 내용 수정 **/ function procBoardAdminUpdateCategory() { $module_srl = Context::get('module_srl'); $category_srl = Context::get('category_srl'); $mode = Context::get('mode'); $oDocumentModel = &getModel('document'); $oDocumentController = &getAdminController('document'); switch($mode) { case 'up' : $output = $oDocumentController->moveCategoryUp($category_srl); $msg_code = 'success_moved'; break; case 'down' : $output = $oDocumentController->moveCategoryDown($category_srl); $msg_code = 'success_moved'; break; case 'delete' : $output = $oDocumentController->deleteCategory($category_srl); $msg_code = 'success_deleted'; break; case 'update' : $selected_category = $oDocumentModel->getCategory($category_srl); $args->category_srl = $selected_category->category_srl; $args->title = Context::get('category_title'); $args->list_order = $selected_category->list_order; $output = $oDocumentController->updateCategory($args); $msg_code = 'success_updated'; break; } if(!$output->toBool()) return $output; $this->add('module_srl', $module_srl); $this->setMessage($msg_code); } } ?>