Extra Form
관련링크 https://xetown.com/questions/1001494

$grant


이걸 왜 찾아봤을까..;;


문서권한지정애드온

https://xe1.xpressengine.com/index.php?mid=download&package_id=21015635



[권한이 없습니다] 권한에 따른 다른 메시지 출력하기

https://xe1.xpressengine.com/tip/17334915

뭡니까?

 권한이 없는 곳에 접근하면

[권한이 없습니다] 라고 뜹니다.

하지만, 회원별 등급을 나누어 운영하는 사이트의 경우,

메시지도 순화시키고, 어떤 등급이 필요한 것인지

(사실 노출 안되는것이 제일 편리하지만)

알려주기 위해서 수정해보았습니다.

어떻게 합니까

 파일 몇 개 수정합니다.

1. 원하는 메시지를 마구마구 추가하세요
    $lang->msg_not_permitted_member1 = '당신 빼고 다 열람 가능합니다 :)';
$lang->msg_not_permitted_member2 = '잘생긴 사람 이상 열람 가능합니다 :)';
$lang->msg_not_permitted_member3 = '로그인 후 열람 가능합니다 :)';
(코드 입력기가 잘 작동안하네요;; common/lang/ko.lang.php입니다.)


2. 권한 정보를 잠시 빼옵니다. 당장 해킹의 위험이 있는것은 아니지만, zbxe에서 원하는 객체지향적인면에서 권한을 알 필요가 없는 곳에서 권한을 가져온다는면에서 바람직하지는 않습니다만, 각오하고 쓰세요 ㅋㅋㅋㅋ
182
183
184
185
186
187
188
189
// 권한변수 설정
$this->grant =$grant;
Context::set('grant',$grant);
 
    // 권한값을알기위한설정
Context::set('grants',$this->module_info->grants);
 
if(method_exists($this,'init'))$this->init();
가운데 Context::set('grants', $this->module_info->grants); 를 추가하시는겁니다.


3. 지금은 board모듈에서 수정합니다. 다른 모듈도 비슷하게 시도해보세요..
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
         /**
         * @brief 목록 및 선택된 글 출력
         **/
        function dispBoardContent() {
            /**
             * 목록보기 권한 체크 (모든 권한은 ModuleObject에서 xml 정보와 module_info의 grant 값을 비교하여 미리 설정하여 놓음)
             **/
 
            $grants = Context::get('grants');
 
            if(!$this->grant->list)
 
            /**
            * module_info에서 권한을 검사하여 해당하는 메시지 출력
            **/
{
            if (in_array('2',$grants['view']))// 그룹2에게 보기 권한이 있을 때
                return $this->dispBoardMessage('msg_not_permitted_member2');
            elseif (in_array('3',$grants['view']))// 그룹3에게 보기 권한이 있을 때
                return $this->dispBoardMessage('msg_not_permitted_member3');
            elseif (in_array('4',$grants['view']))// 그룹4에게 보기 권한이 있을 때
                return $this->dispBoardMessage('msg_not_permitted_member4');
            else
                return $this->dispBoardMessage('msg_not_permitted');
 
}
위 파일 경우는, 사실 원래는 목록보기 권한이 없을 때 나올 메시지입니다만,
그냥 들어왔는데, 로그인해라길래 들어오니까 등급이안된다고 안보여주면 짜증나니까
한번에 필요한 큰 권한을 알려주는..? 뭐 알아서 잘 편집하세요 ㅋ

151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
// 글 보기 권한을 체크해서 권한이 없으면 오류 메세지 출력하도록 처리
if(!$this->grant->view && !$oDocument->isGranted()) {
    $oDocument = null;
    $oDocument =$oDocumentModel->getDocument(0);
 
    Context::set('document_srl','',true);
    if (in_array('2',$grants['view']))//그룹2에게 보기 권한이 있을 때
            return $this->alertMessage('msg_not_permitted_member1');
    elseif (in_array('3',$grants['view']))//그룹3에게 보기 권한이 있을 때
            return $this->alertMessage('msg_not_permitted_member2');
    elseif (in_array('4',$grants['view']))// 그룹4에게 보기 권한이 있을 때
            return $this->alertMessage('msg_not_permitted_member3');
    else
            return $this->alertMessage('msg_not_permitted');
 
}else {
소스 건드실 분들은 아시겠지만, 저기 2,3,4들은 group_srl입니다. 직접 값을 모르시면 잘 찾아보세요...

추가) 관리자로 로그인하셔서 관리 -> 회원 -> 그룹관리 -> 해당 그룹의 수정 링크의 속성에서 링크 주소를 보시면 group_srl=숫자 가 나옵니다. 이 숫자가 해당 그룹의 시리얼넘버이구요, 저기 '2', '3'등과 같이 있는 곳에 해당 숫자를 넣으시면 됩니다 :)

스샷은 귀찮아서.. 

출처 : https://xe1.xpressengine.com/tip/17334915





Who's 이온디

profile

라이믹스는 이온디와 함께

추가시작추가끝


질문•답변

상품문의, 포인트관련 문의는 멤버십 지원게시판에 작성해주세요. (프로젝트>기술지원)

List of Articles
No. Category Subject Date
Notice 기타 본 게시판의 용도 2024.06.11
221 XE 1.0.5 에서 zb4의 문서가 마이그레이션 되나요? 1 2008.07.25
220 XE 2002년 이후 오랜만에 xe로 커뮤니티 만들려고 하는데요? 2 2020.08.24
219 git After changing branch in phpstorm, the directory is not visible 2022.07.30
218 기타 DISK BOOT FAILER, INSERT SYSTEM AND PRESS ENTER 2007.10.27
217 HTML/CSS/JS div 안에 내용 변경 감지 1 2021.08.30
216 XE eb_contact_write사용입니다. 2 file 2021.03.27
215 XE eondZenithworld Layout 구매후 설정 적용이 안되는 것 같습니다. 4 secret 2023.04.05
214 기타 eond님의 스토어에서 구매한 것은 아닌데 질문을 드려도 되는지요. 죄송해요. 2 secret 2023.03.15
213 XE Excel 등록 6 secret 2022.09.29
212 git git pull 했을 때 1 2022.01.21
211 git git pull 했을 때 (2) 1 2022.01.30
210 git git의 .gitignore 사용방법 문의 file 2021.12.27
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 19 Next
/ 19
닫기

마이페이지

로그인을 해주세요

네이버로 로그인