ここの情報は古いです。ご理解頂いた上でお取り扱いください。

source: OpenPNE/trunk/webapp/modules/admin/init.inc @ 2

Last change on this file since 2 was 2, checked in by ogawa, 15 years ago

OpenPNE 2.3.0

File size: 3.7 KB
Line 
1<?php
2/**
3 * @copyright 2005-2006 OpenPNE Project
4 * @license   http://www.php.net/license/3_01.txt PHP License 3.01
5 */
6
7// admin モジュール initialize 処理
8
9// auth関連設定
10session_name('OpenPNEadmin');
11isset($GLOBALS['OpenPNE']['admin']['session_lifetime'])
12    or $GLOBALS['OpenPNE']['admin']['session_lifetime'] = 0;
13isset($GLOBALS['OpenPNE']['admin']['session_idletime'])
14    or $GLOBALS['OpenPNE']['admin']['session_idletime'] = 0;
15
16// ライブラリ読み込み
17$module_lib_dir = dirname(__FILE__) . '/lib';
18require_once $module_lib_dir . '/db_admin.php';
19require_once $module_lib_dir . '/etc_admin.php';
20require_once $module_lib_dir . '/hash_admin.php';
21
22// デフォルトページ
23$GLOBALS['__Framework']['default_page'] = 'top';
24
25// ハッシュから action名を取得
26$hash_tbl =& AdminHashTable::singleton();
27$action = $hash_tbl->action($action, $type);
28
29$GLOBALS['_OPENPNE_ADMIN_AUTH_ACTIONS'] = array(
30'normal_type' => array(
31    'page_delete_c_image_confirm',
32    'page_delete_c_member_confirm',
33    'page_delete_kakikomi',
34    'page_edit_c_image',
35    'page_insert_c_admin_user',
36    'page_list_c_admin_user',
37    'page_list_c_image',
38    'page_list_c_member',
39    'page_manage_c_commu',
40    'page_passwd',
41    'page_send_invites_confirm',
42    'page_send_invites',
43    'page_send_messages_all',
44    'page_send_messages',
45    'do_delete_c_admin_user',
46    'do_delete_c_image',
47    'do_delete_c_image4c_image_id',
48    'do_delete_c_member',
49    'do_delete_kakikomi_c_commu_topic',
50    'do_delete_kakikomi_c_commu',
51    'do_delete_kakikomi_c_diary',
52    'do_insert_c_admin_user',
53    'do_insert_c_image',
54    'do_passwd',
55    'do_send_invites',
56    'do_send_messages_all',
57    'do_send_messages',
58    'do_update_c_commu_is_regist_join',
59    'do_update_is_login_rejected',
60),
61'_type' => array(
62    'page_delete_c_member_confirm',
63    'page_insert_c_admin_user',
64    'page_list_c_admin_user',
65    'page_list_c_member',
66    'page_passwd',
67    'page_send_messages_all',
68    'page_send_messages',
69    'do_delete_c_admin_user',
70    'do_delete_c_member',
71    'do_insert_c_admin_user',
72    'do_passwd',
73    'do_send_messages_all',
74    'do_send_messages',
75    'do_update_is_login_rejected',
76),
77);
78
79function init_admin_page(&$smarty)
80{
81    $is_secure = $GLOBALS['__Framework']['is_secure'];
82    $smarty->assign('inc_header', admin_fetch_inc_header($is_secure));
83    $smarty->assign('inc_footer', admin_fetch_inc_footer($is_secure));
84    $v['module_name'] = ADMIN_MODULE_NAME;
85    $smarty->assign($v);
86    $smarty->assign_by_ref('hash_tbl', AdminHashTable::singleton());
87
88    if ($is_secure) {
89        @session_start();
90        $smarty->assign('PHPSESSID', md5(session_id()));
91
92        $auth_type = admin_get_auth_type();
93        $smarty->assign('auth_type', $auth_type);
94        $act = sprintf('page_%s', $GLOBALS['__Framework']['current_action']);
95        if ($auth_type != 'all' && in_array($act, $GLOBALS['_OPENPNE_ADMIN_AUTH_ACTIONS'][$auth_type.'_type'])) {
96            admin_client_redirect('top', '指定されたページにはアクセスできません');
97        }
98    }
99}
100
101function init_admin_do()
102{
103    $is_secure = $GLOBALS['__Framework']['is_secure'];
104
105    if ($is_secure) {
106        @session_start();
107        if ($_REQUEST['sessid'] !== md5(session_id())) {
108            openpne_display_error('前の画面を再読み込みして、操作をやり直してください');
109        }
110        $auth_type = admin_get_auth_type();
111        $act = sprintf('do_%s', $GLOBALS['__Framework']['current_action']);
112        if ($auth_type != 'all' && in_array($act, $GLOBALS['_OPENPNE_ADMIN_AUTH_ACTIONS'][$auth_type.'_type'])) {
113            admin_client_redirect('top', '指定されたページにはアクセスできません');
114        }
115    }
116}
117
118?>
Note: See TracBrowser for help on using the repository browser.