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

source: OpenPNE/branches/kunitada/MyNETS/trunk/webapp/modules/pc/do/o_login.php @ 3043

Last change on this file since 3043 was 3043, checked in by kunitada, 16 years ago

MyNETS1.0.1 merge

File size: 2.9 KB
Line 
1<?php
2
3/* ========================================================================
4 *
5 * @license This source file is subject to version 3.01 of the PHP license,
6 *              that is available at http://www.php.net/license/3_01.txt
7 *              If you did not receive a copy of the PHP license and are unable
8 *              to obtain it through the world-wide-web, please send a note to
9 *              license@php.net so we can mail you a copy immediately. 
10 *
11 * @category   Application of MyNETS
12 * @project    OpenPNE UsagiProject 2006-2007
13 * @package    MyNETS
14 * @author     UsagiProject <info@usagi.mynets.jp>
15 * @copyright  2006-2007 UsagiProject <author member ad http://usagi.mynets.jp/member.html>
16 * @version    MyNETS,v 1.0.0
17 * @since      File available since Release 1.0.0 Nighty
18 * @chengelog  [2007/02/17] Ver1.1.0Nighty package
19 * ========================================================================
20 */
21
22/**
23 * OpenPNE
24 * @copyright 2005-2006 OpenPNE Project
25 * @link      http://www.tejimaya.com/openpne.shtml
26 *
27 */
28
29class pc_do_o_login extends OpenPNE_Action
30{
31    var $_auth;
32    var $_lc;
33    var $_login_params;
34
35    function isSecure()
36    {
37        return false;
38    }
39
40    function execute($requests)
41    {
42        $this->_login_params = $requests['login_params'];
43        $options = array(
44            'dsn'         => db_get_dsn(),
45            'table'       => MYNETS_PREFIX_NAME . 'c_member_secure',
46            'usernamecol' => 'pc_address',
47            'passwordcol' => 'hashed_password',
48            'cryptType'   => 'md5',
49        );
50        $auth = new OpenPNE_Auth('DB', $options);
51        $this->_auth =& $auth;
52        $auth->setExpire($GLOBALS['OpenPNE']['common']['session_lifetime']);
53        $auth->setIdle($GLOBALS['OpenPNE']['common']['session_idletime']);
54
55        // 現在のセッションを削除
56        $auth->logout();
57
58        if (LOGIN_CHECK_ENABLE) {
59            include_once 'OpenPNE/LoginChecker.php';
60            $options = array(
61                'check_num'   => LOGIN_CHECK_NUM,
62                'check_time'  => LOGIN_CHECK_TIME,
63                'reject_time' => LOGIN_REJECT_TIME,
64            );
65            $this->_lc =& new OpenPNE_LoginChecker($options);
66        }
67
68        if (!$auth->login($requests['is_save'], true)) {
69            $this->_fail_login();
70        }
71
72        if (LOGIN_CHECK_ENABLE && $this->_lc->is_rejected()) {
73            $this->_fail_login();
74        }
75
76        db_api_update_token($auth->uid());
77        $url = OPENPNE_URL;
78        if ($this->_login_params) {
79            $url .= '?' . $this->_login_params;
80        }
81        client_redirect_absolute($url);
82    }
83
84    function _fail_login()
85    {
86        if (LOGIN_CHECK_ENABLE) {
87            $this->_lc->fail_login();
88        }
89        $this->_auth->logout();
90        $p = array('msg_code' => 'login_failed', 'login_params' => $this->_login_params);
91        openpne_redirect('pc', 'page_o_tologin', $p);
92    }
93}
94
95?>
Note: See TracBrowser for help on using the repository browser.