source: branches/comu-ver2/data/class/pages/mypage/LC_Page_Mypage_Change.php @ 17579

Revision 17579, 40.6 KB checked in by Seasoft, 16 years ago (diff)

merge r17463,r17464,r17465,r17468,r17472,r17473,r17493,r17497,r17500,r17501,r17504

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