source: branches/version-2_12-dev/data/class/helper/SC_Helper_Customer.php @ 22340

Revision 22340, 33.7 KB checked in by Seasoft, 11 years ago (diff)

#2053 (モバイルサイト 会員パスワードの文字数制限チェックが行われない)
#2043 (typo修正・ソース整形・ソースコメントの改善 for 2.12.4)
#1669 (変数の初期化漏れ)

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • 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-2013 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/**
25 * 会員情報の登録・編集・検索ヘルパークラス.
26 *
27 *
28 * @package Helper
29 * @author Hirokazu Fukuda
30 * @version $Id$
31 */
32class SC_Helper_Customer {
33
34    /**
35     * 会員情報の登録・編集処理を行う.
36     *
37     * @param array $arrData 登録するデータの配列(SC_FormParamのgetDbArrayの戻り値)
38     * @param array $customer_id nullの場合はinsert, 存在する場合はupdate
39     * @access public
40     * @return integer 登録編集したユーザーのcustomer_id
41     */
42    function sfEditCustomerData($arrData, $customer_id = null) {
43        $objQuery =& SC_Query_Ex::getSingletonInstance();
44        $objQuery->begin();
45
46        $old_version_flag = false;
47
48        $arrData['update_date'] = 'CURRENT_TIMESTAMP';    // 更新日
49
50        // salt値の生成(insert時)または取得(update時)。
51        if (is_numeric($customer_id)) {
52            $salt = $objQuery->get('salt', 'dtb_customer', 'customer_id = ? ', array($customer_id));
53
54            // 旧バージョン(2.11未満)からの移行を考慮
55            if (strlen($salt) === 0) {
56                $old_version_flag = true;
57            }
58        } else {
59            $salt = SC_Utils_Ex::sfGetRandomString(10);
60            $arrData['salt'] = $salt;
61        }
62        //-- パスワードの更新がある場合は暗号化
63        if ($arrData['password'] == DEFAULT_PASSWORD or $arrData['password'] == '') {
64            //更新しない
65            unset($arrData['password']);
66        } else {
67            // 旧バージョン(2.11未満)からの移行を考慮
68            if ($old_version_flag) {
69                $is_password_updated = true;
70                $salt = SC_Utils_Ex::sfGetRandomString(10);
71                $arrData['salt'] = $salt;
72            }
73
74            $arrData['password'] = SC_Utils_Ex::sfGetHashString($arrData['password'], $salt);
75        }
76        //-- 秘密の質問の更新がある場合は暗号化
77        if ($arrData['reminder_answer'] == DEFAULT_PASSWORD or $arrData['reminder_answer'] == '') {
78            //更新しない
79            unset($arrData['reminder_answer']);
80
81            // 旧バージョン(2.11未満)からの移行を考慮
82            if ($old_version_flag && $is_password_updated) {
83                // パスワードが更新される場合は、平文になっている秘密の質問を暗号化する
84                $reminder_answer = $objQuery->get('reminder_answer', 'dtb_customer', 'customer_id = ? ', array($customer_id));
85                $arrData['reminder_answer'] = SC_Utils_Ex::sfGetHashString($reminder_answer, $salt);
86            }
87        } else {
88            // 旧バージョン(2.11未満)からの移行を考慮
89            if ($old_version_flag && !$is_password_updated) {
90                // パスワードが更新されない場合は、平文のままにする
91                unset($arrData['salt']);
92            } else {
93                $arrData['reminder_answer'] = SC_Utils_Ex::sfGetHashString($arrData['reminder_answer'], $salt);
94            }
95        }
96
97        //-- 編集登録実行
98        if (is_numeric($customer_id)) {
99            // 編集
100            $objQuery->update('dtb_customer', $arrData, 'customer_id = ? ', array($customer_id));
101        } else {
102            // 新規登録
103
104            // 会員ID
105            $customer_id = $objQuery->nextVal('dtb_customer_customer_id');
106            $arrData['customer_id'] = $customer_id;
107            // 作成日
108            if (is_null($arrData['create_date'])) {
109                $arrData['create_date'] = 'CURRENT_TIMESTAMP';
110            }
111            $objQuery->insert('dtb_customer', $arrData);
112        }
113
114        $objQuery->commit();
115
116        return $customer_id;
117    }
118
119    /**
120     * 注文番号、利用ポイント、加算ポイントから最終ポイントを取得する.
121     *
122     * @param integer $order_id 注文番号
123     * @param integer $use_point 利用ポイント
124     * @param integer $add_point 加算ポイント
125     * @return array 最終ポイントの配列
126     */
127    function sfGetCustomerPoint($order_id, $use_point, $add_point) {
128        $objQuery =& SC_Query_Ex::getSingletonInstance();
129
130        $arrRet = $objQuery->select('customer_id', 'dtb_order', 'order_id = ?', array($order_id));
131        $customer_id = $arrRet[0]['customer_id'];
132        if ($customer_id != '' && $customer_id >= 1) {
133            if (USE_POINT !== false) {
134                $arrRet = $objQuery->select('point', 'dtb_customer', 'customer_id = ?', array($customer_id));
135                $point = $arrRet[0]['point'];
136                $total_point = $arrRet[0]['point'] - $use_point + $add_point;
137            } else {
138                $total_point = 0;
139                $point = 0;
140            }
141        } else {
142            $total_point = '';
143            $point = '';
144        }
145
146        return array($point, $total_point);
147    }
148
149    /**
150     * emailアドレスから、登録済み会員や退会済み会員をチェックする
151     *
152     * XXX SC_CheckError からしか呼び出されず, 本クラスの中で SC_CheckError を呼び出している
153     *
154     * @param string $email  メールアドレス
155     * @return integer  0:登録可能     1:登録済み   2:再登録制限期間内削除ユーザー  3:自分のアドレス
156     */
157    function sfCheckRegisterUserFromEmail($email) {
158        $objCustomer = new SC_Customer_Ex();
159        $objQuery =& SC_Query_Ex::getSingletonInstance();
160
161        // ログインしている場合、すでに登録している自分のemailの場合
162        if ($objCustomer->isLoginSuccess(true)
163            && SC_Helper_Customer_Ex::sfCustomerEmailDuplicationCheck($objCustomer->getValue('customer_id'), $email)) {
164            // 自分のアドレス
165            return 3;
166        }
167
168        $arrRet = $objQuery->select('email, update_date, del_flg',
169            'dtb_customer',
170            'email = ? OR email_mobile = ? ORDER BY del_flg',
171            array($email, $email));
172
173        if (count($arrRet) > 0) {
174            // 会員である場合
175            if ($arrRet[0]['del_flg'] != '1') {
176                // 登録済み
177                return 1;
178            } else {
179                // 退会した会員である場合
180                $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrRet[0]['update_date']);
181                $now_time   = time();
182                $pass_time  = $now_time - $leave_time;
183                // 退会から何時間-経過しているか判定する。
184                $limit_time = ENTRY_LIMIT_HOUR * 3600;
185                if ($pass_time < $limit_time) {
186                    // 再登録制限期間内削除ユーザー
187                    return 2;
188                }
189            }
190        }
191
192        // 登録可能
193        return 0;
194    }
195
196    /**
197     * ログイン時メールアドレス重複チェック.
198     *
199     * 会員の保持する email, mobile_email が, 引数 $email と一致するかチェックする
200     *
201     * @param integer $customer_id チェック対象会員の会員ID
202     * @param string $email チェック対象のメールアドレス
203     * @return boolean メールアドレスが重複する場合 true
204     */
205    function sfCustomerEmailDuplicationCheck($customer_id, $email) {
206        $objQuery =& SC_Query_Ex::getSingletonInstance();
207
208        $arrResults = $objQuery->getRow('email, email_mobile',
209                                        'dtb_customer', 'customer_id = ?',
210                                        array($customer_id));
211        $return
212            =  strlen($arrResults['email']) >= 1 && $email === $arrResults['email']
213            || strlen($arrResults['email_mobile']) >= 1 &&  $email === $arrResults['email_mobile']
214        ;
215
216        return $return;
217    }
218
219    /**
220     * customer_idから会員情報を取得する
221     *
222     * @param mixed $customer_id
223     * @param mixed $mask_flg
224     * @access public
225     * @return array 会員情報の配列を返す
226     */
227    function sfGetCustomerData($customer_id, $mask_flg = true) {
228        $objQuery       =& SC_Query_Ex::getSingletonInstance();
229
230        // 会員情報DB取得
231        $ret        = $objQuery->select('*','dtb_customer','customer_id=?', array($customer_id));
232        $arrForm    = $ret[0];
233
234        // 確認項目に複製
235        $arrForm['email02'] = $arrForm['email'];
236        $arrForm['email_mobile02'] = $arrForm['email_mobile'];
237
238        // 誕生日を年月日に分ける
239        if (isset($arrForm['birth'])) {
240            $birth = explode(' ', $arrForm['birth']);
241            list($arrForm['year'], $arrForm['month'], $arrForm['day']) = explode('-',$birth[0]);
242        }
243
244        if ($mask_flg) {
245            $arrForm['password']          = DEFAULT_PASSWORD;
246            $arrForm['password02']        = DEFAULT_PASSWORD;
247            $arrForm['reminder_answer']   = DEFAULT_PASSWORD;
248        }
249
250        return $arrForm;
251    }
252
253    /**
254     * 会員ID指定またはwhere条件指定での会員情報取得(単一行データ)
255     *
256     * TODO: sfGetCustomerDataと統合したい
257     *
258     * @param integer $customer_id 会員ID (指定無しでも構わないが、Where条件を入れる事)
259     * @param string $add_where 追加WHERE条件
260     * @param array $arrAddVal 追加WHEREパラメーター
261     * @access public
262     * @return array 対象会員データ
263     */
264    function sfGetCustomerDataFromId($customer_id, $add_where = '', $arrAddVal = array()) {
265        $objQuery   =& SC_Query_Ex::getSingletonInstance();
266
267        if ($add_where == '') {
268            $where = 'customer_id = ?';
269            $arrData = $objQuery->getRow('*', 'dtb_customer', $where, array($customer_id));
270        } else {
271            $where = $add_where;
272            if (SC_Utils_Ex::sfIsInt($customer_id)) {
273                $where .= ' AND customer_id = ?';
274                $arrAddVal[] = $customer_id;
275            }
276            $arrData = $objQuery->getRow('*', 'dtb_customer', $where, $arrAddVal);
277        }
278
279        return $arrData;
280    }
281
282    /**
283     * 重複しない会員登録キーを発行する。
284     *
285     * @access public
286     * @return string 会員登録キーの文字列
287     */
288    function sfGetUniqSecretKey() {
289        $objQuery =& SC_Query_Ex::getSingletonInstance();
290
291        do {
292            $uniqid = SC_Utils_Ex::sfGetUniqRandomId('r');
293            $exists = $objQuery->exists('dtb_customer', 'secret_key = ?', array($uniqid));
294        } while ($exists);
295
296        return $uniqid;
297    }
298
299    /**
300     * 会員登録キーから会員IDを取得する.
301     *
302     * @param string $uniqid 会員登録キー
303     * @param boolean $check_status 本会員のみを対象とするか
304     * @access public
305     * @return integer 会員ID
306     */
307    function sfGetCustomerId($uniqid, $check_status = false) {
308        $objQuery   =& SC_Query_Ex::getSingletonInstance();
309
310        $where      = 'secret_key = ?';
311
312        if ($check_status) {
313            $where .= ' AND status = 1 AND del_flg = 0';
314        }
315
316        return $objQuery->get('customer_id', 'dtb_customer', $where, array($uniqid));
317    }
318
319    /**
320     * 会員登録時フォーム初期化
321     *
322     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
323     * @param boolean $isAdmin true:管理者画面 false:会員向け
324     * @access public
325     * @return void
326     */
327    function sfCustomerEntryParam(&$objFormParam, $isAdmin = false) {
328        SC_Helper_Customer_Ex::sfCustomerCommonParam($objFormParam);
329        SC_Helper_Customer_Ex::sfCustomerRegisterParam($objFormParam, $isAdmin);
330        if ($isAdmin) {
331            $objFormParam->addParam('会員ID', 'customer_id', INT_LEN, 'n', array('NUM_CHECK'));
332            $objFormParam->addParam('携帯メールアドレス', 'email_mobile', null, 'a', array('NO_SPTAB', 'EMAIL_CHECK', 'SPTAB_CHECK' ,'EMAIL_CHAR_CHECK', 'MOBILE_EMAIL_CHECK'));
333            $objFormParam->addParam('会員状態', 'status', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
334            $objFormParam->addParam('SHOP用メモ', 'note', LTEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
335            $objFormParam->addParam('所持ポイント', 'point', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK'), 0);
336        }
337
338        if (SC_Display_Ex::detectDevice() == DEVICE_TYPE_MOBILE) {
339            // 登録確認画面の「戻る」ボタンのためのパラメーター
340            $objFormParam->addParam('戻る', 'return', '', '', array(), '', false);
341        }
342    }
343
344    /**
345     * 会員情報変更フォーム初期化
346     *
347     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
348     * @access public
349     * @return void
350     */
351    function sfCustomerMypageParam(&$objFormParam) {
352        SC_Helper_Customer_Ex::sfCustomerCommonParam($objFormParam);
353        SC_Helper_Customer_Ex::sfCustomerRegisterParam($objFormParam, false, true);
354        if (SC_Display_Ex::detectDevice() !== DEVICE_TYPE_MOBILE) {
355            $objFormParam->addParam('携帯メールアドレス', 'email_mobile', null, 'a', array('NO_SPTAB', 'EMAIL_CHECK', 'SPTAB_CHECK' ,'EMAIL_CHAR_CHECK', 'MOBILE_EMAIL_CHECK'));
356            $objFormParam->addParam('携帯メールアドレス(確認)', 'email_mobile02', null, 'a', array('NO_SPTAB', 'EMAIL_CHECK','SPTAB_CHECK' , 'EMAIL_CHAR_CHECK', 'MOBILE_EMAIL_CHECK'), '', false);
357        } else {
358            $objFormParam->addParam('携帯メールアドレス', 'email_mobile', null, 'a', array('EXIST_CHECK', 'NO_SPTAB', 'EMAIL_CHECK', 'SPTAB_CHECK' ,'EMAIL_CHAR_CHECK', 'MOBILE_EMAIL_CHECK'));
359            $objFormParam->addParam('メールアドレス', 'email', null, 'a', array('NO_SPTAB', 'EMAIL_CHECK', 'SPTAB_CHECK' ,'EMAIL_CHAR_CHECK'));
360        }
361    }
362
363    /**
364     * 会員共通
365     *
366     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
367     * @access public
368     * @return void
369     */
370    function sfCustomerCommonParam(&$objFormParam) {
371        $objFormParam->addParam('お名前(姓)', 'name01', STEXT_LEN, 'aKV', array('EXIST_CHECK', 'NO_SPTAB', 'SPTAB_CHECK' ,'MAX_LENGTH_CHECK'));
372        $objFormParam->addParam('お名前(名)', 'name02', STEXT_LEN, 'aKV', array('EXIST_CHECK', 'NO_SPTAB', 'SPTAB_CHECK' , 'MAX_LENGTH_CHECK'));
373        $objFormParam->addParam('お名前(フリガナ・姓)', 'kana01', STEXT_LEN, 'CKV', array('EXIST_CHECK', 'NO_SPTAB', 'SPTAB_CHECK' ,'MAX_LENGTH_CHECK', 'KANA_CHECK'));
374        $objFormParam->addParam('お名前(フリガナ・名)', 'kana02', STEXT_LEN, 'CKV', array('EXIST_CHECK', 'NO_SPTAB', 'SPTAB_CHECK' ,'MAX_LENGTH_CHECK', 'KANA_CHECK'));
375        $objFormParam->addParam('郵便番号1', 'zip01', ZIP01_LEN, 'n', array('EXIST_CHECK', 'SPTAB_CHECK' ,'NUM_CHECK', 'NUM_COUNT_CHECK'));
376        $objFormParam->addParam('郵便番号2', 'zip02', ZIP02_LEN, 'n', array('EXIST_CHECK', 'SPTAB_CHECK' ,'NUM_CHECK', 'NUM_COUNT_CHECK'));
377        $objFormParam->addParam('都道府県', 'pref', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK'));
378        $objFormParam->addParam('住所1', 'addr01', MTEXT_LEN, 'aKV', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
379        $objFormParam->addParam('住所2', 'addr02', MTEXT_LEN, 'aKV', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
380        $objFormParam->addParam('お電話番号1', 'tel01', TEL_ITEM_LEN, 'n', array('EXIST_CHECK', 'SPTAB_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
381        $objFormParam->addParam('お電話番号2', 'tel02', TEL_ITEM_LEN, 'n', array('EXIST_CHECK', 'SPTAB_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
382        $objFormParam->addParam('お電話番号3', 'tel03', TEL_ITEM_LEN, 'n', array('EXIST_CHECK', 'SPTAB_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
383        $objFormParam->addParam('FAX番号1', 'fax01', TEL_ITEM_LEN, 'n', array('SPTAB_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
384        $objFormParam->addParam('FAX番号2', 'fax02', TEL_ITEM_LEN, 'n', array('SPTAB_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
385        $objFormParam->addParam('FAX番号3', 'fax03', TEL_ITEM_LEN, 'n', array('SPTAB_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
386    }
387
388    /**
389     * 会員登録共通
390     *
391     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
392     * @param boolean $isAdmin true:管理者画面 false:会員向け
393     * @param boolean $is_mypage マイページの場合 true
394     * @return void
395     */
396    function sfCustomerRegisterParam(&$objFormParam, $isAdmin = false, $is_mypage = false) {
397        $objFormParam->addParam('パスワード', 'password', PASSWORD_MAX_LEN, 'a', array('EXIST_CHECK', 'SPTAB_CHECK', 'ALNUM_CHECK'));
398        $objFormParam->addParam('パスワード確認用の質問の答え', 'reminder_answer', STEXT_LEN, 'aKV', array('EXIST_CHECK', 'SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
399        $objFormParam->addParam('パスワード確認用の質問', 'reminder', STEXT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
400        $objFormParam->addParam('性別', 'sex', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
401        $objFormParam->addParam('職業', 'job', INT_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
402        $objFormParam->addParam('年', 'year', 4, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'), '', false);
403        $objFormParam->addParam('月', 'month', 2, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'), '', false);
404        $objFormParam->addParam('日', 'day', 2, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'), '', false);
405        $objFormParam->addParam('メールマガジン', 'mailmaga_flg', INT_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
406
407        if (SC_Display_Ex::detectDevice() !== DEVICE_TYPE_MOBILE) {
408            $objFormParam->addParam('メールアドレス', 'email', null, 'a', array('NO_SPTAB', 'EXIST_CHECK', 'EMAIL_CHECK', 'SPTAB_CHECK' ,'EMAIL_CHAR_CHECK'));
409            $objFormParam->addParam('パスワード(確認)', 'password02', PASSWORD_MAX_LEN, 'a', array('EXIST_CHECK', 'SPTAB_CHECK' ,'ALNUM_CHECK'), '', false);
410            if (!$isAdmin) {
411                $objFormParam->addParam('メールアドレス(確認)', 'email02', null, 'a', array('NO_SPTAB', 'EXIST_CHECK', 'EMAIL_CHECK','SPTAB_CHECK' , 'EMAIL_CHAR_CHECK'), '', false);
412            }
413        } else {
414            if (!$is_mypage) {
415                $objFormParam->addParam('メールアドレス', 'email', null, 'a', array('EXIST_CHECK', 'EMAIL_CHECK', 'NO_SPTAB' ,'EMAIL_CHAR_CHECK', 'MOBILE_EMAIL_CHECK'));
416            }
417        }
418    }
419
420    /**
421     * 会員登録エラーチェック
422     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
423     * @access public
424     * @return array エラーの配列
425     */
426    function sfCustomerEntryErrorCheck(&$objFormParam) {
427        $objErr = SC_Helper_Customer_Ex::sfCustomerCommonErrorCheck($objFormParam);
428        $objErr = SC_Helper_Customer_Ex::sfCustomerRegisterErrorCheck($objErr);
429
430        /*
431         * sfCustomerRegisterErrorCheck() では, ログイン中の場合は重複チェック
432         * されないので, 再度チェックを行う
433         */
434        $objCustomer = new SC_Customer_Ex();
435        if ($objCustomer->isLoginSuccess(true)
436            && SC_Helper_Customer_Ex::sfCustomerEmailDuplicationCheck($objCustomer->getValue('customer_id'), $objFormParam->getValue('email'))) {
437            $objErr->arrErr['email'] .= '※ すでに会員登録で使用されているメールアドレスです。<br />';
438        }
439        if ($objCustomer->isLoginSuccess(true)
440            && SC_Helper_Customer_Ex::sfCustomerEmailDuplicationCheck($objCustomer->getValue('customer_id'), $objFormParam->getValue('email_mobile'))) {
441            $objErr->arrErr['email_mobile'] .= '※ すでに会員登録で使用されているメールアドレスです。<br />';
442        }
443
444        return $objErr->arrErr;
445    }
446
447    /**
448     * 会員情報変更エラーチェック
449     *
450     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
451     * @param boolean $isAdmin 管理画面チェック時:true
452     * @access public
453     * @return array エラーの配列
454     */
455    function sfCustomerMypageErrorCheck(&$objFormParam, $isAdmin = false) {
456
457        $objFormParam->toLower('email_mobile');
458        $objFormParam->toLower('email_mobile02');
459
460        $objErr = SC_Helper_Customer_Ex::sfCustomerCommonErrorCheck($objFormParam);
461        $objErr = SC_Helper_Customer_Ex::sfCustomerRegisterErrorCheck($objErr, $isAdmin);
462
463        if (isset($objErr->arrErr['password'])
464            && $objFormParam->getValue('password') == DEFAULT_PASSWORD) {
465            unset($objErr->arrErr['password']);
466            unset($objErr->arrErr['password02']);
467        }
468        if (isset($objErr->arrErr['reminder_answer'])
469                && $objFormParam->getValue('reminder_answer') == DEFAULT_PASSWORD) {
470            unset($objErr->arrErr['reminder_answer']);
471        }
472
473        return $objErr->arrErr;
474    }
475
476    /**
477     * 会員エラーチェック共通
478     *
479     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
480     * @access private
481     * @return array エラー情報の配列
482     */
483    function sfCustomerCommonErrorCheck(&$objFormParam) {
484        $objFormParam->convParam();
485        $objFormParam->toLower('email');
486        $objFormParam->toLower('email02');
487        $arrParams = $objFormParam->getHashArray();
488
489        // 入力データを渡す。
490        $objErr = new SC_CheckError_Ex($arrParams);
491        $objErr->arrErr = $objFormParam->checkError();
492
493        $objErr->doFunc(array('お電話番号', 'tel01', 'tel02', 'tel03'),array('TEL_CHECK'));
494        $objErr->doFunc(array('FAX番号', 'fax01', 'fax02', 'fax03') ,array('TEL_CHECK'));
495        $objErr->doFunc(array('郵便番号', 'zip01', 'zip02'), array('ALL_EXIST_CHECK'));
496
497        return $objErr;
498    }
499
500    /**
501     * 会員登録編集共通の相関チェック
502     *
503     * @param SC_CheckError $objErr SC_CheckError インスタンス
504     * @param boolean $isAdmin 管理画面チェック時:true
505     * @return SC_CheckError $objErr エラー情報
506     */
507    function sfCustomerRegisterErrorCheck(&$objErr, $isAdmin = false) {
508        $objErr->doFunc(array('生年月日', 'year', 'month', 'day'), array('CHECK_BIRTHDAY'));
509        $objErr->doFunc(array('パスワード', 'password', PASSWORD_MIN_LEN, PASSWORD_MAX_LEN) ,array('NUM_RANGE_CHECK'));
510
511        if (SC_Display_Ex::detectDevice() !== DEVICE_TYPE_MOBILE) {
512            if (!$isAdmin) {
513                $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', 'email', 'email02') ,array('EQUAL_CHECK'));
514            }
515            $objErr->doFunc(array('パスワード', 'パスワード(確認)', 'password', 'password02') ,array('EQUAL_CHECK'));
516        }
517
518        if (!$isAdmin) {
519            // 現会員の判定 → 現会員もしくは仮登録中は、メアド一意が前提になってるので同じメアドで登録不可
520            $objErr->doFunc(array('メールアドレス', 'email'), array('CHECK_REGIST_CUSTOMER_EMAIL'));
521            $objErr->doFunc(array('携帯メールアドレス', 'email_mobile'), array('CHECK_REGIST_CUSTOMER_EMAIL', 'MOBILE_EMAIL_CHECK'));
522        }
523
524        return $objErr;
525    }
526
527    /**
528     * 会員検索パラメーター(管理画面用)
529     *
530     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
531     * @access public
532     * @return void
533     */
534    function sfSetSearchParam(&$objFormParam) {
535        $objFormParam->addParam('会員ID', 'search_customer_id', ID_MAX_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
536        $objFormParam->addParam('お名前', 'search_name', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
537        $objFormParam->addParam('お名前(フリガナ)', 'search_kana', STEXT_LEN, 'CKV', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK', 'KANABLANK_CHECK'));
538        $objFormParam->addParam('都道府県', 'search_pref', INT_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
539        $objFormParam->addParam('誕生日(開始年)', 'search_b_start_year', 4, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
540        $objFormParam->addParam('誕生日(開始月)', 'search_b_start_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
541        $objFormParam->addParam('誕生日(開始日)', 'search_b_start_day', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
542
543        $objFormParam->addParam('誕生日(終了年)', 'search_b_end_year', 4, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
544        $objFormParam->addParam('誕生日(終了月)', 'search_b_end_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
545        $objFormParam->addParam('誕生日(終了日)', 'search_b_end_day', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
546        $objFormParam->addParam('誕生月', 'search_birth_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
547        $objFormParam->addParam('メールアドレス', 'search_email', MTEXT_LEN, 'a', array('SPTAB_CHECK', 'EMAIL_CHAR_CHECK', 'MAX_LENGTH_CHECK'));
548        $objFormParam->addParam('携帯メールアドレス', 'search_email_mobile', MTEXT_LEN, 'a', array('SPTAB_CHECK', 'EMAIL_CHAR_CHECK', 'MAX_LENGTH_CHECK'));
549        $objFormParam->addParam('電話番号', 'search_tel', TEL_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
550        $objFormParam->addParam('購入金額(開始)', 'search_buy_total_from', PRICE_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
551        $objFormParam->addParam('購入金額(終了)', 'search_buy_total_to', PRICE_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
552        $objFormParam->addParam('購入回数(開始)', 'search_buy_times_from', INT_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
553        $objFormParam->addParam('購入回数(終了)', 'search_buy_times_to', INT_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
554        $objFormParam->addParam('登録・更新日(開始年)', 'search_start_year', 4, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
555        $objFormParam->addParam('登録・更新日(開始月)', 'search_start_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
556        $objFormParam->addParam('登録・更新日(開始日)', 'search_start_day', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
557        $objFormParam->addParam('登録・更新日(終了年)', 'search_end_year', 4, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
558        $objFormParam->addParam('登録・更新日(終了月)', 'search_end_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
559        $objFormParam->addParam('登録・更新日(終了日)', 'search_end_day', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
560        $objFormParam->addParam('表示件数', 'search_page_max', INT_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'), SEARCH_PMAX, false);
561        $objFormParam->addParam('ページ番号', 'search_pageno', INT_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'), 1, false);
562        $objFormParam->addParam('最終購入日(開始年)', 'search_buy_start_year', 4, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
563        $objFormParam->addParam('最終購入日(開始月)', 'search_buy_start_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
564        $objFormParam->addParam('最終購入日(開始日)', 'search_buy_start_day', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
565        $objFormParam->addParam('最終購入日(終了年)', 'search_buy_end_year', 4, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
566        $objFormParam->addParam('最終購入日(終了月)', 'search_buy_end_month', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
567        $objFormParam->addParam('最終購入日(終了日)', 'search_buy_end_day', 2, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
568        $objFormParam->addParam('購入商品コード', 'search_buy_product_code', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
569        $objFormParam->addParam('購入商品名', 'search_buy_product_name', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
570        $objFormParam->addParam('カテゴリ', 'search_category_id', INT_LEN, 'n', array('NUM_CHECK','MAX_LENGTH_CHECK'));
571        $objFormParam->addParam('性別', 'search_sex', INT_LEN, 'n', array('MAX_LENGTH_CHECK'));
572        $objFormParam->addParam('会員状態', 'search_status', INT_LEN, 'n', array('MAX_LENGTH_CHECK'));
573        $objFormParam->addParam('職業', 'search_job', INT_LEN, 'n', array('MAX_LENGTH_CHECK'));
574    }
575
576    /**
577     * 会員検索パラメーター エラーチェック(管理画面用)
578     *
579     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
580     * @access public
581     * @return array エラー配列
582     */
583    function sfCheckErrorSearchParam(&$objFormParam) {
584        // パラメーターの基本チェック
585        $arrErr = $objFormParam->checkError();
586        // 拡張エラーチェック初期化
587        $objErr = new SC_CheckError_Ex($objFormParam->getHashArray());
588        // 拡張エラーチェック
589        $objErr->doFunc(array('誕生日(開始日)', 'search_b_start_year', 'search_b_start_month', 'search_b_start_day'), array('CHECK_DATE'));
590        $objErr->doFunc(array('誕生日(終了日)', 'search_b_end_year', 'search_b_end_month', 'search_b_end_day'), array('CHECK_DATE'));
591
592        $objErr->doFunc(array('誕生日(開始日)','誕生日(終了日)', 'search_b_start_year', 'search_b_start_month', 'search_b_start_day', 'search_b_end_year', 'search_b_end_month', 'search_b_end_day'), array('CHECK_SET_TERM'));
593        $objErr->doFunc(array('登録・更新日(開始日)', 'search_start_year', 'search_start_month', 'search_start_day',), array('CHECK_DATE'));
594        $objErr->doFunc(array('登録・更新日(終了日)', 'search_end_year', 'search_end_month', 'search_end_day'), array('CHECK_DATE'));
595        $objErr->doFunc(array('登録・更新日(開始日)','登録・更新日(終了日)', 'search_start_year', 'search_start_month', 'search_start_day', 'search_end_year', 'search_end_month', 'search_end_day'), array('CHECK_SET_TERM'));
596        $objErr->doFunc(array('最終購入日(開始)', 'search_buy_start_year', 'search_buy_start_month', 'search_buy_start_day',), array('CHECK_DATE'));
597        $objErr->doFunc(array('最終購入日(終了)', 'search_buy_end_year', 'search_buy_end_month', 'search_buy_end_day'), array('CHECK_DATE'));
598        // 開始 > 終了 の場合はエラーとする
599        $objErr->doFunc(array('最終購入日(開始)','最終購入日(終了)', 'search_buy_start_year', 'search_buy_start_month', 'search_buy_start_day', 'search_buy_end_year', 'search_buy_end_month', 'search_buy_end_day'), array('CHECK_SET_TERM'));
600
601        if (SC_Utils_Ex::sfIsInt($array['search_buy_total_from'])
602            && SC_Utils_Ex::sfIsInt($array['search_buy_total_to'])
603            && $array['search_buy_total_from'] > $array['buy_total_to']
604        ) {
605            $objErr->arrErr['search_buy_total_from'] .= '※ 購入金額の指定範囲が不正です。';
606        }
607
608        if (SC_Utils_Ex::sfIsInt($array['search_buy_times_from'])
609            && SC_Utils_Ex::sfIsInt($array['search_buy_times_to'])
610            && $array['search_buy_times_from'] > $array['search_buy_times_to']
611        ) {
612            $objErr->arrErr['search_buy_times_from'] .= '※ 購入回数の指定範囲が不正です。';
613        }
614        if (!SC_Utils_Ex::isBlank($objErr->arrErr)) {
615            $arrErr = array_merge($arrErr, $objErr->arrErr);
616        }
617
618        return $arrErr;
619    }
620
621    /**
622     * 会員一覧検索をする処理(ページング処理付き、管理画面用共通処理)
623     *
624     * @param array $arrParam 検索パラメーター連想配列
625     * @param string $limitMode ページングを利用するか判定用フラグ
626     * @return array( integer 全体件数, mixed 会員データ一覧配列, mixed SC_PageNaviオブジェクト)
627     */
628    function sfGetSearchData($arrParam, $limitMode = '') {
629        $objQuery =& SC_Query_Ex::getSingletonInstance();
630        $objSelect = new SC_CustomerList_Ex($arrParam, 'customer');
631
632        $page_max = SC_Utils_Ex::sfGetSearchPageMax($arrParam['search_page_max']);
633        $disp_pageno = $arrParam['search_pageno'];
634        if ($disp_pageno == 0) {
635            $disp_pageno = 1;
636        }
637        $offset = intval($page_max) * (intval($disp_pageno) - 1);
638        if ($limitMode == '') {
639            $objQuery->setLimitOffset($page_max, $offset);
640        }
641        $arrData = $objQuery->getAll($objSelect->getList(), $objSelect->arrVal);
642
643        // 該当全体件数の取得
644        $objQuery =& SC_Query_Ex::getSingletonInstance();
645        $linemax = $objQuery->getOne($objSelect->getListCount(), $objSelect->arrVal);
646
647        // ページ送りの取得
648        $objNavi = new SC_PageNavi_Ex($arrParam['search_pageno'],
649                                    $linemax,
650                                    $page_max,
651                                    'fnNaviSearchOnlyPage',
652                                    NAVI_PMAX);
653        return array($linemax, $arrData, $objNavi);
654    }
655
656    /**
657     * 仮会員かどうかを判定する.
658     *
659     * @param string $login_email メールアドレス
660     * @return boolean 仮会員の場合 true
661     */
662    public function checkTempCustomer($login_email) {
663        $objQuery =& SC_Query_Ex::getSingletonInstance();
664
665        $where = 'email = ? AND status = 1 AND del_flg = 0';
666        $exists = $objQuery->exists('dtb_customer', $where, array($login_email));
667
668        return $exists;
669    }
670}
Note: See TracBrowser for help on using the repository browser.