1
내가 작성 한 글에 대한 일괄 삭제/이동/복사 권한 주기개돌

XE 게시판에 작성된 글 목록을 관라자의 경우 일괄적으로 선택하여 이동/복사/삭제가 가능합니다.

하지만 일반 유저의 경우 게시물을 작성 후 다른 게시판으로 옮기려면 내용을 복사해서 다른 게시판에 다시 글을 쓰고 원래 있던 글을 삭제 해야 되던가 동일한 내용을 여러 게시판에 올릴때는 계속 복사 -> 붙여넣기 -> 확인 작업을 해야겠죠.

삭제 할때도 마찬가지로 게시글을 하나 하나 클릭하여 삭제...

이를 좀더 쉽게 할 수 있도록 게시판 리스트 페이지에서 자신이 작성한 글에 한해 "게시글관리" 기능을 사용할 수 있도록 해주는 겁니다.

 

우선 이 기능을 생각한 첫번째 이유는

팁 공유 게시판에 올라오는 질문 글들을 이런 기능이 있으면 "혹시라도" 쉽게 질문 게시판으로 옮기지 않을까? 라는 생각을 하다가 한번 해보자 라는 생각에 적용을 해봤습니다.

 

1.  /xe/modules/board/skins/xe_board/style.list.html
 - line 7, 9삭제
 <manager">!--@if($grant->manager)-->
            <th scope="col" class="no_line"><input type="checkbox" /></th>
        <!--@end-->

- line 85, 87삭제
 <manager">!--@if($grant->manager)-->
                <td class="checkbox"><input type="checkbox" name="cart" value="{$document->document_srl}" <isCarted())-->checked="checked"checked="checked"checked="checked"&nbsp">!--@else-->&nbsp;
    <!--@end-->
    </td>

관리자 이거나 . 글 작성자의 아이디와 현재 로그인한 유저의 아이디가 동일한 게시물에 대해 체크박스를 보여줍니다.

 

2. /xe/modules/board/skins/xe_board/list.html
 - line 28, 30 삭제

<manager">!--@if($grant->manager)-->
                <a href="/{getUrl(",'module','document','act','dispDocumentManageDocument')}" class="button {$btn_class}"><span>{$lang->cmd_manage_document}</span></a>
            <!--@end-->

역시 마찬가지로 관리자일 경우에 대한 체크 부분을 삭제하여 일반 유저도 관리 버튼이 표시 되도록 합니다.

이 경우 선택된 게시물이 없으면 해당 버튼을 클릭해도 별다른 기능을 하지 않으므로 관리에 대한 문제가 없다고 봅니다.
게시물이 선택된 경우 그 게시물에 대한 권한이 있는 것이고 그 부분을 작업 중인 것이니 그 또한 문제가 없는 거겠죠

 

3. /xe/modules/document/document.view.php
 - line 71  수정

function dispDocumentManageDocument() {
            if(!Context::get('is_logged')) return new Object(-1,'msg_not_permitted');

            // 선택한 목록을 세션에서 가져옴
            $flag_list = $_SESSION['document_management'];
            if(count($flag_list)) {
                foreach($flag_list as $key => $val) {
                    if(!is_bool($val)) continue;
                    $document_srl_list[] = $key;
                }
            }

            if(count($document_srl_list)) {
                $oDocumentModel = &getModel('document');
                //$document_list = $oDocumentModel->getDocuments($document_srl_list, $this->grant->is_admin);
                $document_list = $oDocumentModel->getDocuments($document_srl_list);
                Context::set('document_list', $document_list);
            }

            $oModuleModel = &getModel('module');

            // 모듈 카테고리 목록과 모듈 목록의 조합
            if(count($module_list)>1) Context::set('module_list', $module_categories);

            // 팝업 레이아웃 선택
            $this->setLayoutPath('./common/tpl');
            $this->setLayoutFile('popup_layout');
            $this->setTemplatePath($this->module_path.'tpl');
            $this->setTemplateFile('checked_list');
        }

어드민에게만 허용된 권한을 모두에게로 오픈 하였습니다. 주석 처리된 라인은 그냥 삭제 처리해도 됩니다.

 

4. /xe/modules/document/document.controller.php
 - line 1526 ~ 1527 

/**
         * @brief 관리자가 글 선택시 세션에 담음
         **/
        function procDocumentAddCart() {
            if(!Context::get('is_logged')) return new Object(-1, 'msg_not_permitted');

            // 게시글 번호 구함
            $srls = explode(',',Context::get('srls'));
            for($i=0;$i<count($srls);$i++) {
                $srl = trim($srls[$i]);
                if(!$srl) continue;
                $document_srls[] = $srl;
            }
            if(!count($document_srls)) return;

            // 게시글들의 모듈 번호를 구함
            $args->list_count = count($document_srls);
            $args->document_srls = implode(',',$document_srls);
            $args->order_type = 'asc';
            $output = executeQueryArray('document.getDocuments', $args);
            if(!$output->data) return new Object();

            unset($document_srls);
            foreach($output->data as $key => $val) {
                $document_srls[$val->module_srl][] = $val->document_srl;
            }
            if(!$document_srls || !count($document_srls)) return new Object();

            // 각 문서들의 모듈 관리자 여부 확인
            $oModuleModel = &getModel('module');
            $module_srls = array_keys($document_srls);
            for($i=0;$i<count($module_srls);$i++) {
                $module_srl = $module_srls[$i];
                $module_info = $oModuleModel->getModuleInfoByModuleSrl($module_srl);
                if(!$module_info) {
                    unset($document_srls[$module_srl]);
                    continue;
                }
                $grant = $oModuleModel->getGrant($module_info, Context::get('logged_info'));
                if(!$grant->manager) {
                    //unset($document_srls[$module_srl]);
                    //continue;
                }
            }
            if(!count($document_srls)) return new Object();

            foreach($document_srls as $module_srl => $documents) {
                $cnt = count($documents);
                for($i=0;$i<$cnt;$i++) {
                    $document_srl = (int)trim($documents[$i]);
                    if(!$document_srls) continue;
                    if($_SESSION['document_management'][$document_srl]) unset($_SESSION['document_management'][$document_srl]);
                    else $_SESSION['document_management'][$document_srl] = true;
                }
            }
        }

이 부분은 체크 박스에 체크 할때 세션으로 담는 부분에서 관리자가 아닌 경우 세션을 저장하지 않도록 된 부분을 주석 처리 한 것입니다.

 

 

사내 정보라 다른 게시물들은 필터링 처리 했습니다.

보시다 시피 테스트용으로만든 계정에서 입력한  게시물에만 체크 박스가 나오며 하단의 게시글 관리  버튼이 활성화 되어있습니다.

 

일반적인 게시판에서의 활용도는 어떨지 모르겠습니다만 위 기능을 이용하면 저희 같은 사내 업무에서는 많은 도움이 될 것 같네요.

 

이 게시물을

공유하기

번호
분류
제목
조회 수
319
조회 수: 6649

SEARCH