Добавление регистрации пользователя при оформлении заказа в miniShop2
При оформлении заказа в miniShop2 всегда происходит регистрация пользователя, но уведомление о регистрации не приходит. Если на каком-то этапе пользовател решил, что ему надо зарегистрироваться, то ему достаточно будет указть это при оформлении заказа.На его почту будет отправлено письмо с его Логином и паролем.
Для этого необходимо сделать несколько настроек miniShop2.
Создать само поле регистрации, что бы его нельзя было проставить уже Авторизированным пользователям, то прячем его
<div class="col-sm-8"> <label for="group"><input id="group" name="group" type="checkbox" value="Users" /> Регистрация</label> <p class="small">(Оформляя заказ мы автоматически создадим Вам профиль)</p> </div>
В дальнейшем, согласно инструции к miniShop2 создаем свой обработчик Заказов. Пишем в файл components/minishop2/custom/order/msorderreguserhandler.class.php
<?php class msOrderRegUserHandler extends msOrderHandler { /** * Returns id for current customer. If customer is not exists, registers him and returns id. * * @return integer $id */ public function getCustomerId() { //эту функцию переписываем частично $customer = null; $response = $this->ms2->invokeEvent('msOnBeforeGetOrderCustomer', array( 'order' => $this->ms2->order, 'customer' => &$customer, )); if (!$response['success']) { return $response['message']; } if (!$customer) { $data = $this->ms2->order->get(); $email = isset($data['email']) ? $data['email'] : ''; $receiver = isset($data['receiver']) ? $data['receiver'] : ''; $phone = isset($data['phone']) ? $data['phone'] : ''; $user_group = isset($data['group']) ? $data['group'] : '111'; //$this->modx->log(modX::LOG_LEVEL_ERROR, $user_group); if (empty($receiver)) { $receiver = $email ? substr($email, 0, strpos($email, '@')) : ($phone ? preg_replace('#[^0-9]#', '', $phone) : uniqid('user_', false)); } if (empty($email)) { $email = $receiver . '@' . $this->modx->getOption('http_host'); } if ($this->modx->user->isAuthenticated()) { $profile = $this->modx->user->Profile; if (!$profile->get('email')) { $profile->set('email', $email); $profile->save(); } $customer = $this->modx->user; } else { $c = $this->modx->newQuery('modUser'); $c->leftJoin('modUserProfile', 'Profile'); $filter = array('username' => $email, 'OR:Profile.email:=' => $email); if (!empty($phone)) { $filter['OR:Profile.mobilephone:='] = $phone; } $c->where($filter); $c->select('modUser.id'); if (!$customer = $this->modx->getObject('modUser', $c)) { $pass=md5(rand()); $customer = $this->modx->newObject('modUser', array('username' => $email, 'password' => $pass)); $profile = $this->modx->newObject('modUserProfile', array( 'email' => $email, 'fullname' => $receiver, 'mobilephone' => $phone )); $customer->addOne($profile); /** @var modUserSetting $setting */ $setting = $this->modx->newObject('modUserSetting'); $setting->fromArray(array( 'key' => 'cultureKey', 'area' => 'language', 'value' => $this->modx->getOption('cultureKey', null, 'en', true), ), '', true); $customer->addMany($setting); if (!$customer->save()) { $customer = null; }else if (!empty($user_group)){ if($customer->joinGroup('Users')){ $url=$this->modx->getOption('site_url'); $name=$this->modx->getOption('site_name'); $subjectTheme='Вы зарегистрировались на сайте '.$name; $bodyTheme='<html><body><p>Здравствуйте, '.$data['receiver'].'!</p><p>Сделав заказ, вы зарегистрировались на сайте <a href="'.$url.'">'.$name.'</a>. Ваши данные для входа:</p><p>Логин: '.$email.'</p><p>Пароль: '.$pass.'</p><p>Изменить пароль можно в личном кабинете</p></body></html>'; //$sent = $customer->sendEmail($bodyTheme, array('subject' => $subjectTheme)); $sent = $this->ms2->sendEmail($email,$subjectTheme,$bodyTheme); if ($sent){ $this->modx->log(modX::LOG_LEVEL_ERROR, $sent); } }else{ $this->modx->log(modX::LOG_LEVEL_ERROR, 'Какая та ошибка с добавлением в группу, письмо не отправлено'); } }else if ($groups = $this->modx->getOption('ms2_order_user_groups', null, false)) { $groups = array_map('trim', explode(',', $groups)); foreach ($groups as $group) { $customer->joinGroup($group); } } }else if (!empty($user_group)){ $profile=$customer->getOne('Profile'); if ($profile->get('logincount') > 0){ $length = 8; $olduser = $customer; $pass=$olduser->generatePassword($length); $olduser->toArray(); $olduser->set('password',$pass); $olduser->save(); if ($olduser->joinGroup('Users')){ $url=$this->modx->getOption('site_url'); $name=$this->modx->getOption('site_name'); $subjectTheme='Вы зарегистрировались на сайте '.$name; $bodyTheme='<html><body><p>Здравствуйте, '.$data['receiver'].'!</p><p>Сделав очередной заказ, вы подвердили регистрацию на сайте <a href="'.$url.'">'.$name.'</a>. Ваши данные для входа:</p><p>Логин: '.$email.'</p><p>Пароль: '.$pass.'</p><p>Изменить пароль можно в личном кабинете</p></body></html>'; //$pdo = $this->modx->getService('pdoFetch'); // можно переделать на чанк при желании //$message = $pdo->getChunk('@FILE chunks/email/user.register.tpl', array('username' => $username, 'password' => $pass)); $sent = $this->ms2->sendEmail($email,$subjectTheme,$bodyTheme); //Мгновенная авторизация на сайте без набора пароля, кому надо раскомментируйте //$olduser->addSessionContext('web'); if ($sent){ $this->modx->log(modX::LOG_LEVEL_ERROR, $sent); } }else{ $this->modx->log(modX::LOG_LEVEL_ERROR, 'Какая та ошибка с добавлением в группу, письмо не отправлено'); } } } } } $response = $this->ms2->invokeEvent('msOnGetOrderCustomer', array( 'order' => $this->ms2->order, 'customer' => &$customer, )); if (!$response['success']) { return $response['message']; } return $customer instanceof modUser ? $customer->get('id') : 0; } public function submit($data = array()) { //в этой меняем вызов функции getCustomerId под свою, ранее исправленную $response = $this->ms2->invokeEvent('msOnSubmitOrder', array( 'data' => $data, 'order' => $this, )); if (!$response['success']) { return $this->error($response['message']); } if (!empty($response['data']['data'])) { $this->set($response['data']['data']); } $response = $this->getDeliveryRequiresFields(); if ($this->ms2->config['json_response']) { $response = json_decode($response, true); } if (!$response['success']) { return $this->error($response['message']); } $requires = $response['data']['requires']; $errors = array(); foreach ($requires as $v) { if (!empty($v) && empty($this->order[$v])) { $errors[] = $v; } } if (!empty($errors)) { return $this->error('ms2_order_err_requires', $errors); } $user_id = $this->getCustomerId(); if (empty($user_id) || !is_int($user_id)) { return $this->error(is_string($user_id) ? $user_id : 'ms2_err_user_nf'); } $cart_status = $this->ms2->cart->status(); $delivery_cost = $this->getCost(false, true); $cart_cost = $this->getCost(true, true) - $delivery_cost; $createdon = date('Y-m-d H:i:s'); /** @var msOrder $order */ $order = $this->modx->newObject('msOrder'); $order->fromArray(array( 'user_id' => $user_id, 'createdon' => $createdon, 'num' => $this->getNum(), 'delivery' => $this->order['delivery'], 'payment' => $this->order['payment'], 'cart_cost' => $cart_cost, 'weight' => $cart_status['total_weight'], 'delivery_cost' => $delivery_cost, 'cost' => $cart_cost + $delivery_cost, 'status' => 0, 'context' => $this->ms2->config['ctx'], )); // Adding address /** @var msOrderAddress $address */ $address = $this->modx->newObject('msOrderAddress'); $address->fromArray(array_merge($this->order, array( 'user_id' => $user_id, 'createdon' => $createdon, ))); $order->addOne($address); // Adding products $cart = $this->ms2->cart->get(); $products = array(); foreach ($cart as $v) { if ($tmp = $this->modx->getObject('msProduct', array('id' => $v['id']))) { $name = $tmp->get('pagetitle'); } else { $name = ''; } /** @var msOrderProduct $product */ $product = $this->modx->newObject('msOrderProduct'); $product->fromArray(array_merge($v, array( 'product_id' => $v['id'], 'name' => $name, 'cost' => $v['price'] * $v['count'], ))); $products[] = $product; } $order->addMany($products); $response = $this->ms2->invokeEvent('msOnBeforeCreateOrder', array( 'msOrder' => $order, 'order' => $this, )); if (!$response['success']) { return $this->error($response['message']); } if ($order->save()) { $response = $this->ms2->invokeEvent('msOnCreateOrder', array( 'msOrder' => $order, 'order' => $this, )); if (!$response['success']) { return $this->error($response['message']); } $this->ms2->cart->clean(); $this->clean(); if (empty($_SESSION['minishop2']['orders'])) { $_SESSION['minishop2']['orders'] = array(); } $_SESSION['minishop2']['orders'][] = $order->get('id'); // Trying to set status "new" $response = $this->ms2->changeOrderStatus($order->get('id'), 1); if ($response !== true) { return $this->error($response, array('msorder' => $order->get('id'))); } /** @var msPayment $payment */ elseif ($payment = $this->modx->getObject('msPayment', array('id' => $order->get('payment'), 'active' => 1)) ) { $response = $payment->send($order); if ($this->config['json_response']) { @session_write_close(); exit(is_array($response) ? json_encode($response) : $response); } else { if (!empty($response['data']['redirect'])) { $this->modx->sendRedirect($response['data']['redirect']); } elseif (!empty($response['data']['msorder'])) { $this->modx->sendRedirect( $this->modx->context->makeUrl( $this->modx->resource->id, array('msorder' => $response['data']['msorder']) ) ); } else { $this->modx->sendRedirect($this->modx->context->makeUrl($this->modx->resource->id)); } return $this->success(); } } else { if ($this->ms2->config['json_response']) { return $this->success('', array('msorder' => $order->get('id'))); } else { $this->modx->sendRedirect( $this->modx->context->makeUrl( $this->modx->resource->id, array('msorder' => $response['data']['msorder']) ) ); return $this->success(); } } } return $this->error(); } }
Регистрируем его в miniShop2
<?php if ($miniShop2 = $modx->getService('miniShop2')) { $miniShop2->addService('order', 'msOrderRegUserHandler', '{core_path}components/minishop2/custom/order/msorderreguserhandler.class.php' ); }
И прописываем в системных настройках miniShop2 у ключа ms2_order_handler_class как msOrderRegUserHandler
Комментарии ()