source: branches/version-2_4/data/class/pages/mypage/LC_Page_Mypage_Change.php @ 18147

Revision 18147, 41.0 KB checked in by kajiwara, 12 years ago (diff)

#490 マイページ メールアドレス重複エラー時の不正ソースを修正

  • 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
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
27if (file_exists(MODULE_PATH . "mdl_gmopg/inc/function.php")) {
28    require_once(MODULE_PATH . "mdl_gmopg/inc/function.php");
29}
30
31/**
32 * 登録内容変更 のページクラス.
33 *
34 * @package Page
35 * @author LOCKON CO.,LTD.
36 * @version $Id$
37 */
38class LC_Page_Mypage_Change extends LC_Page {
39
40
41    // }}}
42    // {{{ functions
43
44    /**
45     * Page を初期化する.
46     *
47     * @return void
48     */
49    function init() {
50        parent::init();
51        $this->tpl_mainpage = TEMPLATE_DIR . 'mypage/change.tpl';
52        $this->tpl_title = 'MYページ/会員登録内容変更(入力ページ)';
53        $this->tpl_navi = TEMPLATE_DIR . 'mypage/navi.tpl';
54        $this->tpl_mainno = 'mypage';
55        $this->tpl_mypageno = 'change';
56        $this->tpl_column_num = 1;
57
58        $masterData = new SC_DB_MasterData_Ex();
59        $this->arrReminder = $masterData->getMasterData("mtb_reminder");
60        $this->arrPref = $masterData->getMasterData("mtb_pref",
61                                 array("pref_id", "pref_name", "rank"));
62        $this->arrJob = $masterData->getMasterData("mtb_job");
63        $this->arrMAILMAGATYPE = $masterData->getMasterData("mtb_mail_magazine_type");
64        $this->arrSex = $masterData->getMasterData("mtb_sex");
65        $this->allowClientCache();
66
67    }
68
69    /**
70     * Page のプロセス.
71     *
72     * @return void
73     */
74    function process() {
75        $objView = new SC_SiteView();
76        $this->objQuery = new SC_Query();
77        $this->objCustomer = new SC_Customer();
78        $this->objFormParam = new SC_FormParam();
79
80        // レイアウトデザインを取得
81        $objLayout = new SC_Helper_PageLayout_Ex();
82        $objLayout->sfGetPageLayout($this, false, "mypage/index.php");
83
84        //日付プルダウン設定
85        $objDate = new SC_Date(1901);
86        $this->arrYear = $objDate->getYear();
87        $this->arrMonth = $objDate->getMonth();
88        $this->arrDay = $objDate->getDay();
89
90        // ログインチェック
91        if (!$this->objCustomer->isLoginSuccess()){
92            SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
93        }else {
94            //マイページトップ顧客情報表示用
95            $this->CustomerName1 = $this->objCustomer->getvalue('name01');
96            $this->CustomerName2 = $this->objCustomer->getvalue('name02');
97            $this->CustomerPoint = $this->objCustomer->getvalue('point');
98        }
99
100        //---- 登録用カラム配列
101        $arrRegistColumn = array(
102                                 array(  "column" => "name01",      "convert" => "aKV" ),
103                                 array(  "column" => "name02",      "convert" => "aKV" ),
104                                 array(  "column" => "kana01",      "convert" => "CKV" ),
105                                 array(  "column" => "kana02",      "convert" => "CKV" ),
106                                 array(  "column" => "zip01",       "convert" => "n" ),
107                                 array(  "column" => "zip02",       "convert" => "n" ),
108                                 array(  "column" => "pref",        "convert" => "n" ),
109                                 array(  "column" => "addr01",      "convert" => "aKV" ),
110                                 array(  "column" => "addr02",      "convert" => "aKV" ),
111                                 array(  "column" => "email",       "convert" => "a" ),
112                                 array(  "column" => "email_mobile", "convert" => "a" ),
113                                 array(  "column" => "tel01",       "convert" => "n" ),
114                                 array(  "column" => "tel02",       "convert" => "n" ),
115                                 array(  "column" => "tel03",       "convert" => "n" ),
116                                 array(  "column" => "fax01",       "convert" => "n" ),
117                                 array(  "column" => "fax02",       "convert" => "n" ),
118                                 array(  "column" => "fax03",       "convert" => "n" ),
119                                 array(  "column" => "sex",         "convert" => "n" ),
120                                 array(  "column" => "job",         "convert" => "n" ),
121                                 array(  "column" => "birth",       "convert" => "n" ),
122                                 array(  "column" => "password",    "convert" => "an" ),
123                                 array(  "column" => "reminder",    "convert" => "n" ),
124                                 array(  "column" => "reminder_answer", "convert" => "aKV" ),
125                                 array(  "column" => "mailmaga_flg", "convert" => "n" )
126                                 );
127
128        //メールアドレス種別
129        $arrMailType = array("email" => true, "email_mobile" => true);
130
131        if (!isset($_POST['mode'])) $_POST['mode'] = "";
132
133        switch ($_POST['mode']){
134
135        case 'confirm':
136
137            //エラーなしでかつメールアドレスが重複していない場合
138            if ($this->checkErrorTotal($arrRegistColumn, $arrMailType)) {
139
140                //確認ページへ
141                $this->tpl_mainpage = TEMPLATE_DIR . 'mypage/change_confirm.tpl';
142                $this->tpl_title = 'MYページ/会員登録内容変更(確認ページ)';
143                $passlen = strlen($this->arrForm['password']);
144                $this->passlen = $this->lfPassLen($passlen);
145            } else {
146                $this->lfFormReturn($this->arrForm,$this);
147            }
148
149            break;
150
151        case 'return':
152            $this->arrForm = $_POST;
153            $this->lfFormReturn($this->arrForm,$this);
154            break;
155
156        case 'gmo_oneclick':
157            sfGMOMypageEdit();
158            $this->arrForm = $this->lfGetCustomerData();
159            $this->arrForm['password'] = DEFAULT_PASSWORD;
160            $this->arrForm['password02'] = DEFAULT_PASSWORD;
161            break;
162        case 'complete':
163            //エラーなしでかつメールアドレスが重複していない場合
164            if ($this->checkErrorTotal($arrRegistColumn, $arrMailType)) {
165                $this->arrForm['customer_id'] = $this->objCustomer->getValue('customer_id');
166                //-- 編集登録
167                $objDb = new SC_Helper_DB_Ex();
168                $objDb->sfEditCustomerData($this->arrForm, $arrRegistColumn);
169                //セッション情報を最新の状態に更新する
170                $this->objCustomer->updateSession();
171
172                // Do楽SNS連携モジュールユーザ情報更新処理
173                if (function_exists('sfUpdateSourakuSNSUserInfo')) {
174                    sfUpdateSourakuSNSUserInfo();
175                }
176
177                //完了ページへ
178                $this->sendRedirect($this->getLocation("./change_complete.php"));
179                exit;
180            } else {
181                SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
182            }
183            break;
184
185        default:
186            //顧客情報取得
187            $this->arrForm = $this->lfGetCustomerData();
188            $this->arrForm['password'] = DEFAULT_PASSWORD;
189            $this->arrForm['password02'] = DEFAULT_PASSWORD;
190            break;
191        }
192
193        //誕生日データ登録の有無
194        $arrCustomer = $this->lfGetCustomerData();
195        if ($arrCustomer['birth'] != ""){
196            $this->birth_check = true;
197        }
198
199        $objView->assignobj($this);             //$objpage内の全てのテンプレート変数をsmartyに格納
200        $objView->display(SITE_FRAME);              //パスとテンプレート変数の呼び出し、実行
201
202
203    }
204
205    /**
206     * モバイルページを初期化する.
207     *
208     * @return void
209     */
210    function mobileInit() {
211        $this->tpl_mainpage = 'mypage/change.tpl';      // メインテンプレート
212        $this->tpl_title .= '登録変更(1/3)';            // ページタイトル
213
214        $masterData = new SC_DB_MasterData_Ex();
215        $this->arrReminder = $masterData->getMasterData("mtb_reminder");
216        $this->arrPref = $masterData->getMasterData("mtb_pref",
217                                 array("pref_id", "pref_name", "rank"));
218        $this->arrJob = $masterData->getMasterData("mtb_job");
219        $this->arrMAILMAGATYPE = $masterData->getMasterData("mtb_mail_magazine_type");
220        $this->arrSex = $masterData->getMasterData("mtb_sex");
221    }
222
223    /**
224     * Page のプロセス(モバイル).
225     *
226     * @return void
227     */
228    function mobileProcess() {
229        $objDb = new SC_Helper_DB_Ex();
230        $CONF = $objDb->sf_getBasisData();                  // 店舗基本情報
231        $objConn = new SC_DbConn();
232        $objView = new SC_MobileView();
233        $this->objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
234        $this->arrYear = $this->objDate->getYear();
235        $this->arrMonth = $this->objDate->getMonth();
236        $this->arrDay = $this->objDate->getDay();
237
238        $this->objQuery = new SC_Query();
239        $this->objCustomer = new SC_Customer();
240
241        //メールアドレス種別
242        $arrMailType = array("email" => true, "email_mobile" => true);
243
244        //---- 登録用カラム配列
245        $arrRegistColumn = array(
246                                 array(  "column" => "name01", "convert" => "aKV" ),
247                                 array(  "column" => "name02", "convert" => "aKV" ),
248                                 array(  "column" => "kana01", "convert" => "CKV" ),
249                                 array(  "column" => "kana02", "convert" => "CKV" ),
250                                 array(  "column" => "zip01", "convert" => "n" ),
251                                 array(  "column" => "zip02", "convert" => "n" ),
252                                 array(  "column" => "pref", "convert" => "n" ),
253                                 array(  "column" => "addr01", "convert" => "aKV" ),
254                                 array(  "column" => "addr02", "convert" => "aKV" ),
255                                 array(  "column" => "email", "convert" => "a" ),
256                                 array(  "column" => "email_mobile", "convert" => "a" ),
257                                 array(  "column" => "tel01", "convert" => "n" ),
258                                 array(  "column" => "tel02", "convert" => "n" ),
259                                 array(  "column" => "tel03", "convert" => "n" ),
260                                 array(  "column" => "fax01", "convert" => "n" ),
261                                 array(  "column" => "fax02", "convert" => "n" ),
262                                 array(  "column" => "fax03", "convert" => "n" ),
263                                 array(  "column" => "sex", "convert" => "n" ),
264                                 array(  "column" => "job", "convert" => "n" ),
265                                 array(  "column" => "birth", "convert" => "n" ),
266                                 array(  "column" => "reminder", "convert" => "n" ),
267                                 array(  "column" => "reminder_answer", "convert" => "aKV"),
268                                 array(  "column" => "password", "convert" => "a" ),
269                                 array(  "column" => "mailmaga_flg", "convert" => "n" )
270                                 );
271
272        //---- 登録除外用カラム配列
273        $arrRejectRegistColumn = array("year", "month", "day", "email02", "email_mobile02", "password02");
274
275        $this->arrForm = $this->lfGetCustomerData();
276        $this->arrForm['password'] = DEFAULT_PASSWORD;
277
278        if ($_SERVER["REQUEST_METHOD"] == "POST") {
279
280            //-- POSTデータの引き継ぎ
281            $this->arrForm = array_merge($this->arrForm, $_POST);
282
283            if (!isset($this->arrForm['year'])) $this->arrForm['year'] = "";
284            if($this->arrForm['year'] == '----') {
285                $this->arrForm['year'] = '';
286            }
287
288            // emailはすべて小文字で処理
289            $this->paramToLower($_POST );
290
291            //-- 入力データの変換
292            $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
293
294            // 戻るボタン用処理
295            if (!empty($_POST["return"])) {
296                switch ($_POST["mode"]) {
297                case "complete":
298                    $_POST["mode"] = "set3";
299                    break;
300                case "confirm":
301                    $_POST["mode"] = "set2";
302                    break;
303                default:
304                    $_POST["mode"] = "set1";
305                    break;
306                }
307            }
308
309            //-- 入力エラーチェック
310            if ($_POST["mode"] == "set1") {
311                $this->arrErr = $this->lfErrorCheck1($this->arrForm);
312                $this->tpl_mainpage = 'mypage/change.tpl';
313                $this->tpl_title = '登録変更(1/3)';
314            } elseif ($_POST["mode"] == "set2") {
315                $this->arrErr = $this->lfErrorCheck2($this->arrForm);
316                $this->tpl_mainpage = 'mypage/set1.tpl';
317                $this->tpl_title = '登録変更(2/3)';
318            } else {
319                $this->arrErr = $this->lfErrorCheck3($this->arrForm);
320                $this->tpl_mainpage = 'mypage/set2.tpl';
321                $this->tpl_title = '登録変更(3/3)';
322            }
323
324            if ($this->arrErr || !empty($_POST["return"])) {        // 入力エラーのチェック
325                //-- データの設定
326                if ($_POST["mode"] == "set1") {
327                    $checkVal = array("email", "email_mobile", "password", "reminder", "reminder_answer", "name01", "name02", "kana01", "kana02");
328                } elseif ($_POST["mode"] == "set2") {
329                    $checkVal = array("sex", "year", "month", "day", "zip01", "zip02");
330                } else {
331                    $checkVal = array("pref", "addr01", "addr02", "tel01", "tel02", "tel03", "mailmaga_flg");
332                }
333
334                foreach($this->arrForm as $key => $val) {
335                    if ($key != "return" && $key != "mode" && $key != "confirm" && $key != session_name() && !in_array($key, $checkVal)) {
336                        $this->list_data[ $key ] = $val;
337                    }
338                }
339
340            } else {
341
342                //-- テンプレート設定
343                if ($_POST["mode"] == "set1") {
344                    $this->tpl_mainpage = 'mypage/set1.tpl';
345                    $this->tpl_title = '登録変更(2/3)';
346                } elseif ($_POST["mode"] == "set2") {
347                    $this->tpl_mainpage = 'mypage/set2.tpl';
348                    $this->tpl_title = '登録変更(3/3)';
349                } elseif ($_POST["mode"] == "confirm") {
350                    //パスワード表示
351                    $passlen = strlen($this->arrForm['password']);
352                    $this->passlen = $this->lfPassLen($passlen);
353
354                    // メール受け取り
355                    if (!isset($_POST['mailmaga_flg'])) $_POST['mailmaga_flg'] = "";
356                    if (strtolower($_POST['mailmaga_flg']) == "on") {
357                        $this->arrForm['mailmaga_flg'] = "2";
358                    } else {
359                        $this->arrForm['mailmaga_flg'] = "3";
360                    }
361
362                    $this->tpl_mainpage = 'mypage/change_confirm.tpl';
363                    $this->tpl_title = '登録変更(確認ページ)';
364
365                }
366
367                //-- データ設定
368                unset($this->list_data);
369                if ($_POST["mode"] == "set1") {
370                    $checkVal = array("sex", "year", "month", "day", "zip01", "zip02");
371                } elseif ($_POST["mode"] == "set2") {
372                    $checkVal = array("pref", "addr01", "addr02", "tel01", "tel02", "tel03", "mailmaga_flg");
373                } else {
374                    $checkVal = array();
375                }
376
377                foreach($this->arrForm as $key => $val) {
378                    if ($key != "return" && $key != "mode" && $key != "confirm" && $key != session_name() && !in_array($key, $checkVal)) {
379                        $this->list_data[ $key ] = $val;
380                    }
381                }
382
383
384                //-- 仮登録と完了画面
385                if ($_POST["mode"] == "complete") {
386                    //エラーなしでかつメールアドレスが重複していない場合
387                    if($this->checkErrorTotal($arrRegistColumn, $arrMailType, true)) {
388                        $this->arrForm['customer_id'] = $this->objCustomer->getValue('customer_id');
389                        //-- 編集登録
390                        $objDb->sfEditCustomerData($this->arrForm, $arrRegistColumn);
391                        //セッション情報を最新の状態に更新する
392                        $this->objCustomer->updateSession();
393                        //完了ページへ
394                        $this->sendRedirect($this->getLocation("./change_complete.php"), true);
395                        exit;
396                    } else {
397                        SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR, "", false, "", true);
398                    }
399                }
400            }
401        }
402
403        $arrPrivateVariables = array('secret_key', 'first_buy_date', 'last_buy_date', 'buy_times', 'buy_total', 'point', 'note', 'status', 'create_date', 'update_date', 'del_flg', 'cell01', 'cell02', 'cell03', 'mobile_phone_id');
404        foreach ($arrPrivateVariables as $key) {
405            unset($this->list_data[$key]);
406        }
407
408        //---- ページ表示
409        $objView->assignobj($this);
410        $objView->display(SITE_FRAME);
411    }
412
413    /**
414     * デストラクタ.
415     *
416     * @return void
417     */
418    function destroy() {
419        parent::destroy();
420    }
421
422    /**
423     * すべてのエラーチェックを行う.
424     *
425     * @param array $arrRegistColumn 登録カラムの配列
426     * @param array $arrMailType メール種別とフラグを格納した配列
427     * @param bool $isMobile モバイル版登録チェックの場合 true
428     * @return bool エラーの無い場合 true
429     */
430    function checkErrorTotal(&$arrRegistColumn, &$arrMailType, $isMobile = false) {
431        //-- 入力データの変換
432        $this->arrForm = $_POST;
433        $this->arrForm = $this->lfConvertParam($this->arrForm, $arrRegistColumn);
434
435        // emailはすべて小文字で処理
436        $this->paramToLower($arrRegistColumn);
437
438        //エラーチェック
439        $this->arrErr = $isMobile
440            ? $this->lfErrorCheckMobile($this->arrForm)
441            : $this->lfErrorCheck($this->arrForm);
442
443        //メールアドレスを変更している場合、メールアドレスの重複チェック
444        $arrMailType2 = $arrMailType;
445        foreach ($arrMailType as $mailType => $mailTypeValue) {
446
447            if ($this->arrForm[$mailType]
448                != $this->objCustomer->getValue($mailType)){
449
450                $email_cnt = $this->objQuery->count("dtb_customer",
451                                 "del_flg=0 AND " . $mailType . "= ?",
452                                  array($this->arrForm[$mailType]));
453                if ($email_cnt > 0){
454                    $arrMailType2[$mailType] = false;
455                    $this->arrErr[$mailType] .= "既に使用されているメールアドレスです。";
456                }
457            }
458        }
459
460        // エラーが存在せず, メールアドレスの重複が無い場合は true
461        if (empty($this->arrErr)
462            && $arrMailType2['email'] == true
463            && $arrMailType2['email_mobile'] == true) {
464            return true;
465        } else {
466            return false;
467        }
468    }
469
470    /* パラメータ情報の初期化 */
471    function lfInitParam() {
472        $this->objFormParam->addParam("お名前(姓)", "name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
473        $this->objFormParam->addParam("お名前(名)", "name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
474        $this->objFormParam->addParam("フリガナ(セイ)", "kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
475        $this->objFormParam->addParam("フリガナ(メイ)", "kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
476        $this->objFormParam->addParam("郵便番号1", "zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
477        $this->objFormParam->addParam("郵便番号2", "zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
478        $this->objFormParam->addParam("都道府県", "pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
479        $this->objFormParam->addParam("ご住所1", "addr01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
480        $this->objFormParam->addParam("ご住所2", "addr02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
481        $this->objFormParam->addParam("お電話番号1", "tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
482        $this->objFormParam->addParam("お電話番号2", "tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
483        $this->objFormParam->addParam("お電話番号3", "tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
484    }
485
486    //エラーチェック
487
488    function lfErrorCheck($array) {
489        $objErr = new SC_CheckError($array);
490
491        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
492        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
493        $objErr->doFunc(array("フリガナ(セイ)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
494        $objErr->doFunc(array("フリガナ(メイ)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
495        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
496        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
497        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
498        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
499        $objErr->doFunc(array("ご住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
500        $objErr->doFunc(array("ご住所2", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
501        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "NO_SPTAB" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
502        $objErr->doFunc(array('メールアドレス(確認)', "email02", MTEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK","NO_SPTAB" , "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
503        $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', "email", "email02") ,array("EQUAL_CHECK"));
504        $objErr->doFunc(array('携帯メールアドレス', "email_mobile", MTEXT_LEN) ,array("EMAIL_CHECK", "NO_SPTAB" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK", "MOBILE_EMAIL_CHECK"));
505        $objErr->doFunc(array('携帯メールアドレス(確認)', "email_mobile02", MTEXT_LEN), array("EMAIL_CHECK","NO_SPTAB" , "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK", "MOBILE_EMAIL_CHECK"));
506        $objErr->doFunc(array('携帯メールアドレス', '携帯メールアドレス(確認)', "email_mobile", "email_mobile02") ,array("EQUAL_CHECK"));
507        $objErr->doFunc(array("お電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK"));
508        $objErr->doFunc(array("お電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK"));
509        $objErr->doFunc(array("お電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK"));
510        $objErr->doFunc(array("お電話番号", "tel01", "tel02", "tel03", TEL_LEN) ,array("TEL_CHECK"));
511        $objErr->doFunc(array("FAX番号", "fax01", "fax02", "fax03", TEL_LEN) ,array("TEL_CHECK"));
512        $objErr->doFunc(array("ご性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
513        $objErr->doFunc(array("ご職業", "job") ,array("NUM_CHECK"));
514        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_DATE"));
515        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "ALNUM_CHECK", "NUM_RANGE_CHECK"));
516        $objErr->doFunc(array("パスワード(確認)", 'password02', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "ALNUM_CHECK", "NUM_RANGE_CHECK"));
517        $objErr->doFunc(array("パスワード", 'パスワード(確認)', 'password', 'password02'), array("EQUAL_CHECK"));
518        $objErr->doFunc(array("パスワードを忘れたときの質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
519        $objErr->doFunc(array("パスワードを忘れたときの答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
520        $objErr->doFunc(array("メールマガジン", "mailmaga_flg") ,array("SELECT_CHECK", "NUM_CHECK"));
521        return $objErr->arrErr;
522
523    }
524
525    //---- 取得文字列の変換
526    function lfConvertParam($array, $arrRegistColumn) {
527        /*
528         *  文字列の変換
529         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
530         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
531         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
532         *  n :  「全角」数字を「半角(ハンカク)」に変換
533         *  a :  全角英数字を半角英数字に変換する
534         */
535        // カラム名とコンバート情報
536        foreach ($arrRegistColumn as $data) {
537            $arrConvList[ $data["column"] ] = $data["convert"];
538        }
539
540        // 文字変換
541        foreach ($arrConvList as $key => $val) {
542            // POSTされてきた値のみ変換する。
543            if (isset($array[$key])) {
544                if(strlen(($array[$key])) > 0) {
545                    $array[$key] = mb_convert_kana($array[$key] ,$val);
546                }
547            }
548        }
549        return $array;
550    }
551
552    //顧客情報の取得
553    function lfGetCustomerData(){
554        //顧客情報取得
555        $ret = $this->objQuery->select("*","dtb_customer","customer_id=?", array($this->objCustomer->getValue('customer_id')));
556        $arrForm = $ret[0];
557
558        //誕生日の年月日取得
559        if (isset($arrForm['birth'])){
560            $birth = split(" ", $arrForm["birth"]);
561            list($year, $month, $day) = split("-",$birth[0]);
562
563            $arrForm['year'] = $year;
564            $arrForm['month'] = $month;
565            $arrForm['day'] = $day;
566
567        }
568        return $arrForm;
569    }
570
571    /**
572     * 編集登録
573     * TODO
574     * @deprecated 未使用?
575     */
576    function lfRegistData($array, $arrRegistColumn) {
577
578        foreach ($arrRegistColumn as $data) {
579            if ($data["column"] != "password") {
580                if($array[ $data['column'] ] == "") {
581                    $arrRegist[ $data['column'] ] = NULL;
582                } else {
583                    $arrRegist[ $data["column"] ] = $array[ $data["column"] ];
584                }
585            }
586        }
587        if (strlen($array["year"]) > 0 && strlen($array["month"]) > 0 && strlen($array["day"]) > 0) {
588            $arrRegist["birth"] = $array["year"] ."/". $array["month"] ."/". $array["day"] ." 00:00:00";
589        } else {
590            $arrRegist["birth"] = NULL;
591        }
592
593        //-- パスワードの更新がある場合は暗号化。(更新がない場合はUPDATE文を構成しない)
594        if ($array["password"] != DEFAULT_PASSWORD) $arrRegist["password"] = sha1($array["password"] . ":" . AUTH_MAGIC);
595        $arrRegist["update_date"] = "NOW()";
596
597        //-- 編集登録実行
598        $this->objQuery->begin();
599        $this->objQuery->update("dtb_customer", $arrRegist, "customer_id = ? ", array($this->objCustomer->getValue('customer_id')));
600        $this->objQuery->commit();
601    }
602
603    //確認ページ用パスワード表示用
604
605    function lfPassLen($passlen){
606        $ret = "";
607        for ($i=0;$i<$passlen;true){
608            $ret.="*";
609            $i++;
610        }
611        return $ret;
612    }
613
614    //エラー、戻る時にフォームに入力情報を返す
615    function lfFormReturn($array, &$objPage){
616        foreach($array as $key => $val){
617            switch ($key){
618            case 'password':
619            case 'password02':
620                $objPage->$key = $val;
621                break;
622            default:
623                $array[ $key ] = $val;
624                break;
625            }
626        }
627    }
628
629
630    // }}}
631    // {{{ mobile functions
632
633    /**
634     * TODO
635     * @deprecated 未使用?
636     */
637    function lfRegistDataMobile ($array, $arrRegistColumn,
638                                 $arrRejectRegistColumn) {
639
640        // 仮登録
641        foreach ($arrRegistColumn as $data) {
642            if (strlen($array[ $data["column"] ]) > 0 && ! in_array($data["column"], $arrRejectRegistColumn)) {
643                $arrRegist[ $data["column"] ] = $array[ $data["column"] ];
644            }
645        }
646
647        // 誕生日が入力されている場合
648        if (strlen($array["year"]) > 0 ) {
649            $arrRegist["birth"] = $array["year"] ."/". $array["month"] ."/". $array["day"] ." 00:00:00";
650        }
651
652        // パスワードの暗号化
653        $arrRegist["password"] = sha1($arrRegist["password"] . ":" . AUTH_MAGIC);
654
655        $count = 1;
656        while ($count != 0) {
657            $uniqid = SC_Utils_Ex::sfGetUniqRandomId("t");
658            $count = $objConn->getOne("SELECT COUNT(*) FROM dtb_customer WHERE secret_key = ?", array($uniqid));
659        }
660
661        $arrRegist["secret_key"] = $uniqid;     // 仮登録ID発行
662        $arrRegist["create_date"] = "now()";    // 作成日
663        $arrRegist["update_date"] = "now()";    // 更新日
664        $arrRegist["first_buy_date"] = "";      // 最初の購入日
665
666
667        //-- 仮登録実行
668        $this->objQuery->insert("dtb_customer", $arrRegist);
669
670        return $uniqid;
671    }
672
673
674    //エラーチェック
675
676    function lfErrorCheckMobile($array) {
677        $objErr = new SC_CheckError($array);
678
679        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
680        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
681        $objErr->doFunc(array("お名前(カナ/姓)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
682        $objErr->doFunc(array("お名前(カナ/名)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
683        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
684        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
685        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
686        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
687        $objErr->doFunc(array("市区町村", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
688        $objErr->doFunc(array("番地", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
689        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "NO_SPTAB" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
690        $objErr->doFunc(array('携帯メールアドレス', "email_mobile", MTEXT_LEN) ,array("EMAIL_CHECK", "NO_SPTAB" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK", "MOBILE_EMAIL_CHECK"));
691        $objErr->doFunc(array("電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK"));
692        $objErr->doFunc(array("電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK"));
693        $objErr->doFunc(array("電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK"));
694        $objErr->doFunc(array("電話番号", "tel01", "tel02", "tel03", TEL_LEN) ,array("TEL_CHECK"));
695        $objErr->doFunc(array("FAX番号", "fax01", "fax02", "fax03", TEL_LEN) ,array("TEL_CHECK"));
696        $objErr->doFunc(array("性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
697        $objErr->doFunc(array("ご職業", "job") ,array("NUM_CHECK"));
698        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_DATE"));
699        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "ALNUM_CHECK", "NUM_RANGE_CHECK"));
700        $objErr->doFunc(array("パスワード確認用の質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
701        $objErr->doFunc(array("パスワード確認用の質問の答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
702        return $objErr->arrErr;
703
704    }
705
706
707    //---- 入力エラーチェック
708    function lfErrorCheck1($array) {
709
710        $objErr = new SC_CheckError($array);
711
712        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
713        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
714        $objErr->doFunc(array("お名前(カナ/姓)", 'kana01', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
715        $objErr->doFunc(array("お名前(カナ/名)", 'kana02', STEXT_LEN), array("EXIST_CHECK", "NO_SPTAB", "SPTAB_CHECK" ,"MAX_LENGTH_CHECK", "KANA_CHECK"));
716        $objErr->doFunc(array('メールアドレス', "email", MTEXT_LEN) ,array("NO_SPTAB", "EXIST_CHECK", "EMAIL_CHECK", "SPTAB_CHECK" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
717        $objErr->doFunc(array('携帯メールアドレス', "email_mobile", MTEXT_LEN) ,array("NO_SPTAB", "EMAIL_CHECK", "SPTAB_CHECK" ,"EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK", "MOBILE_EMAIL_CHECK"));
718
719        //現会員の判定 → 現会員もしくは仮登録中は、メアド一意が前提になってるので同じメアドで登録不可
720        $array["customer_id"] = $this->objCustomer->getValue('customer_id');
721        if (strlen($array["email"]) > 0) {
722            $arrRet = $this->objQuery->select("email, update_date, del_flg", "dtb_customer","customer_id <> ? and (email = ? OR email_mobile = ?) ORDER BY del_flg", array($array["customer_id"], $array["email"], $array["email"]));
723
724            if(count($arrRet) > 0) {
725                if($arrRet[0]['del_flg'] != '1') {
726                    // 会員である場合
727                    $objErr->arrErr["email"] .= "※ すでに会員登録で使用されているメールアドレスです。<br />";
728                } else {
729                    // 退会した会員である場合
730                    $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrRet[0]['update_date']);
731                    $now_time = time();
732                    $pass_time = $now_time - $leave_time;
733                    // 退会から何時間-経過しているか判定する。
734                    $limit_time = ENTRY_LIMIT_HOUR * 3600;
735                    if($pass_time < $limit_time) {
736                        $objErr->arrErr["email"] .= "※ 退会から一定期間の間は、同じメールアドレスを使用することはできません。<br />";
737                    }
738                }
739            }
740        }
741
742        $objErr->doFunc(array("パスワード", 'password', PASSWORD_LEN1, PASSWORD_LEN2), array("EXIST_CHECK", "SPTAB_CHECK" ,"ALNUM_CHECK", "NUM_RANGE_CHECK"));
743        $objErr->doFunc(array("パスワード確認用の質問", "reminder") ,array("SELECT_CHECK", "NUM_CHECK"));
744        $objErr->doFunc(array("パスワード確認用の質問の答え", "reminder_answer", STEXT_LEN) ,array("EXIST_CHECK","SPTAB_CHECK" , "MAX_LENGTH_CHECK"));
745
746        return $objErr->arrErr;
747    }
748
749    //---- 入力エラーチェック
750    function lfErrorCheck2($array) {
751
752        $objErr = new SC_CheckError($array);
753
754        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
755        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "SPTAB_CHECK" ,"NUM_CHECK", "NUM_COUNT_CHECK"));
756        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
757
758        $objErr->doFunc(array("性別", "sex") ,array("SELECT_CHECK", "NUM_CHECK"));
759        $objErr->doFunc(array("生年月日 (年)", "year", 4), array("SPTAB_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
760        if (!empty($array["year"])) {
761            $objErr->doFunc(array("生年月日 (年)", "year", $this->objDate->getStartYear()), array("MIN_CHECK"));
762            $objErr->doFunc(array("生年月日 (年)", "year", $this->objDate->getEndYear()), array("MAX_CHECK"));
763        }
764        if (!isset($objErr->arrErr['year']) && !isset($objErr->arrErr['month']) && !isset($objErr->arrErr['day'])) {
765            $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_DATE"));
766        }
767
768        return $objErr->arrErr;
769    }
770
771    //---- 入力エラーチェック
772    function lfErrorCheck3($array) {
773
774        $objErr = new SC_CheckError($array);
775
776        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
777        $objErr->doFunc(array("市区町村", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
778        $objErr->doFunc(array("番地", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK" ,"MAX_LENGTH_CHECK"));
779        $objErr->doFunc(array("電話番号1", 'tel01'), array("EXIST_CHECK","SPTAB_CHECK" ));
780        $objErr->doFunc(array("電話番号2", 'tel02'), array("EXIST_CHECK","SPTAB_CHECK" ));
781        $objErr->doFunc(array("電話番号3", 'tel03'), array("EXIST_CHECK","SPTAB_CHECK" ));
782        $objErr->doFunc(array("電話番号", "tel01", "tel02", "tel03",TEL_ITEM_LEN) ,array("TEL_CHECK"));
783
784        return $objErr->arrErr;
785    }
786
787    // 郵便番号から住所の取得
788    function lfGetAddress($zipcode) {
789        global $arrPref;
790
791        $conn = new SC_DBconn(ZIP_DSN);
792
793        // 郵便番号検索文作成
794        $zipcode = mb_convert_kana($zipcode ,"n");
795        $sqlse = "SELECT state, city, town FROM mtb_zip WHERE zipcode = ?";
796
797        $data_list = $conn->getAll($sqlse, array($zipcode));
798
799        // インデックスと値を反転させる。
800        $arrREV_PREF = array_flip($arrPref);
801
802        /*
803          総務省からダウンロードしたデータをそのままインポートすると
804          以下のような文字列が入っているので 対策する。
805          ・(1・19丁目)
806          ・以下に掲載がない場合
807        */
808        $town =  $data_list[0]['town'];
809        $town = ereg_replace("(.*)$","",$town);
810        $town = ereg_replace("以下に掲載がない場合","",$town);
811        $data_list[0]['town'] = $town;
812        $data_list[0]['state'] = $arrREV_PREF[$data_list[0]['state']];
813
814        return $data_list;
815    }
816
817    //顧客情報の取得
818    function lfGetCustomerDataMobile(){
819
820        //顧客情報取得
821        $ret = $this->objQuery->select("*","dtb_customer","customer_id=?", array($this->objCustomer->getValue('customer_id')));
822        $arrForm = $ret[0];
823        //$arrForm['email'] = $arrForm['email_mobile'];
824
825        //メルマガフラグ取得
826        // TODO たぶん未使用
827        $arrForm['mailmaga_flg'] = $this->objQuery->get("dtb_customer","mailmaga_flg","email_mobile=?", array($this->objCustomer->getValue('email_mobile')));
828
829        //誕生日の年月日取得
830        if (isset($arrForm['birth'])){
831            $birth = split(" ", $arrForm["birth"]);
832            list($year, $month, $day) = split("-",$birth[0]);
833
834            $arrForm['year'] = $year;
835            $arrForm['month'] = $month;
836            $arrForm['day'] = $day;
837
838        }
839        return $arrForm;
840    }
841
842    /**
843     * フォームパラメータの内容を小文字に変換する.
844     *
845     * @param array $arrParam パラメータ名の配列
846     * @return void
847     */
848    function paramToLower(&$arrParam) {
849        foreach ($arrParam as $key => $val) {
850            if (!isset($val)) {
851                $this->arrForm[$key] = "";
852            }elseif($key == 'email' || $key == 'email_mobile'){
853                $this->arrForm[$key] = strtolower($val);
854            }
855        }
856    }
857}
858?>
Note: See TracBrowser for help on using the repository browser.