source: branches/feature-module-update/data/class/pages/entry/LC_Page_Entry.php @ 16582

Revision 16582, 41.8 KB checked in by nanasess, 16 years ago (diff)

ライセンス表記変更

  • Property svn:keywords set to Id Revision Date
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24// {{{ requires
25require_once(CLASS_PATH . "pages/LC_Page.php");
26
27/**
28 * 会員登録(入力ページ) のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id:LC_Page_Entry.php 15532 2007-08-31 14:39:46Z nanasess $
33 */
34class LC_Page_Entry extends LC_Page {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'entry/index.tpl';
47        $this->tpl_title .= '会員登録(入力ページ)';
48        $this->year = "";
49        $masterData = new SC_DB_MasterData_Ex();
50        $this->arrPref = $masterData->getMasterData("mtb_pref",
51                                array("pref_id", "pref_name", "rank"));
52        $this->arrJob = $masterData->getMasterData("mtb_job");
53        $this->arrReminder = $masterData->getMasterData("mtb_reminder");
54        $this->objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
55        $this->arrYear = $this->objDate->getYear('', 1950); // 日付プルダウン設定
56        $this->arrMonth = $this->objDate->getMonth();
57        $this->arrDay = $this->objDate->getDay();
58    }
59
60    /**
61     * Page のプロセス.
62     *
63     * @return void
64     */
65    function process() {
66        global $objCampaignSess;
67
68        $objConn = new SC_DbConn();
69        $objView = new SC_SiteView();
70        $objCustomer = new SC_Customer();
71        $objCampaignSess = new SC_CampaignSession();
72        $objDb = new SC_Helper_DB_Ex();
73        $CONF = $objDb->sf_getBasisData();
74        $objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
75        //SSLURL判定
76        if (SSLURL_CHECK == 1){
77            $ssl_url= SC_Utils_Ex::sfRmDupSlash(SSL_URL.$_SERVER['REQUEST_URI']);
78            if (!ereg("^https://", $non_ssl_url)){
79                // TODO エラーメッセージはデフォルト値でOK?
80                SC_Utils_Ex::sfDispSiteError(URL_ERROR);
81            }
82        }
83
84        // レイアウトデザインを取得
85        $layout = new SC_Helper_PageLayout_Ex();
86        $layout->sfGetPageLayout($this, false, DEF_LAYOUT);
87
88        //---- 登録用カラム配列
89        $arrRegistColumn = array(
90                                     array(  "column" => "name01", "convert" => "aKV" ),
91                                     array(  "column" => "name02", "convert" => "aKV" ),
92                                     array(  "column" => "kana01", "convert" => "CKV" ),
93                                     array(  "column" => "kana02", "convert" => "CKV" ),
94                                     array(  "column" => "zip01", "convert" => "n" ),
95                                     array(  "column" => "zip02", "convert" => "n" ),
96                                     array(  "column" => "pref", "convert" => "n" ),
97                                     array(  "column" => "addr01", "convert" => "aKV" ),
98                                     array(  "column" => "addr02", "convert" => "aKV" ),
99                                     array(  "column" => "email", "convert" => "a" ),
100                                     array(  "column" => "email2", "convert" => "a" ),
101                                     array(  "column" => "email_mobile", "convert" => "a" ),
102                                     array(  "column" => "email_mobile2", "convert" => "a" ),
103                                     array(  "column" => "tel01", "convert" => "n" ),
104                                     array(  "column" => "tel02", "convert" => "n" ),
105                                     array(  "column" => "tel03", "convert" => "n" ),
106                                     array(  "column" => "fax01", "convert" => "n" ),
107                                     array(  "column" => "fax02", "convert" => "n" ),
108                                     array(  "column" => "fax03", "convert" => "n" ),
109                                     array(  "column" => "sex", "convert" => "n" ),
110                                     array(  "column" => "job", "convert" => "n" ),
111                                     array(  "column" => "birth", "convert" => "n" ),
112                                     array(  "column" => "reminder", "convert" => "n" ),
113                                     array(  "column" => "reminder_answer", "convert" => "aKV"),
114                                     array(  "column" => "password", "convert" => "a" ),
115                                     array(  "column" => "password02", "convert" => "a" ),
116                                     array(  "column" => "mailmaga_flg", "convert" => "n" ),
117                                 );
118
119        //---- 登録除外用カラム配列
120        $arrRejectRegistColumn = array("year", "month", "day", "email02", "email_mobile02", "password02");
121
122        if ($_SERVER["REQUEST_METHOD"] == "POST") {
123
124            if (!$this->isValidToken()) {
125                SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
126            }
127
128            //-- POSTデータの引き継ぎ
129            $this->arrForm = $_POST;
130
131            if($this->arrForm['year'] == '----') {
132                $this->arrForm['year'] = '';
133            }
134
135            $this->arrForm['email'] = strtolower($this->arrForm['email']);      // emailはすべて小文字で処理
136            $this->arrForm['email02'] = strtolower($this->arrForm['email02']);  // emailはすべて小文字で処理
137
138            //-- 入力データの変換
139            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
140
141            //-- 入力エラーチェック
142            $this->arrErr = $this->lfErrorCheck($this->arrForm);
143
144            if ($this->arrErr || $_POST["mode"] == "return") {      // 入力エラーのチェック
145                foreach($this->arrForm as $key => $val) {
146                    $this->$key = $val;
147                }
148
149            } else {
150
151                //-- 確認
152                if ($_POST["mode"] == "confirm") {
153                    foreach($this->arrForm as $key => $val) {
154                        if ($key != "mode" && $key != "subm") $this->list_data[ $key ] = $val;
155                    }
156                    //パスワード表示
157                    $passlen = strlen($this->arrForm['password']);
158                    $this->passlen = SC_Utils_Ex::lfPassLen($passlen);
159
160                    $this->tpl_css = '/css/layout/entry/confirm.css';
161                    $this->tpl_mainpage = 'entry/confirm.tpl';
162                    $this->tpl_title = '会員登録(確認ページ)';
163
164                }
165
166                //-- 会員登録と完了画面
167                if ($_POST["mode"] == "complete") {
168                    // キャンペーンからの遷移の時用の値
169                    if($objCampaignSess->getIsCampaign()) {
170                        $this->etc_value = "&cp=".$objCampaignSess->getCampaignId();
171                    }
172
173                    // 会員情報の登録
174                    $this->uniqid = $this->lfRegistData ($this->arrForm, $arrRegistColumn, $arrRejectRegistColumn, CUSTOMER_CONFIRM_MAIL);
175
176                    $this->tpl_css = '/css/layout/entry/complete.css';
177                    $this->tpl_mainpage = 'entry/complete.tpl';
178                    $this->tpl_title = '会員登録(完了ページ)';
179
180                    // 完了メール送信
181                    $this->CONF = $CONF;
182                    $this->name01 = $_POST['name01'];
183                    $this->name02 = $_POST['name02'];
184                    $objMailText = new SC_SiteView();
185                    $objMailText->assignobj($this);
186
187                    $mailHelper = new SC_Helper_Mail_Ex();
188                    $objQuery = new SC_Query();
189                    // 仮会員が有効の場合
190                    if(CUSTOMER_CONFIRM_MAIL == true) {
191                        $subject = $mailHelper->sfMakesubject($objQuery, $objMailText, $this, '会員登録のご確認');
192                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_mail.tpl");
193                    } else {
194                        $subject = $mailHelper->sfMakesubject($objQuery, $objMailText, $this, '会員登録のご完了');
195                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_regist_mail.tpl");
196                        // ログイン状態にする
197                        $objCustomer->setLogin($_POST["email"]);
198                    }
199
200                    $objMail = new SC_SendMail();
201                    $objMail->setItem(
202                                        ''                                  // 宛先
203                                        , $subject                          // サブジェクト
204                                        , $toCustomerMail                   // 本文
205                                        , $CONF["email03"]                  // 配送元アドレス
206                                        , $CONF["shop_name"]                // 配送元 名前
207                                        , $CONF["email03"]                  // reply_to
208                                        , $CONF["email04"]                  // return_path
209                                        , $CONF["email04"]                  //  Errors_to
210                                    );
211                    // 宛先の設定
212                    $name = $_POST["name01"] . $_POST["name02"] ." 様";
213                    $objMail->setTo($_POST["email"], $name);
214                    $objMail->sendMail();
215
216                    // 完了ページに移動させる。
217                    $this->sendRedirect($this->getLocation("./complete.php"));
218                    exit;
219                }
220            }
221        }
222
223        if($this->year == '') {
224            $this->year = '----';
225        }
226
227        $this->transactionid = $this->getToken();
228
229        //---- ページ表示
230        $objView->assignobj($this);
231        // フレームを選択(キャンペーンページから遷移なら変更)
232        $objCampaignSess->pageView($objView);
233    }
234
235    /**
236     * モバイルページを初期化する.
237     *
238     * @return void
239     */
240    function mobileInit() {
241        $this->init();
242        $this->tpl_mainpage = 'entry/index.tpl';        // メインテンプレート
243        $this->tpl_title .= '会員登録(1/3)';            // ページタイトル
244    }
245
246    /**
247     * Page のプロセス(モバイル).
248     *
249     * @return void
250     */
251    function mobileProcess() {
252        //---- ページ初期設定
253        $objDb = new SC_Helper_DB_Ex();
254        $objMobile = new SC_Helper_Mobile_Ex();
255        $CONF = $objDb->sf_getBasisData();                  // 店舗基本情報
256        $objConn = new SC_DbConn();
257        $objView = new SC_MobileView();
258        $objCustomer = new SC_Customer();
259        $objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
260
261        // 空メール
262        if (isset($_SESSION['mobile']['kara_mail_from'])) {
263            $this->tpl_kara_mail_from = $_POST['email'] = $_SESSION['mobile']['kara_mail_from'];
264        } elseif (MOBILE_USE_KARA_MAIL) {
265            $token = $objMobile->gfPrepareKaraMail('entry/index.php');
266            if ($token !== false) {
267                $this->tpl_mainpage = 'entry/mail.tpl';
268                $this->tpl_title = '会員登録(空メール)';
269                $this->tpl_kara_mail_to = MOBILE_KARA_MAIL_ADDRESS_USER . MOBILE_KARA_MAIL_ADDRESS_DELIMITER . 'entry_' . $token . '@' . MOBILE_KARA_MAIL_ADDRESS_DOMAIN;
270                $this->tpl_from_address = $CONF['email03'];
271            }
272        }
273
274        //SSLURL判定
275        if (SSLURL_CHECK == 1){
276            $ssl_url= SC_Utils_Ex::sfRmDupSlash(MOBILE_SSL_URL.$_SERVER['REQUEST_URI']);
277            if (!ereg("^https://", $non_ssl_url)){
278                SC_Utils_Ex::sfDispSiteError(URL_ERROR, "", false, "", true);
279            }
280        }
281
282        // レイアウトデザインを取得
283        $objLayout = new SC_Helper_PageLayout_Ex();
284        $objLayout->sfGetPageLayout($this, false, DEF_LAYOUT);
285
286        //---- 登録用カラム配列
287        $arrRegistColumn = array(
288                                 array(  "column" => "name01", "convert" => "aKV" ),
289                                 array(  "column" => "name02", "convert" => "aKV" ),
290                                 array(  "column" => "kana01", "convert" => "CKV" ),
291                                 array(  "column" => "kana02", "convert" => "CKV" ),
292                                 array(  "column" => "zip01", "convert" => "n" ),
293                                 array(  "column" => "zip02", "convert" => "n" ),
294                                 array(  "column" => "pref", "convert" => "n" ),
295                                 array(  "column" => "addr01", "convert" => "aKV" ),
296                                 array(  "column" => "addr02", "convert" => "aKV" ),
297                                 array(  "column" => "email", "convert" => "a" ),
298                                 array(  "column" => "email2", "convert" => "a" ),
299                                 array(  "column" => "email_mobile", "convert" => "a" ),
300                                 array(  "column" => "email_mobile2", "convert" => "a" ),
301                                 array(  "column" => "tel01", "convert" => "n" ),
302                                 array(  "column" => "tel02", "convert" => "n" ),
303                                 array(  "column" => "tel03", "convert" => "n" ),
304                                 array(  "column" => "fax01", "convert" => "n" ),
305                                 array(  "column" => "fax02", "convert" => "n" ),
306                                 array(  "column" => "fax03", "convert" => "n" ),
307                                 array(  "column" => "sex", "convert" => "n" ),
308                                 array(  "column" => "job", "convert" => "n" ),
309                                 array(  "column" => "birth", "convert" => "n" ),
310                                 array(  "column" => "reminder", "convert" => "n" ),
311                                 array(  "column" => "reminder_answer", "convert" => "aKV"),
312                                 array(  "column" => "password", "convert" => "a" ),
313                                 array(  "column" => "password02", "convert" => "a" ),
314                                 array(  "column" => "mailmaga_flg", "convert" => "n" ),
315                                 );
316
317        //---- 登録除外用カラム配列
318        $arrRejectRegistColumn = array("year", "month", "day", "email02", "email_mobile02", "password02");
319
320        if ($_SERVER["REQUEST_METHOD"] == "POST") {
321
322            //-- POSTデータの引き継ぎ
323            $this->arrForm = $_POST;
324
325            if(isset($this->arrForm['year'])
326               && $this->arrForm['year'] == '----') {
327                $this->arrForm['year'] = '';
328            }
329
330            $this->arrForm['email'] = strtolower($this->arrForm['email']);      // emailはすべて小文字で処理
331
332            //-- 入力データの変換
333            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
334
335            // 戻るボタン用処理
336            if (!empty($_POST["return"])) {
337                switch ($_POST["mode"]) {
338                case "complete":
339                    $_POST["mode"] = "set3";
340                    break;
341                case "confirm":
342                    $_POST["mode"] = "set2";
343                    break;
344                default:
345                    $_POST["mode"] = "set1";
346                    break;
347                }
348            }
349
350            //-- 入力エラーチェック
351            if ($_POST["mode"] == "set1") {
352                $this->arrErr = $this->lfErrorCheck1($this->arrForm);
353                $this->tpl_mainpage = 'entry/index.tpl';
354                $this->tpl_title = '会員登録(1/3)';
355            } elseif ($_POST["mode"] == "set2") {
356                $this->arrErr = $this->lfErrorCheck2($this->arrForm);
357                $this->tpl_mainpage = 'entry/set1.tpl';
358                $this->tpl_title = '会員登録(2/3)';
359            } else {
360                $this->arrErr = $this->lfErrorCheck3($this->arrForm);
361                $this->tpl_mainpage = 'entry/set2.tpl';
362                $this->tpl_title = '会員登録(3/3)';
363            }
364
365            foreach($this->arrForm as $key => $val) {
366                $this->$key = $val;
367            }
368
369            if ($this->arrErr || !empty($_POST["return"])) {        // 入力エラーのチェック
370
371                //-- データの設定
372                if ($_POST["mode"] == "set1") {
373                    $checkVal = array("email", "password", "reminder", "reminder_answer", "name01", "name02", "kana01", "kana02");
374                } elseif ($_POST["mode"] == "set2") {
375                    $checkVal = array("sex", "year", "month", "day", "zip01", "zip02");
376                } else {
377                    $checkVal = array("pref", "addr01", "addr02", "tel01", "tel02", "tel03", "mailmaga_flg");
378                }
379
380                foreach($this->arrForm as $key => $val) {
381                    if ($key != "mode" && $key != "submit" && $key != "return" && $key != session_name() && !in_array($key, $checkVal))
382                        $this->list_data[ $key ] = $val;
383                }
384
385
386
387            } else {
388
389                //-- テンプレート設定
390                if ($_POST["mode"] == "set1") {
391                    $this->tpl_mainpage = 'entry/set1.tpl';
392                    $this->tpl_title = '会員登録(2/3)';
393                } elseif ($_POST["mode"] == "set2") {
394                    $this->tpl_mainpage = 'entry/set2.tpl';
395                    $this->tpl_title = '会員登録(3/3)';
396
397                    if (@$this->arrForm['pref'] == "" && @$this->arrForm['addr01'] == "" && @$this->arrForm['addr02'] == "") {
398                        $address = $this->lfGetAddress($_REQUEST['zip01'].$_REQUEST['zip02']);
399                        $this->pref = @$address[0]['state'];
400                        $this->addr01 = @$address[0]['city'] . @$address[0]['town'];
401                    }
402                } elseif ($_POST["mode"] == "confirm") {
403                    //パスワード表示
404                    $passlen = strlen($this->arrForm['password']);
405                    $this->passlen = $this->lfPassLen($passlen);
406
407                    //メール受け取り
408                    if (!isset($this->arrForm['mailmaga_flg'])) $this->arrForm['mailmaga_flg']  = "";
409                    if (strtolower($this->arrForm['mailmaga_flg']) == "on") {
410                        $this->arrForm['mailmaga_flg']  = "2";
411                    } else {
412                        $this->arrForm['mailmaga_flg']  = "3";
413                    }
414
415                    $this->tpl_mainpage = 'entry/confirm.tpl';
416                    $this->tpl_title = '会員登録(確認ページ)';
417
418                }
419
420                //-- データ設定
421                unset($this->list_data);
422                if ($_POST["mode"] == "set1") {
423                    $checkVal = array("sex", "year", "month", "day", "zip01", "zip02");
424                } elseif ($_POST["mode"] == "set2") {
425                    $checkVal = array("pref", "addr01", "addr02", "tel01", "tel02", "tel03", "mailmaga_flg");
426                } else {
427                    $checkVal = array();
428                }
429
430                foreach($this->arrForm as $key => $val) {
431                    if ($key != "mode" && $key != "submit" && $key != "confirm" && $key != "return" && $key != session_name() && !in_array($key, $checkVal)) {
432                        $this->list_data[ $key ] = $val;
433                    }
434                }
435
436
437                //-- 仮登録と完了画面
438                if ($_POST["mode"] == "complete") {
439
440                    // 確認画面で再度エラーチェックを行う。(画面1)
441                    $arrErr = $this->lfErrorCheck1($this->arrForm);
442                    if(count($arrErr) > 0){
443                        $this->tpl_mainpage = 'entry/index.tpl';
444                        $this->tpl_title = '会員登録(1/3)';
445                        $this->arrErr = $arrErr;
446                        //---- ページ表示
447                        $objView->assignobj($this);
448                        $objView->display(SITE_FRAME);
449                        exit();
450                    }
451
452                    // 確認画面で再度エラーチェックを行う。(画面2)
453                    $arrErr = $this->lfErrorCheck2($this->arrForm);
454                    if(count($arrErr) > 0){
455                        $this->tpl_mainpage = 'entry/set1.tpl';
456                        $this->tpl_title = '会員登録(2/3)';
457                        $this->arrErr = $arrErr;
458                        //---- ページ表示
459                        $objView->assignobj($this);
460                        $objView->display(SITE_FRAME);
461                        exit();
462                    }
463
464                    // 確認画面で再度エラーチェックを行う。(画面3)
465                    $arrErr = $this->lfErrorCheck3($this->arrForm);
466                    if(count($arrErr) > 0){
467                        $this->tpl_mainpage = 'entry/set2.tpl';
468                        $this->tpl_title = '会員登録(3/3)';
469                        $this->arrErr = $arrErr;
470                        //---- ページ表示
471                        $objView->assignobj($this);
472                        $objView->display(SITE_FRAME);
473                        exit();
474                    }
475
476                    $this->uniqid = $this->lfRegistData ($this->arrForm, $arrRegistColumn, $arrRejectRegistColumn, CUSTOMER_CONFIRM_MAIL, true, $this->arrForm["email"]);
477
478                    // 空メールを受信済みの場合はすぐに本登録完了にする。
479                    if (isset($_SESSION['mobile']['kara_mail_from'])) {
480
481                        $param = array("mode" => "regist",
482                                       "id" => $this->uniqid,
483                                       session_name() => session_id());
484                        $this->sendRedirect($this->getLocation(MOBILE_URL_DIR . "regist/index.php", $param));
485                        exit;
486                    }
487
488                    $this->tpl_mainpage = 'entry/complete.tpl';
489                    $this->tpl_title = '会員登録(完了ページ)';
490
491                    $objMobile->sfMobileSetExtSessionId('id', $this->uniqid, 'regist/index.php');
492
493                    // 仮登録完了メール送信
494                    $this->CONF = $CONF;
495                    $this->to_name01 = $_POST['name01'];
496                    $this->to_name02 = $_POST['name02'];
497                    $objMailText = new SC_MobileView();
498                    $objMailText->assignobj($this);
499                    $objHelperMail = new SC_Helper_Mail_Ex();
500                    $objQuery = new SC_Query();
501
502                    // 仮会員が有効の場合
503                    if(CUSTOMER_CONFIRM_MAIL == true) {
504
505                        $subject = $objHelperMail->sfMakeSubject($objQuery, $objMailText, $this, '会員登録のご確認');
506                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_mail.tpl");
507                    } else {
508                        $subject = $objHelperMail->sfMakesubject($objQuery, $objMailText, $this, '会員登録のご完了');
509                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_regist_mail.tpl");
510                        // ログイン状態にする
511                        $objCustomer->setLogin($_POST["email"]);
512                    }
513
514                    $objMail = new SC_SendMail();
515                    $objMail->setItem(
516                                      ''                                    // 宛先
517                                      , $subject                            // サブジェクト
518                                      , $toCustomerMail                 // 本文
519                                      , $CONF["email03"]                    // 配送元アドレス
520                                      , $CONF["shop_name"]              // 配送元 名前
521                                      , $CONF["email03"]                    // reply_to
522                                      , $CONF["email04"]                    // return_path
523                                      , $CONF["email04"]                    //  Errors_to
524                                      , $CONF["email01"]                    //  Bcc
525                                      );
526                    // 宛先の設定
527                    $name = $_POST["name01"] . $_POST["name02"] ." 様";
528                    $objMail->setTo($_POST["email"], $name);
529                    $objMail->sendMail();
530
531                    // 完了ページに移動させる。
532                    $this->sendRedirect($this->getLocation("./complete.php"), true);
533                    exit;
534                }
535            }
536        }
537
538        //---- ページ表示
539        $objView->assignobj($this);
540        $objView->display(SITE_FRAME);
541    }
542
543    /**
544     * デストラクタ.
545     *
546     * @return void
547     */
548    function destroy() {
549        parent::destroy();
550    }
551
552    // }}}
553    // {{{ protected functions
554
555    // 会員情報の登録
556    function lfRegistData ($array, $arrRegistColumn, $arrRejectRegistColumn, $confirm_flg, $isMobile = false, $email_mobile = "") {
557        $objConn = new SC_DbConn();
558
559        // 登録データの生成
560        foreach ($arrRegistColumn as $data) {
561            if (strlen($array[ $data["column"] ]) > 0 && ! in_array($data["column"], $arrRejectRegistColumn)) {
562                $arrRegist[ $data["column"] ] = $array[ $data["column"] ];
563            }
564        }
565
566        // 誕生日が入力されている場合
567        if (strlen($array["year"]) > 0 ) {
568            $arrRegist["birth"] = $array["year"] ."/". $array["month"] ."/". $array["day"] ." 00:00:00";
569        }
570
571        // パスワードの暗号化
572        $arrRegist["password"] = sha1($arrRegist["password"] . ":" . AUTH_MAGIC);
573
574        // 仮会員登録の場合
575        if($confirm_flg == true) {
576            // 重複しない会員登録キーを発行する。
577            $count = 1;
578            while ($count != 0) {
579                $uniqid = SC_Utils_Ex::sfGetUniqRandomId("t");
580                $count = $objConn->getOne("SELECT COUNT(*) FROM dtb_customer WHERE secret_key = ?", array($uniqid));
581            }
582            switch($array["mailmaga_flg"]) {
583                case 1:
584                    $arrRegist["mailmaga_flg"] = 4;
585                    break;
586                case 2:
587                    $arrRegist["mailmaga_flg"] = 5;
588                    break;
589                default:
590                    $arrRegist["mailmaga_flg"] = 6;
591                    break;
592            }
593
594            $arrRegist["status"] = "1";             // 仮会員
595        } else {
596            // 重複しない会員登録キーを発行する。
597            $count = 1;
598            while ($count != 0) {
599                $uniqid = SC_Utils_Ex::sfGetUniqRandomId("r");
600                $count = $objConn->getOne("SELECT COUNT(*) FROM dtb_customer WHERE secret_key = ?", array($uniqid));
601            }
602            $arrRegist["status"] = "2";             // 本会員
603        }
604
605        /*
606          secret_keyは、テーブルで重複許可されていない場合があるので、
607          本会員登録では利用されないがセットしておく。
608        */
609        $arrRegist["secret_key"] = $uniqid;     // 会員登録キー
610        $arrRegist["create_date"] = "now()";    // 作成日
611        $arrRegist["update_date"] = "now()";    // 更新日
612        $arrRegist["first_buy_date"] = "";      // 最初の購入日
613
614        if ($isMobile) {
615            // 携帯メールアドレス
616            $arrRegist['email_mobile'] = $arrRegist['email'];
617        }
618
619        //-- 仮登録実行
620        $objConn->query("BEGIN");
621
622        $objQuery = new SC_Query();
623        $objQuery->insert("dtb_customer", $arrRegist);
624
625
626    /* メルマガ会員機能は現在停止中 2007/03/07
627
628
629        //-- 非会員でメルマガ登録しているかの判定
630        $sql = "SELECT count(*) FROM dtb_customer_mail WHERE email = ?";
631        $mailResult = $objConn->getOne($sql, array($arrRegist["email"]));
632
633        //-- メルマガ仮登録実行
634        $arrRegistMail["email"] = $arrRegist["email"];
635        if ($array["mailmaga_flg"] == 1) {
636            $arrRegistMail["mailmaga_flg"] = 4;
637        } elseif ($array["mailmaga_flg"] == 2) {
638            $arrRegistMail["mailmaga_flg"] = 5;
639        } else {
640            $arrRegistMail["mailmaga_flg"] = 6;
641        }
642        $arrRegistMail["update_date"] = "now()";
643
644        // 非会員でメルマガ登録している場合
645        if ($mailResult == 1) {
646            $objQuery->update("dtb_customer_mail", $arrRegistMail, "email = '" .addslashes($arrRegistMail["email"]). "'");
647        } else {                // 新規登録の場合
648            $arrRegistMail["create_date"] = "now()";
649            $objQuery->insert("dtb_customer_mail", $arrRegistMail);
650        }
651    */
652        $objConn->query("COMMIT");
653
654        return $uniqid;
655    }
656
657    //---- 取得文字列の変換
658    function lfConvertParam($array, $arrRegistColumn) {
659        /*
660         *  文字列の変換
661         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
662         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
663         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
664         *  n :  「全角」数字を「半角(ハンカク)」に変換
665         *  a :  全角英数字を半角英数字に変換する
666         */
667        // カラム名とコンバート情報
668        foreach ($arrRegistColumn as $data) {
669            $arrConvList[ $data["column"] ] = $data["convert"];
670        }
671        // 文字変換
672        foreach ($arrConvList as $key => $val) {
673            // POSTされてきた値のみ変換する。
674            if(isset($array[$key]) && strlen($array[$key]) > 0) {
675                $array[$key] = mb_convert_kana($array[$key] ,$val);
676            }
677        }
678        return $array;
679    }
680
681    //---- 入力エラーチェック
682    function lfErrorCheck($array) {
683
684        $objErr = new SC_CheckError($array);
685
686        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
687        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
688        $objErr->doFunc(array("フリガナ(セイ)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
689        $objErr->doFunc(array("フリガナ(メイ)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
690        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
691        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
692        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
693        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
694        $objErr->doFunc(array("ご住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
695        $objErr->doFunc(array("ご住所2", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
696        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK", "SPTAB_CHECK" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
697        $objErr->doFunc(array('メールアドレス(確認)', "email02", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK","SPTAB_CHECK" , "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
698        $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', "email", "email02") ,array("EQUAL_CHECK"));
699
700        //現会員の判定 → 現会員もしくは仮登録中は、メアド一意が前提になってるので同じメアドで登録不可
701        if (strlen($array["email"]) > 0) {
702            $array["email"] = strtolower($array["email"]);
703            $objQuery = new SC_Query();
704            $arrRet = $objQuery->select("email, update_date, del_flg", "dtb_customer","email = ? ORDER BY del_flg", array($array["email"]));
705
706            if(count($arrRet) > 0) {
707                if($arrRet[0]['del_flg'] != '1') {
708                    // 会員である場合
709                    if (!isset($objErr->arrErr['email'])) $objErr->arrErr['email'] = "";
710                    $objErr->arrErr["email"] .= "※ すでに会員登録で使用されているメールアドレスです。<br />";
711                } else {
712                    // 退会した会員である場合
713                    $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrRet[0]['update_date']);
714                    $now_time = time();
715                    $pass_time = $now_time - $leave_time;
716                    // 退会から何時間-経過しているか判定する。
717                    $limit_time = ENTRY_LIMIT_HOUR * 3600;
718                    if($pass_time < $limit_time) {
719                        if (!isset($objErr->arrErr['email'])) $objErr->arrErr['email'] = "";
720                        $objErr->arrErr["email"] .= "※ 退会から一定期間の間は、同じメールアドレスを使用することはできません。<br />";
721                    }
722                }
723            }
724        }
725
726        $objErr->doFunc(array("お電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK" ));
727        $objErr->doFunc(array("お電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK" ));
728        $objErr->doFunc(array("お電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK" ));
729        $objErr->doFunc(array("お電話番号", "tel01", "tel02", "tel03",TEL_ITEM_LEN) ,array("TEL_CHECK"));
730        $objErr->doFunc(array("FAX番号1", 'fax01'), array("SPTAB_CHECK"));
731        $objErr->doFunc(array("FAX番号2", 'fax02'), array("SPTAB_CHECK"));
732        $objErr->doFunc(array("FAX番号3", 'fax03'), array("SPTAB_CHECK"));
733        $objErr->doFunc(array("FAX番号", "fax01", "fax02", "fax03", TEL_ITEM_LEN) ,array("TEL_CHECK"));
734        $objErr->doFunc(array("ご性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
735        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
736        $objErr->doFunc(array("パスワード(確認)", 'password02', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
737        $objErr->doFunc(array('パスワード', 'パスワード(確認)', "password", "password02") ,array("EQUAL_CHECK"));
738        $objErr->doFunc(array("パスワードを忘れたときのヒント 質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
739        $objErr->doFunc(array("パスワードを忘れたときのヒント 答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK","SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
740        $objErr->doFunc(array("メールマガジン", "mailmaga_flg") ,array("SELECT_CHECK", "NUM_CHECK"));
741
742        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_DATE"));
743        $objErr->doFunc(array("メールマガジン", 'mailmaga_flg'), array("SELECT_CHECK"));
744        return $objErr->arrErr;
745    }
746
747    //確認ページ用パスワード表示用
748
749    function lfPassLen($passlen){
750        $ret = "";
751        for ($i=0;$i<$passlen;true){
752        $ret.="*";
753        $i++;
754        }
755        return $ret;
756    }
757
758    // }}}
759    // {{{ mobile functions
760
761    // 郵便番号から住所の取得
762    function lfGetAddress($zipcode) {
763
764        $conn = new SC_DBconn(ZIP_DSN);
765
766        // 郵便番号検索文作成
767        $zipcode = mb_convert_kana($zipcode ,"n");
768        $sqlse = "SELECT state, city, town FROM mtb_zip WHERE zipcode = ?";
769
770        $data_list = $conn->getAll($sqlse, array($zipcode));
771
772        // インデックスと値を反転させる。
773        $arrREV_PREF = array_flip($this->arrPref);
774
775        /*
776         総務省からダウンロードしたデータをそのままインポートすると
777         以下のような文字列が入っているので  対策する。
778         ・(1・19丁目)
779         ・以下に掲載がない場合
780        */
781        $town =  $data_list[0]['town'];
782        $town = ereg_replace("(.*)$","",$town);
783        $town = ereg_replace("以下に掲載がない場合","",$town);
784        $data_list[0]['town'] = $town;
785        $data_list[0]['state'] = $arrREV_PREF[$data_list[0]['state']];
786
787        return $data_list;
788    }
789
790    //---- 入力エラーチェック
791    function lfErrorCheck1($array) {
792
793        $objErr = new SC_CheckError($array);
794        $objDb = new SC_Helper_DB_Ex();
795
796        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
797        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
798        $objErr->doFunc(array("お名前(カナ/姓)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
799        $objErr->doFunc(array("お名前(カナ/名)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
800        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK", "SPTAB_CHECK" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK", "MOBILE_EMAIL_CHECK"));
801
802        //現会員の判定 → 現会員もしくは仮登録中は、メアド一意が前提になってるので同じメアドで登録不可
803        if (strlen($array["email"]) > 0) {
804            $array['email'] = strtolower($array['email']);
805            $objQuery = new SC_Query();
806            $arrRet = $objQuery->select("email, update_date, del_flg", "dtb_customer","email = ? OR email_mobile = ? ORDER BY del_flg", array($array["email"], $array["email"]));
807
808            if(count($arrRet) > 0) {
809                if($arrRet[0]['del_flg'] != '1') {
810                    // 会員である場合
811                    $objErr->arrErr["email"] .= "※ すでに会員登録で使用されているメールアドレスです。<br />";
812                } else {
813                    // 退会した会員である場合
814                    $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrRet[0]['update_date']);
815                    $now_time = time();
816                    $pass_time = $now_time - $leave_time;
817                    // 退会から何時間-経過しているか判定する。
818                    $limit_time = ENTRY_LIMIT_HOUR * 3600;
819                    if($pass_time < $limit_time) {
820                        $objErr->arrErr["email"] .= "※ 退会から一定期間の間は、同じメールアドレスを使用することはできません。<br />";
821                    }
822                }
823            }
824        }
825
826        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
827        $objErr->doFunc(array("パスワード確認用の質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
828        $objErr->doFunc(array("パスワード確認用の質問の答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK","SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
829
830        return $objErr->arrErr;
831    }
832
833    //---- 入力エラーチェック
834    function lfErrorCheck2($array) {
835        $objErr = new SC_CheckError($array);
836
837        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
838        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
839        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
840
841        $objErr->doFunc(array("性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
842        $objErr->doFunc(array("生年月日 (年)", "year", 4), array("EXIST_CHECK", "SPTAB_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
843        if (!isset($objErr->arrErr['year'])) {
844            $objErr->doFunc(array("生年月日 (年)", "year", $this->objDate->getStartYear()), array("MIN_CHECK"));
845            $objErr->doFunc(array("生年月日 (年)", "year", $this->objDate->getEndYear()), array("MAX_CHECK"));
846        }
847        $objErr->doFunc(array("生年月日 (月日)", "month", "day"), array("SELECT_CHECK"));
848        if (!isset($objErr->arrErr['year']) && !isset($objErr->arrErr['month']) && !isset($objErr->arrErr['day'])) {
849            $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_DATE"));
850        }
851
852        return $objErr->arrErr;
853    }
854
855    //---- 入力エラーチェック
856    function lfErrorCheck3($array) {
857        $objErr = new SC_CheckError($array);
858
859        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
860        $objErr->doFunc(array("市区町村", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
861        $objErr->doFunc(array("番地", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
862        $objErr->doFunc(array("電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK" ));
863        $objErr->doFunc(array("電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK" ));
864        $objErr->doFunc(array("電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK" ));
865        $objErr->doFunc(array("電話番号", "tel01", "tel02", "tel03",TEL_ITEM_LEN) ,array("TEL_CHECK"));
866
867        return $objErr->arrErr;
868    }
869
870}
871?>
Note: See TracBrowser for help on using the repository browser.