Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
33.33% |
1 / 3 |
CRAP | |
89.74% |
70 / 78 |
| EntryController | |
0.00% |
0 / 1 |
|
33.33% |
1 / 3 |
13.18 | |
89.74% |
70 / 78 |
| index | |
0.00% |
0 / 1 |
8.05 | |
90.57% |
48 / 53 |
|||
| complete | |
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
|||
| activate | |
0.00% |
0 / 1 |
4.03 | |
87.50% |
21 / 24 |
|||
| <?php | |
| /* | |
| * This file is part of EC-CUBE | |
| * | |
| * Copyright(c) 2000-2015 LOCKON CO.,LTD. All Rights Reserved. | |
| * | |
| * http://www.lockon.co.jp/ | |
| * | |
| * This program is free software; you can redistribute it and/or | |
| * modify it under the terms of the GNU General Public License | |
| * as published by the Free Software Foundation; either version 2 | |
| * of the License, or (at your option) any later version. | |
| * | |
| * This program is distributed in the hope that it will be useful, | |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| * GNU General Public License for more details. | |
| * | |
| * You should have received a copy of the GNU General Public License | |
| * along with this program; if not, write to the Free Software | |
| * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | |
| */ | |
| namespace Eccube\Controller; | |
| use Eccube\Application; | |
| use Eccube\Entity\Master\CustomerStatus; | |
| use Eccube\Event\EccubeEvents; | |
| use Eccube\Event\EventArgs; | |
| use Symfony\Component\HttpFoundation\Request; | |
| use Symfony\Component\HttpKernel\Exception as HttpException; | |
| use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken; | |
| use Symfony\Component\Validator\Constraints as Assert; | |
| class EntryController extends AbstractController | |
| { | |
| /** | |
| * 会員登録画面. | |
| * | |
| * @param Application $app | |
| * @param Request $request | |
| * @return \Symfony\Component\HttpFoundation\Response | |
| */ | |
| public function index(Application $app, Request $request) | |
| { | |
| if ($app->isGranted('ROLE_USER')) { | |
| log_info('認証済のためログイン処理をスキップ'); | |
| return $app->redirect($app->url('mypage')); | |
| } | |
| /** @var $Customer \Eccube\Entity\Customer */ | |
| $Customer = $app['eccube.repository.customer']->newCustomer(); | |
| /* @var $builder \Symfony\Component\Form\FormBuilderInterface */ | |
| $builder = $app['form.factory']->createBuilder('entry', $Customer); | |
| $event = new EventArgs( | |
| array( | |
| 'builder' => $builder, | |
| 'Customer' => $Customer, | |
| ), | |
| $request | |
| ); | |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::FRONT_ENTRY_INDEX_INITIALIZE, $event); | |
| /* @var $form \Symfony\Component\Form\FormInterface */ | |
| $form = $builder->getForm(); | |
| $form->handleRequest($request); | |
| if ($form->isSubmitted() && $form->isValid()) { | |
| switch ($request->get('mode')) { | |
| case 'confirm': | |
| log_info('会員登録確認開始'); | |
| $builder->setAttribute('freeze', true); | |
| $form = $builder->getForm(); | |
| $form->handleRequest($request); | |
| log_info('会員登録確認完了'); | |
| return $app->render('Entry/confirm.twig', array( | |
| 'form' => $form->createView(), | |
| )); | |
| case 'complete': | |
| log_info('会員登録開始'); | |
| $Customer | |
| ->setSalt( | |
| $app['eccube.repository.customer']->createSalt(5) | |
| ) | |
| ->setPassword( | |
| $app['eccube.repository.customer']->encryptPassword($app, $Customer) | |
| ) | |
| ->setSecretKey( | |
| $app['eccube.repository.customer']->getUniqueSecretKey($app) | |
| ); | |
| $CustomerAddress = new \Eccube\Entity\CustomerAddress(); | |
| $CustomerAddress | |
| ->setFromCustomer($Customer); | |
| $app['orm.em']->persist($Customer); | |
| $app['orm.em']->persist($CustomerAddress); | |
| $app['orm.em']->flush(); | |
| log_info('会員登録完了'); | |
| $event = new EventArgs( | |
| array( | |
| 'form' => $form, | |
| 'Customer' => $Customer, | |
| 'CustomerAddress' => $CustomerAddress, | |
| ), | |
| $request | |
| ); | |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::FRONT_ENTRY_INDEX_COMPLETE, $event); | |
| $activateUrl = $app->url('entry_activate', array('secret_key' => $Customer->getSecretKey())); | |
| /** @var $BaseInfo \Eccube\Entity\BaseInfo */ | |
| $BaseInfo = $app['eccube.repository.base_info']->get(); | |
| $activateFlg = $BaseInfo->getOptionCustomerActivate(); | |
| // 仮会員設定が有効な場合は、確認メールを送信し完了画面表示. | |
| if ($activateFlg) { | |
| // メール送信 | |
| $app['eccube.service.mail']->sendCustomerConfirmMail($Customer, $activateUrl); | |
| if ($event->hasResponse()) { | |
| return $event->getResponse(); | |
| } | |
| log_info('仮会員登録完了画面へリダイレクト'); | |
| return $app->redirect($app->url('entry_complete')); | |
| // 仮会員設定が無効な場合は認証URLへ遷移させ、会員登録を完了させる. | |
| } else { | |
| log_info('本会員登録画面へリダイレクト'); | |
| return $app->redirect($activateUrl); | |
| } | |
| } | |
| } | |
| return $app->render('Entry/index.twig', array( | |
| 'form' => $form->createView(), | |
| )); | |
| } | |
| /** | |
| * 会員登録完了画面. | |
| * | |
| * @param Application $app | |
| * @return \Symfony\Component\HttpFoundation\Response | |
| */ | |
| public function complete(Application $app) | |
| { | |
| return $app->render('Entry/complete.twig', array()); | |
| } | |
| /** | |
| * 会員のアクティベート(本会員化)を行う. | |
| * | |
| * @param Application $app | |
| * @param Request $request | |
| * @param $secret_key | |
| * @return \Symfony\Component\HttpFoundation\Response | |
| */ | |
| public function activate(Application $app, Request $request, $secret_key) | |
| { | |
| $errors = $app['validator']->validateValue($secret_key, array( | |
| new Assert\NotBlank(), | |
| new Assert\Regex(array( | |
| 'pattern' => '/^[a-zA-Z0-9]+$/', | |
| )) | |
| ) | |
| ); | |
| if ($request->getMethod() === 'GET' && count($errors) === 0) { | |
| log_info('本会員登録開始'); | |
| try { | |
| $Customer = $app['eccube.repository.customer'] | |
| ->getNonActiveCustomerBySecretKey($secret_key); | |
| } catch (\Exception $e) { | |
| throw new HttpException\NotFoundHttpException('※ 既に会員登録が完了しているか、無効なURLです。'); | |
| } | |
| $CustomerStatus = $app['eccube.repository.customer_status']->find(CustomerStatus::ACTIVE); | |
| $Customer->setStatus($CustomerStatus); | |
| $app['orm.em']->persist($Customer); | |
| $app['orm.em']->flush(); | |
| log_info('本会員登録完了'); | |
| $event = new EventArgs( | |
| array( | |
| 'Customer' => $Customer, | |
| ), | |
| $request | |
| ); | |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::FRONT_ENTRY_ACTIVATE_COMPLETE, $event); | |
| // メール送信 | |
| $app['eccube.service.mail']->sendCustomerCompleteMail($Customer); | |
| // 本会員登録してログイン状態にする | |
| $token = new UsernamePasswordToken($Customer, null, 'customer', array('ROLE_USER')); | |
| $this->getSecurity($app)->setToken($token); | |
| log_info('ログイン済に変更', array($app->user()->getId())); | |
| return $app->render('Entry/activate.twig'); | |
| } else { | |
| throw new HttpException\AccessDeniedHttpException('不正なアクセスです。'); | |
| } | |
| } | |
| } |