예제 #1
0
 /**
  * 管理者データをUpdateする.
  *
  * @param array 管理者データの連想配列
  * @return void
  */
 public function updateMemberData($member_id, $arrMemberData)
 {
     $objQuery = Application::alias('eccube.query');
     // Updateする値を作成する.
     $sqlVal = array();
     $sqlVal['name'] = $arrMemberData['name'];
     $sqlVal['department'] = $arrMemberData['department'];
     $sqlVal['login_id'] = $arrMemberData['login_id'];
     $sqlVal['authority'] = $arrMemberData['authority'];
     $sqlVal['work'] = $arrMemberData['work'];
     $sqlVal['update_date'] = 'CURRENT_TIMESTAMP';
     if ($arrMemberData['password'] != DEFAULT_PASSWORD) {
         $salt = Utils::sfGetRandomString(10);
         $sqlVal['salt'] = $salt;
         $sqlVal['password'] = Utils::sfGetHashString($arrMemberData['password'], $salt);
     }
     $where = 'member_id = ?';
     // UPDATEの実行
     $objQuery->update('dtb_member', $sqlVal, $where, array($member_id));
 }
예제 #2
0
 /**
  * 会員情報の登録・編集処理を行う.
  *
  * @param array $arrData     登録するデータの配列(FormParamのgetDbArrayの戻り値)
  * @param array $customer_id nullの場合はinsert, 存在する場合はupdate
  * @access public
  * @return integer 登録編集したユーザーのcustomer_id
  */
 public function sfEditCustomerData($arrData, $customer_id = null)
 {
     /* @var $objQuery Query*/
     $objQuery = Application::alias('eccube.query');
     $objQuery->begin();
     $old_version_flag = false;
     $arrData['update_date'] = 'CURRENT_TIMESTAMP';
     // 更新日
     // salt値の生成(insert時)または取得(update時)。
     if (is_numeric($customer_id)) {
         $salt = $objQuery->get('salt', 'dtb_customer', 'customer_id = ? ', array($customer_id));
         // 旧バージョン(2.11未満)からの移行を考慮
         if (strlen($salt) === 0) {
             $old_version_flag = true;
         }
     } else {
         $salt = Utils::sfGetRandomString(10);
         $arrData['salt'] = $salt;
     }
     //-- パスワードの更新がある場合は暗号化
     if ($arrData['password'] == DEFAULT_PASSWORD or $arrData['password'] == '') {
         //更新しない
         unset($arrData['password']);
     } else {
         // 旧バージョン(2.11未満)からの移行を考慮
         if ($old_version_flag) {
             $is_password_updated = true;
             $salt = Utils::sfGetRandomString(10);
             $arrData['salt'] = $salt;
         }
         $arrData['password'] = Utils::sfGetHashString($arrData['password'], $salt);
     }
     //-- 秘密の質問の更新がある場合は暗号化
     if ($arrData['reminder_answer'] == DEFAULT_PASSWORD or $arrData['reminder_answer'] == '') {
         //更新しない
         unset($arrData['reminder_answer']);
         // 旧バージョン(2.11未満)からの移行を考慮
         if ($old_version_flag && $is_password_updated) {
             // パスワードが更新される場合は、平文になっている秘密の質問を暗号化する
             $reminder_answer = $objQuery->get('reminder_answer', 'dtb_customer', 'customer_id = ? ', array($customer_id));
             $arrData['reminder_answer'] = Utils::sfGetHashString($reminder_answer, $salt);
         }
     } else {
         // 旧バージョン(2.11未満)からの移行を考慮
         if ($old_version_flag && !$is_password_updated) {
             // パスワードが更新されない場合は、平文のままにする
             unset($arrData['salt']);
         } else {
             $arrData['reminder_answer'] = Utils::sfGetHashString($arrData['reminder_answer'], $salt);
         }
     }
     //デフォルト国IDを追加
     if (FORM_COUNTRY_ENABLE == false) {
         $arrData['country_id'] = DEFAULT_COUNTRY_ID;
     }
     //-- 編集登録実行
     if (is_numeric($customer_id)) {
         // 編集
         $objQuery->update('dtb_customer', $arrData, 'customer_id = ? ', array($customer_id));
     } else {
         // 新規登録
         // 会員ID
         $customer_id = $objQuery->nextVal('dtb_customer_customer_id');
         $arrData['customer_id'] = $customer_id;
         // 作成日
         if (is_null($arrData['create_date'])) {
             $arrData['create_date'] = 'CURRENT_TIMESTAMP';
         }
         $objQuery->insert('dtb_customer', $arrData);
     }
     $objQuery->commit();
     return $customer_id;
 }