source: branches/version-2_5-dev/data/class/pages/entry/LC_Page_Entry.php @ 18788

Revision 18788, 45.6 KB checked in by nanasess, 14 years ago (diff)

シーケンス値の出力に SC_Query::nextVal() を使用するよう修正(#780)

  • インストーラでシーケンスの生成/削除を行うよう修正
  • html/install/sql/insert_data.sql を, シーケンス値を含めたものに修正
  • PostgreSQL の serial 型を int 型に修正
  • MySQL で auto_increment を使用しないように修正
  • シーケンスIDを使用するテーブルへの INSERT を行っている個所で, 事前にシーケンス値を取得するよう修正
  • FIXME data/class/pages/admin/system/LC_Page_Admin_System_Bkup.php を要改修
  • Property svn:eol-style set to LF
  • 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-2010 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     * 以下のプロパティの初期化を行う.
43     * - tpl_mainpage
44     * - tpl_title
45     * - year
46     * - arrPref (mtb_pref からマスタデータを取得する)
47     * - arrJob (mtb_job からマスタデータを取得する)
48     * - arrReminder (mtb_reminder からマスタデータを取得する)
49     * - arrYear
50     * - arrMonth
51     * - arrDay
52     *
53     * また, クライアント・プロキシのキャッシュ制御を "nocache" に設定する.
54     *
55     * @return void
56     */
57    function init() {
58        parent::init();
59        $this->tpl_mainpage = 'entry/index.tpl';
60        $this->tpl_title .= '会員登録(入力ページ)';
61        $this->year = "";
62        $masterData = new SC_DB_MasterData_Ex();
63        $this->arrPref = $masterData->getMasterData("mtb_pref",
64                                array("pref_id", "pref_name", "rank"));
65        $this->arrJob = $masterData->getMasterData("mtb_job");
66        $this->arrReminder = $masterData->getMasterData("mtb_reminder");
67       
68        // 生年月日選択肢の取得
69        $objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
70        $this->arrYear = $objDate->getYear('', 1950, '');
71        $this->arrMonth = $objDate->getMonth(true);
72        $this->arrDay = $objDate->getDay(true);
73       
74        $this->httpCacheControl('nocache');
75    }
76
77    /**
78     * Page のプロセス.
79     *
80     * <b>概要</b>
81     *
82     * 一般ユーザーが個人情報を入力し, 会員登録を行う.
83     * 会員登録完了時, ユーザーのメールアドレスと店舗管理者へ会員登録完了
84     * の通知メールを送信し, 登録完了画面へリダイレクトを行う.
85     *
86     * <b>アクター</b>
87     *
88     * - 一般ユーザー
89     *
90     * <b>基本フロー</b>
91     *
92     * 遷移の際, トランザクショントークンを使用し, 不正な遷移が発生した場合は
93     * エラーページを表示する.
94     *
95     * <ol>
96     *   <li>入力フォーム($_POST['mode'] == '')
97     *     <ul>
98     *       <li>入力チェックがエラーの場合($_POST['mode'] == 'return')</li>
99     *       <li>$_POST が空かつ, $_SERVER['HTTP_REFERER'] に "kiyaku.php"
100     *       の文字列が存在しない場合はエラーページを表示する</li>
101     *     </ul>
102     *   </li>
103     *   <li>入力確認画面($_POST['mode'] == 'confirm')</li>
104     *   <li>登録完了処理($_POST['mode'] == 'complete')</li>
105     *   <li>登録完了画面へリダイレクトを行う</li>
106     * </ol>
107     *
108     * 仮会員登録が有効な場合, 3 の登録完了画面の前に, 仮会員登録メールを送信し,
109     * ユーザーが本会員登録用 URL をクリックした時点で登録を完了する.
110     *
111     * <b>代替フロー</b>
112     *
113     * なし
114     *
115     * <b>特別な要件事項</b>
116     *
117     * - ユーザーが入力した情報は, 空文字, 改行を削除する.
118     * - メールアドレスは, すべて小文字に変換し, DBに格納する.
119     *
120     * <b>事前条件</b>
121     *
122     * アクターがシステムに訪問していること.
123     *
124     * <b>事後条件</b>
125     *
126     * アクターの会員登録が完了していること.
127     *
128     * <b>サブユースケース</b>
129     *
130     * なし
131     *
132     * <b>使用するスーパーグローバル変数</b>
133     *
134     * - $_SERVER['PHP_SELF']
135     * - $_SERVER['HTTP_REFERER']
136     * - $_SERVER["REQUEST_METHOD"]
137     * - $_POST["name01"]
138     * - $_POST["name02"]
139     * - $_POST["kana01"]
140     * - $_POST["kana02"]
141     * - $_POST["zip01"]
142     * - $_POST["zip02"]
143     * - $_POST["addr01"]
144     * - $_POST["addr02"]
145     * - $_POST["tel01"]
146     * - $_POST["tel02"]
147     * - $_POST["tel03"]
148     * - $_POST["fax01"]
149     * - $_POST["fax02"]
150     * - $_POST["fax03"]
151     * - $_POST["email"]
152     * - $_POST["email02"]
153     * - $_POST["password"]
154     * - $_POST["password02"]
155     * - $_POST["reminder_answer"]
156     * - $_POST["mode"]('return', 'confirm', 'complate')
157     *
158     * @global $objCampaignSess
159     * @return void
160     */
161    function process() {
162        global $objCampaignSess;
163
164        $objView = new SC_SiteView();
165        $objCustomer = new SC_Customer();
166        $objCampaignSess = new SC_CampaignSession();
167        $objDb = new SC_Helper_DB_Ex();
168        $CONF = $objDb->sf_getBasisData();
169
170        $ssl_url  = rtrim(SSL_URL,"/");
171        $ssl_url .= $_SERVER['PHP_SELF'];
172
173        // 規約ページからの遷移でなければエラー画面へ遷移する
174        if (empty($_POST) && !preg_match('/kiyaku.php/', basename($_SERVER['HTTP_REFERER']))) {
175            SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
176        }
177
178        // レイアウトデザインを取得
179        $objLayout = new SC_Helper_PageLayout_Ex();
180        $objLayout->sfGetPageLayout($this, false, DEF_LAYOUT);
181
182        //---- 登録用カラム配列
183        $arrRegistColumn = array(
184                                     array(  "column" => "name01", "convert" => "aKV" ),
185                                     array(  "column" => "name02", "convert" => "aKV" ),
186                                     array(  "column" => "kana01", "convert" => "CKV" ),
187                                     array(  "column" => "kana02", "convert" => "CKV" ),
188                                     array(  "column" => "zip01", "convert" => "n" ),
189                                     array(  "column" => "zip02", "convert" => "n" ),
190                                     array(  "column" => "pref", "convert" => "n" ),
191                                     array(  "column" => "addr01", "convert" => "aKV" ),
192                                     array(  "column" => "addr02", "convert" => "aKV" ),
193                                     array(  "column" => "email", "convert" => "a" ),
194                                     array(  "column" => "email02", "convert" => "a" ),
195                                     array(  "column" => "email_mobile", "convert" => "a" ),
196                                     array(  "column" => "email_mobile02", "convert" => "a" ),
197                                     array(  "column" => "tel01", "convert" => "n" ),
198                                     array(  "column" => "tel02", "convert" => "n" ),
199                                     array(  "column" => "tel03", "convert" => "n" ),
200                                     array(  "column" => "fax01", "convert" => "n" ),
201                                     array(  "column" => "fax02", "convert" => "n" ),
202                                     array(  "column" => "fax03", "convert" => "n" ),
203                                     array(  "column" => "sex", "convert" => "n" ),
204                                     array(  "column" => "job", "convert" => "n" ),
205                                     array(  "column" => "birth", "convert" => "n" ),
206                                     array(  "column" => "year", "convert" => "n" ),
207                                     array(  "column" => "month", "convert" => "n" ),
208                                     array(  "column" => "day", "convert" => "n" ),
209                                     array(  "column" => "reminder", "convert" => "n" ),
210                                     array(  "column" => "reminder_answer", "convert" => "aKV"),
211                                     array(  "column" => "password", "convert" => "a" ),
212                                     array(  "column" => "password02", "convert" => "a" ),
213                                     array(  "column" => "mailmaga_flg", "convert" => "n" ),
214                                 );
215
216        //---- 登録除外用カラム配列
217        $arrRejectRegistColumn = array("year", "month", "day", "email02", "email_mobile02", "password02");
218
219        if ($_SERVER["REQUEST_METHOD"] == "POST") {
220
221            if (!$this->isValidToken()) {
222                SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
223            }
224
225            // 空白・改行の削除
226            $_POST["name01"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["name01"]);
227            $_POST["name02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["name02"]);
228            $_POST["kana01"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["kana01"]);
229            $_POST["kana02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["kana02"]);
230            $_POST["zip01"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["zip01"]);
231            $_POST["zip02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["zip02"]);
232            $_POST["addr01"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["addr01"]);
233            $_POST["addr02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["addr02"]);
234            $_POST["tel01"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["tel01"]);
235            $_POST["tel02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["tel02"]);
236            $_POST["tel03"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["tel03"]);
237            $_POST["fax01"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["fax01"]);
238            $_POST["fax02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["fax02"]);
239            $_POST["fax03"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["fax03"]);
240            $_POST["email"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["email"]);
241            $_POST["email02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["email02"]);
242            $_POST["password"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["password"]);
243            $_POST["password02"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["password02"]);
244            $_POST["reminder_answer"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["reminder_answer"]);
245
246            //-- POSTデータの引き継ぎ
247            $this->arrForm = $_POST;
248
249            // SSL用
250            $this->arrForm['ssl_url'] = $ssl_url;
251
252            $this->arrForm['email'] = strtolower($this->arrForm['email']);      // emailはすべて小文字で処理
253            $this->arrForm['email02'] = strtolower($this->arrForm['email02']);  // emailはすべて小文字で処理
254
255            //-- 入力データの変換
256            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
257
258            //-- 入力エラーチェック
259            $this->arrErr = $this->lfErrorCheck($this->arrForm);
260
261            if ($this->arrErr || $_POST["mode"] == "return") {      // 入力エラーのチェック
262                foreach($arrRegistColumn as $key) {
263                    $this->$key['column'] = $this->arrForm[$key['column']];
264                }
265
266            } else {
267
268                //-- 確認
269                if ($_POST["mode"] == "confirm") {
270                    foreach($this->arrForm as $key => $val) {
271                        if ($key != "mode" && $key != "subm") $this->list_data[ $key ] = $val;
272                    }
273                    //パスワード表示
274                    $passlen = strlen($this->arrForm['password']);
275                    $this->passlen = SC_Utils_Ex::lfPassLen($passlen);
276
277                    $this->tpl_css = '/css/layout/entry/confirm.css';
278                    $this->tpl_mainpage = 'entry/confirm.tpl';
279                    $this->tpl_title = '会員登録(確認ページ)';
280
281                }
282
283                //-- 会員登録と完了画面
284                if ($_POST["mode"] == "complete") {
285                    // キャンペーンからの遷移の時用の値
286                    if($objCampaignSess->getIsCampaign()) {
287                        $this->etc_value = "&cp=".$objCampaignSess->getCampaignId();
288                    }
289
290                    // 会員情報の登録
291                    $this->CONF = $CONF;
292                    $this->uniqid = $this->lfRegistData ($this->arrForm, $arrRegistColumn, $arrRejectRegistColumn, CUSTOMER_CONFIRM_MAIL);
293
294                    $this->tpl_css = '/css/layout/entry/complete.css';
295                    $this->tpl_mainpage = 'entry/complete.tpl';
296                    $this->tpl_title = '会員登録(完了ページ)';
297
298                    // 完了メール送信
299                    $this->name01 = $_POST['name01'];
300                    $this->name02 = $_POST['name02'];
301                    $objMailText = new SC_SiteView();
302                    $objMailText->assignobj($this);
303
304                    $objHelperMail = new SC_Helper_Mail_Ex();
305                    $objQuery = new SC_Query();
306
307                    // 仮会員が有効の場合
308                    if(CUSTOMER_CONFIRM_MAIL == true) {
309                        $subject = $objHelperMail->sfMakeSubject('会員登録のご確認');
310                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_mail.tpl");
311                    } else {
312                        $subject = $objHelperMail->sfMakeSubject('会員登録のご完了');
313                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_regist_mail.tpl");
314                        // ログイン状態にする
315                        $objCustomer->setLogin($_POST["email"]);
316                    }
317
318                    $objMail = new SC_SendMail();
319                    $objMail->setItem(
320                                          ''                    // 宛先
321                                        , $subject              // サブジェクト
322                                        , $toCustomerMail       // 本文
323                                        , $CONF["email03"]      // 配送元アドレス
324                                        , $CONF["shop_name"]    // 配送元 名前
325                                        , $CONF["email03"]      // reply_to
326                                        , $CONF["email04"]      // return_path
327                                        , $CONF["email04"]      // Errors_to
328                                        , $CONF["email01"]      // Bcc
329                    );
330                    // 宛先の設定
331                    $name = $_POST["name01"] . $_POST["name02"] ." 様";
332                    $objMail->setTo($_POST["email"], $name);
333                    $objMail->sendMail();
334
335                    // 完了ページに移動させる。
336                    $customer_id = $objQuery->get("dtb_customer", "customer_id", "secret_key = ?", array($this->uniqid));
337                    $this->sendRedirect($this->getLocation("./complete.php", array("ci" => $customer_id)));
338                    exit;
339                }
340            }
341        }
342
343        $this->transactionid = $this->getToken();
344
345        //---- ページ表示
346        $objView->assignobj($this);
347        // フレームを選択(キャンペーンページから遷移なら変更)
348        $objCampaignSess->pageView($objView);
349    }
350
351    /**
352     * モバイルページを初期化する.
353     *
354     * @return void
355     */
356    function mobileInit() {
357        $this->init();
358        $this->tpl_mainpage = 'entry/index.tpl';        // メインテンプレート
359        $this->tpl_title .= '会員登録(1/3)';            // ページタイトル
360    }
361
362    /**
363     * Page のプロセス(モバイル).
364     *
365     * @return void
366     */
367    function mobileProcess() {
368        //---- ページ初期設定
369        $objDb = new SC_Helper_DB_Ex();
370        $objMobile = new SC_Helper_Mobile_Ex();
371        $CONF = $objDb->sf_getBasisData();                  // 店舗基本情報
372        $objView = new SC_MobileView();
373        $objCustomer = new SC_Customer();
374
375        // 空メール
376        if (isset($_SESSION['mobile']['kara_mail_from'])) {
377            $_POST['email'] = $_SESSION['mobile']['kara_mail_from'];
378            $this->tpl_kara_mail_from = $_POST['email'];
379        } elseif (MOBILE_USE_KARA_MAIL) {
380            $token = $objMobile->gfPrepareKaraMail('entry/' . DIR_INDEX_URL);
381            if ($token !== false) {
382                $this->tpl_mainpage = 'entry/mail.tpl';
383                $this->tpl_title = '会員登録(空メール)';
384                $this->tpl_kara_mail_to = MOBILE_KARA_MAIL_ADDRESS_USER . MOBILE_KARA_MAIL_ADDRESS_DELIMITER . 'entry_' . $token . '@' . MOBILE_KARA_MAIL_ADDRESS_DOMAIN;
385                $this->tpl_from_address = $CONF['email03'];
386            }
387        }
388
389        // レイアウトデザインを取得
390        $objLayout = new SC_Helper_PageLayout_Ex();
391        $objLayout->sfGetPageLayout($this, false, DEF_LAYOUT);
392
393        //---- 登録用カラム配列
394        $arrRegistColumn = array(
395                                 array(  "column" => "name01", "convert" => "aKV" ),
396                                 array(  "column" => "name02", "convert" => "aKV" ),
397                                 array(  "column" => "kana01", "convert" => "CKV" ),
398                                 array(  "column" => "kana02", "convert" => "CKV" ),
399                                 array(  "column" => "zip01", "convert" => "n" ),
400                                 array(  "column" => "zip02", "convert" => "n" ),
401                                 array(  "column" => "pref", "convert" => "n" ),
402                                 array(  "column" => "addr01", "convert" => "aKV" ),
403                                 array(  "column" => "addr02", "convert" => "aKV" ),
404                                 array(  "column" => "email", "convert" => "a" ),
405                                 array(  "column" => "email02", "convert" => "a" ),
406                                 array(  "column" => "email_mobile", "convert" => "a" ),
407                                 array(  "column" => "email_mobile02", "convert" => "a" ),
408                                 array(  "column" => "tel01", "convert" => "n" ),
409                                 array(  "column" => "tel02", "convert" => "n" ),
410                                 array(  "column" => "tel03", "convert" => "n" ),
411                                 array(  "column" => "fax01", "convert" => "n" ),
412                                 array(  "column" => "fax02", "convert" => "n" ),
413                                 array(  "column" => "fax03", "convert" => "n" ),
414                                 array(  "column" => "sex", "convert" => "n" ),
415                                 array(  "column" => "job", "convert" => "n" ),
416                                 array(  "column" => "birth", "convert" => "n" ),
417                                 array(  "column" => "year", "convert" => "n" ),
418                                 array(  "column" => "month", "convert" => "n" ),
419                                 array(  "column" => "day", "convert" => "n" ),
420                                 array(  "column" => "reminder", "convert" => "n" ),
421                                 array(  "column" => "reminder_answer", "convert" => "aKV"),
422                                 array(  "column" => "password", "convert" => "a" ),
423                                 array(  "column" => "password02", "convert" => "a" ),
424                                 array(  "column" => "mailmaga_flg", "convert" => "n" ),
425                                 );
426
427        //---- 登録除外用カラム配列
428        $arrRejectRegistColumn = array("year", "month", "day", "email02", "email_mobile02", "password02");
429
430        if ($_SERVER["REQUEST_METHOD"] == "POST") {
431
432            //-- POSTデータの引き継ぎ
433            $this->arrForm = $_POST;
434            $this->arrForm['email'] = strtolower($this->arrForm['email']);      // emailはすべて小文字で処理
435
436            //-- 入力データの変換
437            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
438
439            // 戻るボタン用処理
440            if (!empty($_POST["return"])) {
441                switch ($_POST["mode"]) {
442                case "complete":
443                    $_POST["mode"] = "set3";
444                    break;
445                case "confirm":
446                    $_POST["mode"] = "set2";
447                    break;
448                default:
449                    $_POST["mode"] = "set1";
450                    break;
451                }
452            }
453
454            //-- 入力エラーチェック
455            if ($_POST["mode"] == "set1") {
456                $this->arrErr = $this->lfErrorCheck1($this->arrForm);
457                $this->tpl_mainpage = 'entry/index.tpl';
458                $this->tpl_title = '会員登録(1/3)';
459            } elseif ($_POST["mode"] == "set2") {
460                $this->arrErr = $this->lfErrorCheck2($this->arrForm);
461                $this->tpl_mainpage = 'entry/set1.tpl';
462                $this->tpl_title = '会員登録(2/3)';
463            } else {
464                $this->arrErr = $this->lfErrorCheck3($this->arrForm);
465                $this->tpl_mainpage = 'entry/set2.tpl';
466                $this->tpl_title = '会員登録(3/3)';
467            }
468
469            foreach($arrRegistColumn as $key) {
470                $this->$key['column'] = $this->arrForm[$key['column']];
471            }
472
473            if ($this->arrErr || !empty($_POST["return"])) {        // 入力エラーのチェック
474
475                //-- データの設定
476                if ($_POST["mode"] == "set1") {
477                    $checkVal = array("email", "password", "reminder", "reminder_answer", "name01", "name02", "kana01", "kana02");
478                } elseif ($_POST["mode"] == "set2") {
479                    $checkVal = array("sex", "year", "month", "day", "zip01", "zip02");
480                } else {
481                    $checkVal = array("pref", "addr01", "addr02", "tel01", "tel02", "tel03", "mailmaga_flg");
482                }
483
484                foreach($this->arrForm as $key => $val) {
485                    if ($key != "mode" && $key != "submit" && $key != "return" && $key != session_name() && !in_array($key, $checkVal))
486                        $this->list_data[ $key ] = $val;
487                }
488
489
490
491            } else {
492
493                //-- テンプレート設定
494                if ($_POST["mode"] == "set1") {
495                    $this->tpl_mainpage = 'entry/set1.tpl';
496                    $this->tpl_title = '会員登録(2/3)';
497                } elseif ($_POST["mode"] == "set2") {
498                    $this->tpl_mainpage = 'entry/set2.tpl';
499                    $this->tpl_title = '会員登録(3/3)';
500
501                    if (@$this->arrForm['pref'] == "" && @$this->arrForm['addr01'] == "" && @$this->arrForm['addr02'] == "") {
502                        $address = SC_Utils_Ex::sfGetAddress($_REQUEST['zip01'].$_REQUEST['zip02']);
503                        $this->pref = @$address[0]['state'];
504                        $this->addr01 = @$address[0]['city'] . @$address[0]['town'];
505                    }
506                } elseif ($_POST["mode"] == "confirm") {
507                    // パスワード表示
508                    $passlen = strlen($this->arrForm['password']);
509                    $this->passlen = $this->lfPassLen($passlen);
510
511                    // メール受け取り
512                    if (!isset($this->arrForm['mailmaga_flg'])) $this->arrForm['mailmaga_flg']  = "";
513                    if (strtolower($this->arrForm['mailmaga_flg']) == "on") {
514                        $this->arrForm['mailmaga_flg']  = "2";
515                    } else {
516                        $this->arrForm['mailmaga_flg']  = "3";
517                    }
518
519                    $this->tpl_mainpage = 'entry/confirm.tpl';
520                    $this->tpl_title = '会員登録(確認ページ)';
521
522                }
523
524                //-- データ設定
525                unset($this->list_data);
526                if ($_POST["mode"] == "set1") {
527                    $checkVal = array("sex", "year", "month", "day", "zip01", "zip02");
528                } elseif ($_POST["mode"] == "set2") {
529                    $checkVal = array("pref", "addr01", "addr02", "tel01", "tel02", "tel03", "mailmaga_flg");
530                } else {
531                    $checkVal = array();
532                }
533
534                foreach($this->arrForm as $key => $val) {
535                    if ($key != "mode" && $key != "submit" && $key != "confirm" && $key != "return" && $key != session_name() && !in_array($key, $checkVal)) {
536                        $this->list_data[ $key ] = $val;
537                    }
538                }
539
540
541                //-- 仮登録と完了画面
542                if ($_POST["mode"] == "complete") {
543
544                    // 確認画面で再度エラーチェックを行う。(画面1)
545                    $arrErr = $this->lfErrorCheck1($this->arrForm);
546                    if(count($arrErr) > 0){
547                        $this->tpl_mainpage = 'entry/index.tpl';
548                        $this->tpl_title = '会員登録(1/3)';
549                        $this->arrErr = $arrErr;
550                        //---- ページ表示
551                        $objView->assignobj($this);
552                        $objView->display(SITE_FRAME);
553                        exit();
554                    }
555
556                    // 確認画面で再度エラーチェックを行う。(画面2)
557                    $arrErr = $this->lfErrorCheck2($this->arrForm);
558                    if(count($arrErr) > 0){
559                        $this->tpl_mainpage = 'entry/set1.tpl';
560                        $this->tpl_title = '会員登録(2/3)';
561                        $this->arrErr = $arrErr;
562                        //---- ページ表示
563                        $objView->assignobj($this);
564                        $objView->display(SITE_FRAME);
565                        exit();
566                    }
567
568                    // 確認画面で再度エラーチェックを行う。(画面3)
569                    $arrErr = $this->lfErrorCheck3($this->arrForm);
570                    if(count($arrErr) > 0){
571                        $this->tpl_mainpage = 'entry/set2.tpl';
572                        $this->tpl_title = '会員登録(3/3)';
573                        $this->arrErr = $arrErr;
574                        //---- ページ表示
575                        $objView->assignobj($this);
576                        $objView->display(SITE_FRAME);
577                        exit();
578                    }
579
580                    $this->CONF = $CONF;
581                    $this->uniqid = $this->lfRegistData ($this->arrForm, $arrRegistColumn, $arrRejectRegistColumn, CUSTOMER_CONFIRM_MAIL, true, $this->arrForm["email"]);
582
583                    // 空メールを受信済みの場合はすぐに本登録完了にする。
584                    if (isset($_SESSION['mobile']['kara_mail_from'])) {
585                        $param = array("mode" => "regist",
586                                       "id" => $this->uniqid,
587                                       session_name() => session_id());
588                        $this->sendRedirect($this->getLocation(MOBILE_URL_DIR . "regist/" . DIR_INDEX_URL, $param));
589                        exit;
590                    }
591
592                    $this->tpl_mainpage = 'entry/complete.tpl';
593                    $this->tpl_title = '会員登録(完了ページ)';
594
595                    $objMobile->sfMobileSetExtSessionId('id', $this->uniqid, 'regist/' . DIR_INDEX_URL);
596
597                    // 仮登録完了メール送信
598                    $this->to_name01 = $_POST['name01'];
599                    $this->to_name02 = $_POST['name02'];
600                    $objMailText = new SC_MobileView();
601                    $objMailText->assignobj($this);
602                    $objHelperMail = new SC_Helper_Mail_Ex();
603                    $objQuery = new SC_Query();
604
605                    // 仮会員が有効の場合
606                    if(CUSTOMER_CONFIRM_MAIL == true) {
607                        // Moba8パラメーターを保持する場合はカラム追加
608                        if (isset($_SESSION['a8'])) $this->etc_value = "&a8=". $_SESSION['a8'];
609                        $subject = $objHelperMail->sfMakeSubject('会員登録のご確認');
610                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_mail.tpl");
611                    } else {
612                        $subject = $objHelperMail->sfMakeSubject('会員登録のご完了');
613                        $toCustomerMail = $objMailText->fetch("mail_templates/customer_regist_mail.tpl");
614                        // ログイン状態にする
615                        $objCustomer->setLogin($_POST["email"]);
616                    }
617
618                    $objMail = new SC_SendMail();
619                    $objMail->setItem(
620                                        ''                  // 宛先
621                                      , $subject            // サブジェクト
622                                      , $toCustomerMail     // 本文
623                                      , $CONF["email03"]    // 配送元アドレス
624                                      , $CONF["shop_name"]  // 配送元 名前
625                                      , $CONF["email03"]    // reply_to
626                                      , $CONF["email04"]    // return_path
627                                      , $CONF["email04"]    // Errors_to
628                                      , $CONF["email01"]    // Bcc
629                    );
630                    // 宛先の設定
631                    $name = $_POST["name01"] . $_POST["name02"] ." 様";
632                    $objMail->setTo($_POST["email"], $name);
633                    $objMail->sendMail();
634
635                    // 完了ページに移動させる。
636                    $this->sendRedirect($this->getLocation("./complete.php"), true);
637                    exit;
638                }
639            }
640        }
641
642        //---- ページ表示
643        $objView->assignobj($this);
644        $objView->display(SITE_FRAME);
645    }
646
647    /**
648     * デストラクタ.
649     *
650     * @return void
651     */
652    function destroy() {
653        parent::destroy();
654    }
655
656    // }}}
657    // {{{ protected functions
658
659    // 会員情報の登録
660    function lfRegistData ($array, $arrRegistColumn, $arrRejectRegistColumn, $confirm_flg, $isMobile = false, $email_mobile = "") {
661        $objQuery = new SC_Query();
662
663        // 登録データの生成
664        foreach ($arrRegistColumn as $data) {
665            if (strlen($array[ $data["column"] ]) > 0 && ! in_array($data["column"], $arrRejectRegistColumn)) {
666                $arrRegist[ $data["column"] ] = $array[ $data["column"] ];
667            }
668        }
669
670        // 誕生日が入力されている場合
671        if (strlen($array["year"]) > 0 ) {
672            $arrRegist["birth"] = $array["year"] ."/". $array["month"] ."/". $array["day"] ." 00:00:00";
673        }
674
675        // パスワードの暗号化
676        $arrRegist["password"] = sha1($arrRegist["password"] . ":" . AUTH_MAGIC);
677
678        // 仮会員登録の場合
679        if($confirm_flg == true) {
680            // 重複しない会員登録キーを発行する。
681            $count = 1;
682            while ($count != 0) {
683                $uniqid = SC_Utils_Ex::sfGetUniqRandomId("t");
684                $count = $objQuery->count("dtb_customer", "secret_key = ?", array($uniqid));
685            }
686            switch($array["mailmaga_flg"]) {
687                case 1:
688                    $arrRegist["mailmaga_flg"] = 4;
689                    break;
690                case 2:
691                    $arrRegist["mailmaga_flg"] = 5;
692                    break;
693                default:
694                    $arrRegist["mailmaga_flg"] = 6;
695                    break;
696            }
697
698            $arrRegist["status"] = "1";             // 仮会員
699        } else {
700            // 重複しない会員登録キーを発行する。
701            $count = 1;
702            while ($count != 0) {
703                $uniqid = SC_Utils_Ex::sfGetUniqRandomId("r");
704                $count = $objQuery->count("dtb_customer", "secret_key = ?", array($uniqid));
705            }
706            $arrRegist["status"] = "2";             // 本会員
707        }
708
709        /*
710          secret_keyは、テーブルで重複許可されていない場合があるので、
711          本会員登録では利用されないがセットしておく。
712        */
713        $arrRegist["secret_key"] = $uniqid;     // 会員登録キー
714        $arrRegist["create_date"] = "now()";    // 作成日
715        $arrRegist["update_date"] = "now()";    // 更新日
716        $arrRegist["first_buy_date"] = "";      // 最初の購入日
717        $arrRegist["point"] = $this->CONF["welcome_point"]; // 入会時ポイント
718
719        if ($isMobile) {
720            // 携帯メールアドレス
721            $arrRegist['email_mobile'] = $arrRegist['email'];
722            //PHONE_IDを取り出す
723            $phoneId = SC_MobileUserAgent::getId();
724            $arrRegist['mobile_phone_id'] =  $phoneId;
725        }
726
727        //-- 仮登録実行
728        $objQuery->begin();
729
730        $arrRegist['customer_id'] = $objQuery->nextVal('dtb_customer_customer_id');
731        $objQuery->insert("dtb_customer", $arrRegist);
732
733
734    /* メルマガ会員機能は現在停止中 2007/03/07
735
736
737        //-- 非会員でメルマガ登録しているかの判定
738        $sql = "SELECT count(*) FROM dtb_customer_mail WHERE email = ?";
739        $mailResult = $objConn->getOne($sql, array($arrRegist["email"]));
740
741        //-- メルマガ仮登録実行
742        $arrRegistMail["email"] = $arrRegist["email"];
743        if ($array["mailmaga_flg"] == 1) {
744            $arrRegistMail["mailmaga_flg"] = 4;
745        } elseif ($array["mailmaga_flg"] == 2) {
746            $arrRegistMail["mailmaga_flg"] = 5;
747        } else {
748            $arrRegistMail["mailmaga_flg"] = 6;
749        }
750        $arrRegistMail["update_date"] = "now()";
751
752        // 非会員でメルマガ登録している場合
753        if ($mailResult == 1) {
754            $objQuery->update("dtb_customer_mail", $arrRegistMail, "email = '" .addslashes($arrRegistMail["email"]). "'");
755        } else {                // 新規登録の場合
756            $arrRegistMail["create_date"] = "now()";
757            $objQuery->insert("dtb_customer_mail", $arrRegistMail);
758        }
759    */
760        $objQuery->commit();
761
762        return $uniqid;
763    }
764
765    //---- 取得文字列の変換
766    function lfConvertParam($array, $arrRegistColumn) {
767        /*
768         *  文字列の変換
769         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
770         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
771         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
772         *  n :  「全角」数字を「半角(ハンカク)」に変換
773         *  a :  全角英数字を半角英数字に変換する
774         */
775        // カラム名とコンバート情報
776        foreach ($arrRegistColumn as $data) {
777            $arrConvList[ $data["column"] ] = $data["convert"];
778        }
779        // 文字変換
780        foreach ($arrConvList as $key => $val) {
781            // POSTされてきた値のみ変換する。
782            if(isset($array[$key]) && strlen($array[$key]) > 0) {
783                $array[$key] = mb_convert_kana($array[$key] ,$val);
784            }
785        }
786        return $array;
787    }
788
789    //---- 入力エラーチェック
790    function lfErrorCheck($array) {
791
792        $objErr = new SC_CheckError($array);
793
794        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
795        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
796        $objErr->doFunc(array("フリガナ(セイ)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
797        $objErr->doFunc(array("フリガナ(メイ)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
798        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
799        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
800        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
801        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
802        $objErr->doFunc(array("ご住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
803        $objErr->doFunc(array("ご住所2", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
804        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK", "SPTAB_CHECK" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
805        $objErr->doFunc(array('メールアドレス(確認)', "email02", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK","SPTAB_CHECK" , "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
806        $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', "email", "email02") ,array("EQUAL_CHECK"));
807
808        // 現会員の判定 → 現会員もしくは仮登録中は、メアド一意が前提になってるので同じメアドで登録不可
809        if (strlen($array["email"]) > 0) {
810            $array["email"] = strtolower($array["email"]);
811            $objQuery = new SC_Query();
812            $arrRet = $objQuery->select("email, update_date, del_flg", "dtb_customer","email = ? OR email_mobile = ? ORDER BY del_flg", array($array["email"], $array["email"]));
813
814            if(count($arrRet) > 0) {
815                if($arrRet[0]['del_flg'] != '1') {
816                    // 会員である場合
817                    if (!isset($objErr->arrErr['email'])) $objErr->arrErr['email'] = "";
818                    $objErr->arrErr["email"] .= "※ すでに会員登録で使用されているメールアドレスです。<br />";
819                } else {
820                    // 退会した会員である場合
821                    $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrRet[0]['update_date']);
822                    $now_time = time();
823                    $pass_time = $now_time - $leave_time;
824                    // 退会から何時間-経過しているか判定する。
825                    $limit_time = ENTRY_LIMIT_HOUR * 3600;
826                    if($pass_time < $limit_time) {
827                        if (!isset($objErr->arrErr['email'])) $objErr->arrErr['email'] = "";
828                        $objErr->arrErr["email"] .= "※ 退会から一定期間の間は、同じメールアドレスを使用することはできません。<br />";
829                    }
830                }
831            }
832        }
833
834        $objErr->doFunc(array("お電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK" ));
835        $objErr->doFunc(array("お電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK" ));
836        $objErr->doFunc(array("お電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK" ));
837        $objErr->doFunc(array("お電話番号", "tel01", "tel02", "tel03") ,array("TEL_CHECK"));
838        $objErr->doFunc(array("FAX番号1", 'fax01'), array("SPTAB_CHECK"));
839        $objErr->doFunc(array("FAX番号2", 'fax02'), array("SPTAB_CHECK"));
840        $objErr->doFunc(array("FAX番号3", 'fax03'), array("SPTAB_CHECK"));
841        $objErr->doFunc(array("FAX番号", "fax01", "fax02", "fax03") ,array("TEL_CHECK"));
842        $objErr->doFunc(array("ご性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
843        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
844        $objErr->doFunc(array("パスワード(確認)", 'password02', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
845        $objErr->doFunc(array('パスワード', 'パスワード(確認)', "password", "password02") ,array("EQUAL_CHECK"));
846        $objErr->doFunc(array("パスワードを忘れたときのヒント 質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
847        $objErr->doFunc(array("パスワードを忘れたときのヒント 答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK","SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
848        $objErr->doFunc(array("メールマガジン", "mailmaga_flg") ,array("SELECT_CHECK", "NUM_CHECK"));
849
850        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_BIRTHDAY"));
851        $objErr->doFunc(array("メールマガジン", 'mailmaga_flg'), array("SELECT_CHECK"));
852        return $objErr->arrErr;
853    }
854
855    //確認ページ用パスワード表示用
856
857    function lfPassLen($passlen){
858        $ret = "";
859        for ($i=0;$i<$passlen;true){
860        $ret.="*";
861        $i++;
862        }
863        return $ret;
864    }
865
866    // }}}
867    // {{{ mobile functions
868
869    //---- 入力エラーチェック
870    function lfErrorCheck1($array) {
871
872        $objErr = new SC_CheckError($array);
873        $objDb = new SC_Helper_DB_Ex();
874
875        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
876        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
877        $objErr->doFunc(array("お名前(カナ/姓)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
878        $objErr->doFunc(array("お名前(カナ/名)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
879        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK", "SPTAB_CHECK" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK", "MOBILE_EMAIL_CHECK"));
880
881        // 現会員の判定 → 現会員もしくは仮登録中は、メアド一意が前提になってるので同じメアドで登録不可
882        if (strlen($array["email"]) > 0) {
883            $array['email'] = strtolower($array['email']);
884            $objQuery = new SC_Query();
885            $arrRet = $objQuery->select("email, update_date, del_flg", "dtb_customer","email = ? OR email_mobile = ? ORDER BY del_flg", array($array["email"], $array["email"]));
886
887            if(count($arrRet) > 0) {
888                if($arrRet[0]['del_flg'] != '1') {
889                    // 会員である場合
890                    $objErr->arrErr["email"] .= "※ すでに会員登録で使用されているメールアドレスです。<br />";
891                } else {
892                    // 退会した会員である場合
893                    $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrRet[0]['update_date']);
894                    $now_time = time();
895                    $pass_time = $now_time - $leave_time;
896                    // 退会から何時間-経過しているか判定する。
897                    $limit_time = ENTRY_LIMIT_HOUR * 3600;
898                    if($pass_time < $limit_time) {
899                        $objErr->arrErr["email"] .= "※ 退会から一定期間の間は、同じメールアドレスを使用することはできません。<br />";
900                    }
901                }
902            }
903        }
904
905        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
906        $objErr->doFunc(array("パスワード確認用の質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
907        $objErr->doFunc(array("パスワード確認用の質問の答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK","SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
908
909        return $objErr->arrErr;
910    }
911
912    //---- 入力エラーチェック
913    function lfErrorCheck2($array) {
914        $objErr = new SC_CheckError($array);
915
916        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
917        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
918        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
919
920        $objErr->doFunc(array("性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
921        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_BIRTHDAY"));
922
923        return $objErr->arrErr;
924    }
925
926    //---- 入力エラーチェック
927    function lfErrorCheck3($array) {
928        $objErr = new SC_CheckError($array);
929
930        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
931        $objErr->doFunc(array("市区町村", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
932        $objErr->doFunc(array("番地", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
933        $objErr->doFunc(array("電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK" ));
934        $objErr->doFunc(array("電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK" ));
935        $objErr->doFunc(array("電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK" ));
936        $objErr->doFunc(array("電話番号", "tel01", "tel02", "tel03") ,array("TEL_CHECK"));
937
938        return $objErr->arrErr;
939    }
940
941}
942?>
Note: See TracBrowser for help on using the repository browser.