322 lines
12 KiB

7 years ago
7 years ago
7 years ago
7 years ago
  1. <?php
  2. defined('BASEPATH') OR exit('No direct script access allowed');
  3. /**
  4. *
  5. * HookPostControllerConstructor.php
  6. *
  7. * 컨트롤러가 인스턴스화 직후 가동되는 후킹 클래스.
  8. *
  9. */
  10. class HookPostControllerConstructor {
  11. protected $CI;
  12. /************************************************
  13. * 후킹 초기 실행 지점
  14. ***********************************************/
  15. function init() {
  16. // 인스턴스화 된 컨트롤러를 불러와 참조시킨다.
  17. $this->CI =& get_instance();
  18. if( PAGE_INSTALL ) return;
  19. $install_file = APPPATH . '..'.DIRECTORY_SEPARATOR.'config'.DIRECTORY_SEPARATOR.'no_install.php';
  20. if( file_exists($install_file) && (! isset($_SERVER['WB_ENV']) OR $_SERVER['WB_ENV'] !== 'DEV'))
  21. {
  22. include_once $install_file;
  23. exit;
  24. }
  25. $this->load_config();
  26. $this->setup_device_view();
  27. $this->autologin_check();
  28. $this->member_status_check();
  29. $this->admin_check();
  30. $this->statics();
  31. $this->ip_block();
  32. $this->lang_set();
  33. }
  34. /************************************************
  35. * 환경설정 파일을 로드한다.
  36. ***********************************************/
  37. function load_config()
  38. {
  39. $this->CI->config->set_item('base_url', BASE_URL);
  40. $this->CI->config->set_item('cookie_domain', COOKIE_DOMAIN);
  41. $this->CI->load->database();
  42. $this->CI->load->helper(array('url','form','cookie','common','thumbnail','widgets','lang'));
  43. $this->CI->load->helper('language');
  44. $this->CI->load->library('site');
  45. $this->CI->load->library('session');
  46. $this->CI->load->library('member');
  47. $this->CI->load->library('user_agent');
  48. $this->CI->load->library('banner');
  49. $this->CI->load->library('boardlib');
  50. if( PAGE_ADMIN )
  51. {
  52. $this->CI->load->helper('admin');
  53. }
  54. }
  55. /************************************************
  56. * 현재 접속한 기기정보와, 보기 모드 설정들을 정의한다.
  57. ***********************************************/
  58. function setup_device_view()
  59. {
  60. // 모바일 접속여부에 따라 device 정보 확인
  61. $device = $viewmode = $this->CI->agent->is_mobile() ? DEVICE_MOBILE : DEVICE_DESKTOP;
  62. // 해당 모드로 보기 쿠키가 존재한다면 해당 보기 모드로
  63. if( get_cookie( COOKIE_VIEWMODE ) && ( get_cookie( COOKIE_VIEWMODE ) == DEVICE_DESKTOP OR get_cookie( COOKIE_VIEWMODE ) == DEVICE_MOBILE) )
  64. {
  65. $viewmode = get_cookie(COOKIE_VIEWMODE);
  66. }
  67. // 사이트 정보에 저장
  68. $this->CI->site->device = $device;
  69. $this->CI->site->viewmode = $viewmode;
  70. }
  71. /**************************************************
  72. * 자동로그인 체크
  73. ***********************************************/
  74. function autologin_check()
  75. {
  76. if( PAGE_INSTALL ) return;
  77. if( $this->CI->agent->is_robot() ) return; // 로봇일경우도 건너뛴다.
  78. if( $this->CI->member->is_login() ) return; // 로그인중이라면 건너뛴다.
  79. // 자동로그인 쿠키가 있다면
  80. if($aul_key = get_cookie(COOKIE_AUTOLOGIN))
  81. {
  82. // DB에 저장된 자동로그인 데이타가 있는지 확인한다.
  83. $result =
  84. $this->CI->db
  85. ->where('aul_key', $aul_key)
  86. ->where('aul_ip', ip2long( $this->CI->input->ip_address() ))
  87. ->limit(1)
  88. ->get('member_autologin');
  89. $autologin = $result->row_array();
  90. if( ! $autologin )
  91. {
  92. // DB에 데이타가 없다면 쿠키삭제
  93. delete_cookie(COOKIE_AUTOLOGIN);
  94. return FALSE;
  95. }
  96. else if( strtotime($autologin['aul_regtime']) + (60*60*24*30) < time() )
  97. {
  98. $this->CI->member->remove_autologin($autologin['mem_idx']);
  99. return FALSE;
  100. }
  101. else
  102. {
  103. $member_info = $this->CI->member->get_member( $autologin['mem_idx'], "mem_idx" );
  104. if(! $member_info)
  105. {
  106. // 회원정보가 없다면 삭제
  107. $this->CI->member->remove_autologin($autologin['mem_idx']);
  108. return FALSE;
  109. }
  110. else if( $member_info['mem_status'] != 'Y' )
  111. {
  112. // 회원상태가 '정상'이 아닌경우도 자동로그인 삭제
  113. $this->CI->member->remove_autologin($autologin['mem_idx']);
  114. return FALSE;
  115. }
  116. else
  117. {
  118. $this->CI->member->login_process( $member_info, TRUE, TRUE );
  119. }
  120. }
  121. }
  122. }
  123. function member_status_check()
  124. {
  125. if(! $this->CI->member->is_login()) return;
  126. if( PAGE_AJAX ) return;
  127. $member = $this->CI->member->get_member( $this->CI->member->is_login(), "mem_idx" );
  128. if( $member['mem_status'] == 'H' )
  129. {
  130. if( strtolower($this->CI->uri->segment(1)) != 'members' OR ( strtolower($this->CI->uri->segment(2)) != 'activation' && strtolower($this->CI->uri->segment(2)) != 'logout' )) {
  131. redirect(base_url('members/activation'));
  132. exit;
  133. }
  134. }
  135. }
  136. /**************************************************
  137. * 관리자 페이지인 경우,
  138. * 로그인 체크및 관리자 권한을 체크합니다.
  139. ***********************************************/
  140. function admin_check()
  141. {
  142. if( ! PAGE_ADMIN ) return;
  143. if( $this->CI->uri->segment(2) == 'members' && $this->CI->uri->segment(3) == 'login' ) return;
  144. if( ! $this->CI->member->is_login() )
  145. {
  146. alert_login("admin/members/login");
  147. exit;
  148. }
  149. else
  150. {
  151. if(! $this->CI->member->is_super())
  152. {
  153. alert('해당 페이지에 접근할 권한이 없습니다.', base_url());
  154. exit;
  155. }
  156. }
  157. }
  158. /**************************************************
  159. * 통계데이타 기록
  160. ***********************************************/
  161. function statics()
  162. {
  163. if ( PAGE_INSTALL || PAGE_ADMIN ) return;
  164. if ( $this->CI->input->is_ajax_request() ) return; // AJAX 요청인경우도 리턴
  165. if ( $this->CI->agent->is_robot() ) return; // 검색봇의 경우도 리턴
  166. if ( get_cookie(COOKIE_STATICS) ) return; // 방문자 쿠키가 있는경우 리턴
  167. if( $this->CI->input->ip_address() == '127.0.0.1' OR $this->CI->input->ip_address() == '0.0.0.0' ) return; // 접속IP가 정확하지 않을경우 리턴
  168. $sta_data['sta_regtime'] = date('Y-m-d H:i:s');
  169. $sta_data['sta_browser'] = $this->CI->agent->browser();
  170. $sta_data['sta_version'] = $this->CI->agent->version();
  171. $sta_data['sta_is_mobile'] = $this->CI->agent->is_mobile() ? 'Y':'N';
  172. $sta_data['sta_mobile'] = $this->CI->agent->mobile();
  173. $sta_data['sta_platform'] = $this->CI->agent->platform();
  174. $sta_data['sta_referrer'] = "";
  175. $sta_data['sta_referrer_host'] = "";
  176. $sta_data['sta_keyword'] = "";
  177. $sta_data['sta_ip'] = ip2long($this->CI->input->ip_address());
  178. // 브라우져가 없다면 로봇으로 파악하고 return
  179. if( empty($sta_data['sta_browser']) ) return;
  180. // 플랫폼이 Unknown Platform 이라면 로봇일 가능성이크므로 리턴
  181. if( $sta_data['sta_platform'] == 'Unknown Platform' ) return;
  182. if( $this->CI->agent->is_referral() )
  183. {
  184. $sta_data['sta_referrer'] = $this->CI->agent->referrer();
  185. // 리퍼러에서 호스트와 패러미터 추출
  186. $referrer = parse_url($sta_data['sta_referrer']);
  187. $sta_data['sta_referrer_host'] = (isset($referrer['host'])) ? $referrer['host'] : "";
  188. // 검색키워드 분석
  189. $keyword = '';
  190. if(isset($referrer['query']) && $referrer['query'])
  191. {
  192. $queries = explode('&', $referrer['query']);
  193. foreach ($queries as $query) {
  194. if (preg_match('/^(query|q|p)=(.+)$/i', $query, $matches)) {
  195. $keyword = urldecode($matches[2]);
  196. break;
  197. }
  198. }
  199. }
  200. $sta_data['sta_keyword'] = trim($keyword);
  201. }
  202. // 집계 DB에 저장
  203. $result = $this->CI->db->insert("statics", $sta_data);
  204. // 통계 DB에도 저장
  205. $query = " INSERT INTO {$this->CI->db->dbprefix}statics_date SET `std_date` = '".date('Y-m-d')."', `std_count` = 1 ";
  206. if( $this->CI->agent->is_mobile() ) $query .= ", `std_mobile` = 1 ";
  207. $query .= ' ON DUPLICATE KEY UPDATE `std_count` = `std_count` + 1';
  208. if( $this->CI->agent->is_mobile() ) $query .= ", `std_mobile` = `std_mobile` + 1";
  209. $this->CI->db->query($query);
  210. $expire = strtotime(date('Y-m-d 23:59:59')) - time();
  211. set_cookie(COOKIE_STATICS, ip2long($this->CI->input->ip_address()), $expire );
  212. }
  213. /**************************************************
  214. * IP접근 금지
  215. ***********************************************/
  216. function ip_block()
  217. {
  218. if( $this->CI->site->config('deny_ip') )
  219. {
  220. $blacklist = $this->CI->site->config('deny_ip');
  221. $blacklist = preg_replace("/[\r|\n|\r\n]+/", ',', $blacklist);
  222. $blacklist = preg_replace("/\s+/", '', $blacklist);
  223. if (preg_match('/(<\?|<\?php|\?>)/xsm', $blacklist)) {
  224. $blacklist = '';
  225. }
  226. if ($blacklist) {
  227. $blacklist = explode(',', trim($blacklist, ','));
  228. $blacklist = array_unique($blacklist);
  229. if (is_array($blacklist)) {
  230. $this->CI->load->library('Ipfilter');
  231. $ipfilter = new Ipfilter();
  232. if ($ipfilter->filter($blacklist)) {
  233. $title = 'Not Allowed IP';
  234. show_error("Access Denied", '500', $title);
  235. exit;
  236. }
  237. }
  238. }
  239. }
  240. }
  241. /**************************************************
  242. * 다국어 설정
  243. ***********************************************/
  244. function lang_set()
  245. {
  246. // 사용할 언어 리스트
  247. $accept_lang = $this->CI->site->config('accept_languages');
  248. $accept_lang = explode(',', $accept_lang);
  249. // 다국어 사용설정이 FALSE 면 리턴
  250. if( $this->CI->site->config('use_localize') != 'Y' )
  251. {
  252. unset($accept_lang);
  253. $accept_lang = array();
  254. $accept_lang[] = $this->CI->site->config('default_language');
  255. }
  256. // Default 값으로 언어중 가장 첫번째값
  257. $lang = $this->CI->site->config('default_language');
  258. // 현재 브라우져에서 ACCEPT_LANG에 정의된 언어셋값이 있는지 확인한다.
  259. foreach($accept_lang as $lng)
  260. {
  261. if( preg_match('/'.$lng.'/', isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) && $_SERVER['HTTP_ACCEPT_LANGUAGE']) ? $_SERVER['HTTP_ACCEPT_LANGUAGE'] : '')
  262. {
  263. $lang = $lng;
  264. }
  265. }
  266. // 쿠키에 저장된 언어값이 있는지 확인하고, 저장된 언어값이 있다면 그언어를 불러온다.
  267. $cookie_lang = get_cookie('site_lang');
  268. if( ! empty($cookie_lang) && in_array($cookie_lang, $accept_lang) )
  269. {
  270. $lang = $cookie_lang;
  271. }
  272. // 만약 GET 값으로 lang 값이 넘어왔고, 이값이 언어 리스트에 있다면
  273. $get_lang = $this->CI->input->get('lang', TRUE);
  274. if( ! empty($get_lang) && in_array($get_lang, $accept_lang) )
  275. {
  276. set_cookie("site_lang", $get_lang, 60*60*24*30 );
  277. $lang = $get_lang;
  278. }
  279. // 언어를 define
  280. define('LANG', $lang);
  281. $this->CI->site->lang = $lang;
  282. }
  283. }