웹마스터 팁

안녕하세요. 혼자 삽질을 하다가 겨우 완성해서 저 처럼 줄기차게 구글의 신탁을 찾고 계실 분들을 위해 정리 하나 올려 봅니다. 외부 프로그램 연동해 쓰시는 분들은 대부분 이미 잘 아실 내용입니다. 기본적으로 아래 문서들에 나온 내용을 step by step으로 따라할 수 있게 하나로 정리했습니다.


XE와 별도 프로그램 연동시 세션 공유 : http://www.xpressengine.com/tip/17536608

XE와 도쿠위키(dokuwiki) 세션으로 연동 : http://50ndd1n6.tistory.com/59

Authentication Plugins : https://www.dokuwiki.org/devel:auth_plugins

Working Example of trustExternal() : https://www.dokuwiki.org/devel:working_example_of_trustexternal


=======================

0. 당연하지만 모든 작업 하시기 전에 백업 잊지마시구요...


1. 제일 먼저 할 일은 도쿠위키 인증 백엔드 파일을 만드는 것입니다. 도쿠위키가 2013년 버전업을 하면서 인증방식이 플러그인식으로 바뀌었습니다. 그래서 위치가 


(도쿠위키설치경로)/lib/plugins/auth(인증백엔드이름)/auth.php


가 되어야 합니다. 예를들면


doku/lib/plugins/authxe/auth.php


이런 식으로 말이죠. 그냥 디폴트 인증 플러그인인 authplain을 하나 복사해서 디렉토리명만 바꿔주시면 기본적인건 끝납니다. 다음으로 auth.php를 열어서


// must be run within Dokuwiki
if(!defined('DOKU_INC')) die();

/**
 * XE session sharing authentication backend
 */
class auth_plugin_authxe extends DokuWiki_Auth_Plugin {
    /**
     * Constructor
     *
     * Carry out sanity checks to ensure the Context object 
     * is able to operate. Set capabilities.
     *
     * @author  Christopher Smith <chris@jalakai.co.uk>
     */
    public function __construct() {
        parent::__construct();
        global $config_cascade;

        $this->cando['external'] = true;
    }
    
    function trustExternal($user, $pass, $sticky = false) {
        global $USERINFO;
global $conf;
 
if (!empty($_SESSION[DOKU_COOKIE]['auth']['info'])) {
    $USERINFO['name'] = $_SESSION[DOKU_COOKIE]['auth']['info']['user'];
    $USERINFO['mail'] = $_SESSION[DOKU_COOKIE]['auth']['info']['mail'];
    $USERINFO['grps'] = $_SESSION[DOKU_COOKIE]['auth']['info']['grps'];
    $_SERVER['REMOTE_USER'] = $_SESSION[DOKU_COOKIE]['auth']['user'];
    return true;
}
 
        $logged_info = Context::get('logged_info');
             
if ($logged_info) {
    $sticky ? $sticky = true : $sticky = false;
    $USERINFO['name'] = $logged_info->user_id;
    $USERINFO['mail'] = $logged_info->email_address;
    
    $is_admin = in_array('Admin', $logged_info->group_list);
    $is_member = in_array('Member', $logged_info->group_list);
    ...
    if ($is_admin) {
                $USERINFO['grps'] = array('Admin');
    } else {
        if ($is_member) {
            $USERINFO['grps'] = array('Member');
        } else if (...) {
            ...
        } else {
               $USERINFO['grps'] = array('Wait-listed');
        }
    }
    
    $_SERVER['REMOTE_USER'] = $logged_info->user_id;
    $_SESSION[DOKU_COOKIE]['auth']['user'] = $logged_info->user_id;
    $_SESSION[DOKU_COOKIE]['auth']['info'] = $USERINFO;

    return true;
} else {
    return false;
}
    }    
}


이런 식으로 씁니다. 가운데 ... 부분은 추가로 ACL에 원하시는 XE 그룹을 넣으시면 됩니다.


2. 다음으로 ACL 목록을 수정합니다. 이것은


(도쿠위키설치경로)/conf/acl.auth.php


여기에 있습니다. 일단 XE 그룹명과 동일하게 이름들만 추가해 주시고 (접근은 전역 (*), 권한은 1 (read only)로 통일) 나중에 도쿠위키의 ACL 관리자 화면에서 상세 권한 설정을 하시면 됩니다.  이를테면


* @ALL 1

* @Member 1

...


이런 식으로 씁니다. Admin (관리그룹)은 추가하실 필요 없습니다. 그룹명은 영문으로 하실 것을 권합니다.


3. 이제 도쿠위키 관리자 모드로 들어갑니다. 일단 ACL 관리자를 여셔서 방금 추가한 그룹들이 제대로 추가가 되었는지 확인합니다. 다음으로 플러그인 관리자를 여셔서 1번에서 추가한 XE용 인증 플러그인을 활성화하고 저장합니다. (아직 authplain을 비활성화하지 마세요!)


4. 이제 도쿠위키 설정 파일을 수정해야 합니다. 도쿠위키 전통의 설정파일인


(도쿠위키설치경로)/conf/local.php


를 여셔서 $conf['superuser']를 XE에서 사용하는 관리자 그룹명으로 변경합니다. (ex. @Admin) 다음으로 $conf['defaultgroup']을 원하시는 XE의 기본 사용자 그룹명으로 써줍니다. 이곳에 들어갈 그룹명은 XE에서 가입하여 로그인시 아무런 등업을 하지 않은 상태에서 부여되는 기본 그룹명을 지정하시는게 좋습니다.


5. 이제 세션을 읽어오기위해 


(도쿠위키설치경로)/doku.php


를 수정합니다. 제일 위의 주석 바로 아래에


define('__XE__', true);
require_once('(XE설치경로)/config/config.inc.php');
$oContext = &Context::getInstance();
$oContext->init();


를, 맨 아래에는


$oContext->close();


를 추가합니다.


6. 이제 다시 도쿠위키 관리화면으로 돌아가서 설정 화면에서 기본 인증 모듈에 authxe를 선택하시고 저장하시면 됩니다. 만약 5번 항목 수정 이후 관리자 모드 접근이 안될 경우 


(도쿠위키설치경로)/conf/local.php


를 여셔서 $conf['authtype']에 인증 플러그인명을 적어주시면 됩니다.


7. 정상 작동을 확인하시고 스킨을 적절히 수정하시면 끝입니다 ^^


=======================


혹시 제가 빠뜨린 것이나 잘못하고 있는 것이 있다면 덧글로 알려주시면 감사하겠습니다 m(_ _)m


p.s. 어서 XE 위키가 안정화 되었으면 좋겠네요. 가능하면 도쿠위키 문법도 지원해 주시고ㅎㅎ


p.s.2 멀티 업로드 관련 문제로 이 방법으로 하시면 파일 업로드가 안됩니다;;; 어느 고수 분이 해결책을 알려주시면 좋겠네요 ㅠㅠ

제목 글쓴이 날짜
(재 수정) 제로보드 XE 신버젼에 Lavalic 2 설치하기 [4] 조성우371 2009.01.16
사이트 이전팁( files 폴더) [6] 샤이니라 2009.01.28
게시판에서 사이트 관리자만 볼수있는 항목 만들기 [1] ☜ TeRy ☞ 2009.02.13
테스트용 아이디 탈퇴 막기 [1] SMaker 2009.02.26
첨부파일의 외부 무단 링크 차단하기(XE) 게시판설정 [7] file 왕초보왕따 2009.03.02
브라우저 크기에 따라 본문 가로 크기 자동 조절 [1] 개돌 2009.03.18
제로보드의 아이콘을 내 맘대로 변경하기...(2) [2] file winter548 2009.03.23
로그인 포인트 출력 위젯을 수정해보자 [花穗] 2009.03.27
특정그룹 멤버 표시 위젯에서 이름 순 정렬하기 [2] file 이재한744 2009.03.30
클릭마다 조회수 올리기 [1.4.0] [12] file 지B 2009.04.04
요청하신 모듈을 찾을 수 없습니다 문제해결 방법 [2] 반도체맨 2009.04.09
주민등록 입력 폼 1.2.0 [55] file 개돌 2009.04.10
다양한 언어로 홈페이지 서비스하기 - 무식한 방법 [4] 멀리서 2009.04.21
BNU님의 Planner XE 1.2 버젼(일정관리) [9] file 개돌 2009.04.21
내가 작성 한 글에 대한 일괄 삭제/이동/복사 권한 주기 [2] file 개돌 2009.05.15
별도 페이지 로그인방법 cornet 2009.05.21
로그인 페이지 만드는 방법 [5] 산토 2009.06.12
로그인 후 그룹별로 다른 페이지로 가기 - 업데이트판 v1.5 [19] 무대포2 2009.06.24
로그인 & 파일 첨부 문제 [3] peter99 2009.06.29
Lavalic Mp3 플레이어를 대신하는... [8] 조성우371 2009.07.13