getAll($sql, $arrValues); if (empty($result)) { return false; } else { $data = $result[0]; } // パスワードが合っていれば会員情報をcustomer_dataにセットしてtrueを返す if ( SC_Utils_Ex::sfIsMatchHashPassword($pass, $data['password'], $data['salt']) ) { $this->customer_data = $data; $this->startSession(); return true; } return false; } /** * 会員の登録住所を取得する. * * 配列の1番目に会員登録住所, 追加登録住所が存在する場合は2番目以降に * 設定される. * * @param integer $customer_id 顧客ID * @return array 会員登録住所, 追加登録住所の配列 */ function getCustomerAddress($customer_id) { $objQuery =& SC_Query_Ex::getSingletonInstance(); $from = <<< __EOS__ ( SELECT NULL AS other_deliv_id, customer_id, name01, name02, kana01, kana02, zip01, zip02, pref, addr01, addr02, email, email_mobile, tel01, tel02, tel03, fax01, fax02, fax03 FROM dtb_customer WHERE customer_id = ? UNION ALL SELECT other_deliv_id, customer_id, name01, name02, kana01, kana02, zip01, zip02, pref, addr01, addr02, NULL AS email, NULL AS email_mobile, tel01, tel02, tel03, NULL AS fax01, NULL AS fax02, NULL AS fax03 FROM dtb_other_deliv WHERE customer_id = ? ) AS addrs __EOS__; $objQuery->setOrder("other_deliv_id IS NULL DESC, other_deliv_id DESC"); return $objQuery->select("*", $from, "", array($customer_id, $customer_id)); } /** * 携帯端末IDが一致する会員が存在するかどうかをチェックする。 * FIXME * @return boolean 該当する会員が存在する場合は true、それ以外の場合 * は false を返す。 */ function checkMobilePhoneId() { //docomo用にデータを取り出す。 if(SC_MobileUserAgent_Ex::getCarrier() == 'docomo'){ if($_SESSION['mobile']['phone_id'] == "" && strlen($_SESSION['mobile']['phone_id']) == 0) $_SESSION['mobile']['phone_id'] = SC_MobileUserAgent_Ex::getId(); } if (!isset($_SESSION['mobile']['phone_id']) || $_SESSION['mobile']['phone_id'] === false) { return false; } // 携帯端末IDが一致し、本登録された会員を検索する。 $sql = 'SELECT count(*) FROM dtb_customer WHERE mobile_phone_id = ? AND del_flg = 0 AND status = 2'; $objQuery = new SC_Query_Ex(); $result = $objQuery->count("dtb_customer", "mobile_phone_id = ? AND del_flg = 0 AND status = 2", array($_SESSION['mobile']['phone_id'])); return $result > 0; } /** * 携帯端末IDを使用して会員を検索し、パスワードの照合を行う。 * パスワードが合っている場合は会員情報を取得する。 * * @param string $pass パスワード * @return boolean 該当する会員が存在し、パスワードが合っている場合は true、 * それ以外の場合は false を返す。 */ function getCustomerDataFromMobilePhoneIdPass($pass) { //docomo用にデータを取り出す。 if(SC_MobileUserAgent_Ex::getCarrier() == 'docomo'){ if($_SESSION['mobile']['phone_id'] == "" && strlen($_SESSION['mobile']['phone_id']) == 0) $_SESSION['mobile']['phone_id'] = SC_MobileUserAgent_Ex::getId(); } if (!isset($_SESSION['mobile']['phone_id']) || $_SESSION['mobile']['phone_id'] === false) { return false; } // 携帯端末IDが一致し、本登録された会員を検索する。 $sql = 'SELECT * FROM dtb_customer WHERE mobile_phone_id = ? AND del_flg = 0 AND status = 2'; $objQuery = new SC_Query_Ex(); @list($data) = $objQuery->getAll($sql, array($_SESSION['mobile']['phone_id'])); // パスワードが合っている場合は、会員情報をcustomer_dataに格納してtrueを返す。 if ( SC_Utils_Ex::sfIsMatchHashPassword($pass, $data['password'], $data['salt']) ) { $this->customer_data = $data; $this->startSession(); return true; } return false; } /** * 携帯端末IDを登録する。 * * @return void */ function updateMobilePhoneId() { if (!isset($_SESSION['mobile']['phone_id']) || $_SESSION['mobile']['phone_id'] === false) { return; } if ($this->customer_data['mobile_phone_id'] == $_SESSION['mobile']['phone_id']) { return; } $objQuery = new SC_Query_Ex(); $sqlval = array('mobile_phone_id' => $_SESSION['mobile']['phone_id']); $where = 'customer_id = ? AND del_flg = 0 AND status = 2'; $objQuery->update('dtb_customer', $sqlval, $where, array($this->customer_data['customer_id'])); $this->customer_data['mobile_phone_id'] = $_SESSION['mobile']['phone_id']; } // パスワードを確認せずにログイン function setLogin($email) { // 本登録された会員のみ $sql = "SELECT * FROM dtb_customer WHERE (email = ? OR email_mobile = ?) AND del_flg = 0 AND status = 2"; $objQuery = new SC_Query_Ex(); $result = $objQuery->getAll($sql, array($email, $email)); $data = isset($result[0]) ? $result[0] : ""; $this->customer_data = $data; $this->startSession(); } // セッション情報を最新の情報に更新する function updateSession() { $sql = "SELECT * FROM dtb_customer WHERE customer_id = ? AND del_flg = 0"; $customer_id = $this->getValue('customer_id'); $objQuery = new SC_Query_Ex(); $arrRet = $objQuery->getAll($sql, array($customer_id)); $this->customer_data = isset($arrRet[0]) ? $arrRet[0] : ""; $_SESSION['customer'] = $this->customer_data; } // ログイン情報をセッションに登録し、ログに書き込む function startSession() { $_SESSION['customer'] = $this->customer_data; // セッション情報の保存 GC_Utils_Ex::gfPrintLog("access : user=".$this->customer_data['customer_id'] ."\t"."ip=". $this->getRemoteHost(), CUSTOMER_LOG_REALFILE ); } // ログアウト $_SESSION['customer']を解放し、ログに書き込む function EndSession() { // $_SESSION['customer']の解放 unset($_SESSION['customer']); // トランザクショントークンの破棄 SC_Helper_Session_Ex::destroyToken(); $objSiteSess = new SC_SiteSession_Ex(); $objSiteSess->unsetUniqId(); // ログに記録する GC_Utils_Ex::gfPrintLog("logout : user=".$this->customer_data['customer_id'] ."\t"."ip=". $this->getRemoteHost(), CUSTOMER_LOG_REALFILE ); } // ログインに成功しているか判定する。 function isLoginSuccess($dont_check_email_mobile = false) { // ログイン時のメールアドレスとDBのメールアドレスが一致している場合 if(isset($_SESSION['customer']['customer_id']) && SC_Utils_Ex::sfIsInt($_SESSION['customer']['customer_id'])) { $objQuery = new SC_Query_Ex(); $email = $objQuery->get('email', "dtb_customer", "customer_id = ?", array($_SESSION['customer']['customer_id'])); if($email == $_SESSION['customer']['email']) { // モバイルサイトの場合は携帯のメールアドレスが登録されていることもチェックする。 // ただし $dont_check_email_mobile が true の場合はチェックしない。 if (SC_Display_Ex::detectDevice() == DEVICE_TYPE_MOBILE && !$dont_check_email_mobile) { $email_mobile = $objQuery->get("email_mobile", "dtb_customer", "customer_id = ?", array($_SESSION['customer']['customer_id'])); return isset($email_mobile); } return true; } } return false; } // パラメーターの取得 function getValue($keyname) { // ポイントはリアルタイム表示 if ($keyname == 'point') { $objQuery =& SC_Query_Ex::getSingletonInstance(); $point = $objQuery->get('point', 'dtb_customer', 'customer_id = ?', array($_SESSION['customer']['customer_id'])); $_SESSION['customer']['point'] = $point; return $point; } else { return isset($_SESSION['customer'][$keyname]) ? $_SESSION['customer'][$keyname] : ""; } } // パラメーターのセット function setValue($keyname, $val) { $_SESSION['customer'][$keyname] = $val; } // パラメーターがNULLかどうかの判定 function hasValue($keyname) { if (isset($_SESSION['customer'][$keyname])) { return !SC_Utils_Ex::isBlank($_SESSION['customer'][$keyname]); } return false; } // 誕生日月であるかどうかの判定 function isBirthMonth() { if (isset($_SESSION['customer']['birth'])) { $arrRet = preg_split("|[- :/]|", $_SESSION['customer']['birth']); $birth_month = intval($arrRet[1]); $now_month = intval(date('m')); if($birth_month == $now_month) { return true; } } return false; } /** * $_SERVER['REMOTE_HOST'] または $_SERVER['REMOTE_ADDR'] を返す. * * $_SERVER['REMOTE_HOST'] が取得できない場合は $_SERVER['REMOTE_ADDR'] * を返す. * * @return string $_SERVER['REMOTE_HOST'] 又は $_SERVER['REMOTE_ADDR']の文字列 */ function getRemoteHost() { if (!empty($_SERVER['REMOTE_HOST'])) { return $_SERVER['REMOTE_HOST']; } elseif (!empty($_SERVER['REMOTE_ADDR'])) { return $_SERVER['REMOTE_ADDR']; } else { return ""; } } } ?>