все просто

Добавление регистрации пользователя при оформлении заказа в 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

Комментарии ()