| <?php |
| <?php |
| /* |
| /* |
| * This file is part of EC-CUBE |
| * This file is part of EC-CUBE |
| * |
| * |
| * Copyright(c) 2000-2015 LOCKON CO.,LTD. All Rights Reserved. |
| * Copyright(c) 2000-2015 LOCKON CO.,LTD. All Rights Reserved. |
| * |
| * |
| * http://www.lockon.co.jp/ |
| * http://www.lockon.co.jp/ |
| * |
| * |
| * This program is free software; you can redistribute it and/or |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License |
| * modify it under the terms of the GNU General Public License |
| * as published by the Free Software Foundation; either version 2 |
| * as published by the Free Software Foundation; either version 2 |
| * of the License, or (at your option) any later version. |
| * of the License, or (at your option) any later version. |
| * |
| * |
| * This program is distributed in the hope that it will be useful, |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * GNU General Public License for more details. |
| * |
| * |
| * You should have received a copy of the GNU General Public License |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
| * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
| */ |
| */ |
| |
| |
| |
| |
| namespace Eccube\Controller\Admin\Setting\Shop; |
| namespace Eccube\Controller\Admin\Setting\Shop; |
| |
| |
| use Eccube\Application; |
| use Eccube\Application; |
| use Eccube\Common\Constant; |
| use Eccube\Common\Constant; |
| use Eccube\Controller\AbstractController; |
| use Eccube\Controller\AbstractController; |
| use Eccube\Event\EccubeEvents; |
| use Eccube\Event\EccubeEvents; |
| use Eccube\Event\EventArgs; |
| use Eccube\Event\EventArgs; |
| use Symfony\Component\Filesystem\Filesystem; |
| use Symfony\Component\Filesystem\Filesystem; |
| use Symfony\Component\HttpFoundation\Request; |
| use Symfony\Component\HttpFoundation\Request; |
| . | |
| use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; |
| |
| use Symfony\Component\HttpKernel\Exception\UnsupportedMediaTypeHttpException; |
| |
| |
| class PaymentController extends AbstractController |
| class PaymentController extends AbstractController |
| { |
| { |
| public function index(Application $app, Request $request) |
| public function index(Application $app, Request $request) |
| { |
| { |
| $Payments = $app['eccube.repository.payment'] |
| $Payments = $app['eccube.repository.payment'] |
| ->findBy( |
| ->findBy( |
| array('del_flg' => 0), |
| array('del_flg' => 0), |
| array('rank' => 'DESC') |
| array('rank' => 'DESC') |
| ); |
| ); |
| |
| |
| $event = new EventArgs( |
| $event = new EventArgs( |
| array( |
| array( |
| 'Payments' => $Payments, |
| 'Payments' => $Payments, |
| ), |
| ), |
| $request |
| $request |
| ); |
| ); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_INDEX_COMPLETE, $event); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_INDEX_COMPLETE, $event); |
| |
| |
| return $app->render('Setting/Shop/payment.twig', array( |
| return $app->render('Setting/Shop/payment.twig', array( |
| 'Payments' => $Payments, |
| 'Payments' => $Payments, |
| )); |
| )); |
| } |
| } |
| |
| |
| public function edit(Application $app, Request $request, $id = null) |
| public function edit(Application $app, Request $request, $id = null) |
| { |
| { |
| $Payment = $app['eccube.repository.payment'] |
| $Payment = $app['eccube.repository.payment'] |
| ->findOrCreate($id); |
| ->findOrCreate($id); |
| |
| |
| $builder = $app['form.factory'] |
| $builder = $app['form.factory'] |
| ->createBuilder('payment_register'); |
| ->createBuilder('payment_register'); |
| |
| |
| $event = new EventArgs( |
| $event = new EventArgs( |
| array( |
| array( |
| 'builder' => $builder, |
| 'builder' => $builder, |
| 'Payment' => $Payment, |
| 'Payment' => $Payment, |
| ), |
| ), |
| $request |
| $request |
| ); |
| ); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_EDIT_INITIALIZE, $event); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_EDIT_INITIALIZE, $event); |
| |
| |
| $form = $builder->getForm(); |
| $form = $builder->getForm(); |
| |
| |
| $form->setData($Payment); |
| $form->setData($Payment); |
| |
| |
| // 登録ボタン押下 |
| // 登録ボタン押下 |
| if ('POST' === $app['request']->getMethod()) { |
| if ('POST' === $app['request']->getMethod()) { |
| $form->handleRequest($app['request']); |
| $form->handleRequest($app['request']); |
| |
| |
| if ($form->isValid()) { |
| if ($form->isValid()) { |
| $PaymentData = $form->getData(); |
| $PaymentData = $form->getData(); |
| |
| |
| // 手数料を設定できない場合には、手数料を0にする |
| // 手数料を設定できない場合には、手数料を0にする |
| if ($PaymentData->getChargeFlg() == 2) { |
| if ($PaymentData->getChargeFlg() == 2) { |
| $PaymentData->setCharge(0); |
| $PaymentData->setCharge(0); |
| } |
| } |
| |
| |
| // ファイルアップロード |
| // ファイルアップロード |
| $file = $form['payment_image']->getData(); |
| $file = $form['payment_image']->getData(); |
| $fs = new Filesystem(); |
| $fs = new Filesystem(); |
| if ($file && $fs->exists($app['config']['image_temp_realdir'] . '/' . $file)) { |
| if ($file && $fs->exists($app['config']['image_temp_realdir'] . '/' . $file)) { |
| $fs->rename( |
| $fs->rename( |
| $app['config']['image_temp_realdir'] . '/' . $file, |
| $app['config']['image_temp_realdir'] . '/' . $file, |
| $app['config']['image_save_realdir'] . '/' . $file |
| $app['config']['image_save_realdir'] . '/' . $file |
| ); |
| ); |
| } |
| } |
| |
| |
| $app['orm.em']->persist($PaymentData); |
| $app['orm.em']->persist($PaymentData); |
| |
| |
| $app['orm.em']->flush(); |
| $app['orm.em']->flush(); |
| |
| |
| $event = new EventArgs( |
| $event = new EventArgs( |
| array( |
| array( |
| 'form' => $form, |
| 'form' => $form, |
| 'Payment' => $Payment, |
| 'Payment' => $Payment, |
| ), |
| ), |
| $request |
| $request |
| ); |
| ); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_EDIT_COMPLETE, $event); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_EDIT_COMPLETE, $event); |
| |
| |
| $app->addSuccess('admin.register.complete', 'admin'); |
| $app->addSuccess('admin.register.complete', 'admin'); |
| |
| |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| } |
| } |
| } |
| } |
| |
| |
| return $app->render('Setting/Shop/payment_edit.twig', array( |
| return $app->render('Setting/Shop/payment_edit.twig', array( |
| 'form' => $form->createView(), |
| 'form' => $form->createView(), |
| 'payment_id' => $id, |
| 'payment_id' => $id, |
| 'Payment' => $Payment, |
| 'Payment' => $Payment, |
| )); |
| )); |
| } |
| } |
| |
| |
| public function imageAdd(Application $app, Request $request) |
| public function imageAdd(Application $app, Request $request) |
| { |
| { |
| . | |
| if (!$request->isXmlHttpRequest()) { |
| |
| throw new BadRequestHttpException(); |
| |
| } |
| |
| |
| $images = $request->files->get('payment_register'); |
| $images = $request->files->get('payment_register'); |
| $filename = null; |
| $filename = null; |
| if (isset($images['payment_image_file'])) { |
| if (isset($images['payment_image_file'])) { |
| $image = $images['payment_image_file']; |
| $image = $images['payment_image_file']; |
| . | |
| |
| |
| //ファイルフォーマット検証 |
| |
| $mimeType = $image->getMimeType(); |
| |
| if (0 !== strpos($mimeType, 'image')) { |
| |
| throw new UnsupportedMediaTypeHttpException(); |
| |
| } |
| |
| |
| $extension = $image->guessExtension(); |
| $extension = $image->guessExtension(); |
| $filename = date('mdHis') . uniqid('_') . '.' . $extension; |
| $filename = date('mdHis') . uniqid('_') . '.' . $extension; |
| $image->move($app['config']['image_temp_realdir'], $filename); |
| $image->move($app['config']['image_temp_realdir'], $filename); |
| } |
| } |
| $event = new EventArgs( |
| $event = new EventArgs( |
| array( |
| array( |
| 'images' => $images, |
| 'images' => $images, |
| 'filename' => $filename, |
| 'filename' => $filename, |
| ), |
| ), |
| $request |
| $request |
| ); |
| ); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_IMAGE_ADD_COMPLETE, $event); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_IMAGE_ADD_COMPLETE, $event); |
| $filename = $event->getArgument('filename'); |
| $filename = $event->getArgument('filename'); |
| |
| |
| return $app->json(array('filename' => $filename), 200); |
| return $app->json(array('filename' => $filename), 200); |
| } |
| } |
| |
| |
| public function delete(Application $app, Request $request, $id) |
| public function delete(Application $app, Request $request, $id) |
| { |
| { |
| $this->isTokenValid($app); |
| $this->isTokenValid($app); |
| |
| |
| $Payment = $app['eccube.repository.payment']->find($id); |
| $Payment = $app['eccube.repository.payment']->find($id); |
| if (!$Payment) { |
| if (!$Payment) { |
| $app->deleteMessage(); |
| $app->deleteMessage(); |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| } |
| } |
| |
| |
| $Payment |
| $Payment |
| ->setDelFlg(Constant::ENABLED) |
| ->setDelFlg(Constant::ENABLED) |
| ->setRank(0); |
| ->setRank(0); |
| $app['orm.em']->persist($Payment); |
| $app['orm.em']->persist($Payment); |
| |
| |
| $rank = 1; |
| $rank = 1; |
| $Payments = $app['eccube.repository.payment']->findBy(array('del_flg' => Constant::DISABLED), array('rank' => 'ASC')); |
| $Payments = $app['eccube.repository.payment']->findBy(array('del_flg' => Constant::DISABLED), array('rank' => 'ASC')); |
| foreach ($Payments as $Payment) { |
| foreach ($Payments as $Payment) { |
| if ($Payment->getId() != $id) { |
| if ($Payment->getId() != $id) { |
| $Payment->setRank($rank); |
| $Payment->setRank($rank); |
| $rank ++; |
| $rank ++; |
| } |
| } |
| } |
| } |
| |
| |
| $app['orm.em']->flush(); |
| $app['orm.em']->flush(); |
| |
| |
| $event = new EventArgs( |
| $event = new EventArgs( |
| array( |
| array( |
| 'Payment' => $Payment, |
| 'Payment' => $Payment, |
| ), |
| ), |
| $request |
| $request |
| ); |
| ); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_DELETE_COMPLETE, $event); |
| $app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_SETTING_SHOP_PAYMENT_DELETE_COMPLETE, $event); |
| |
| |
| $app->addSuccess('admin.delete.complete', 'admin') ; |
| $app->addSuccess('admin.delete.complete', 'admin') ; |
| |
| |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| } |
| } |
| |
| |
| public function up(Application $app, $id) |
| public function up(Application $app, $id) |
| { |
| { |
| $this->isTokenValid($app); |
| $this->isTokenValid($app); |
| |
| |
| $repo = $app['orm.em']->getRepository('Eccube\Entity\Payment'); |
| $repo = $app['orm.em']->getRepository('Eccube\Entity\Payment'); |
| |
| |
| $current = $repo->find($id); |
| $current = $repo->find($id); |
| $currentRank = $current->getRank(); |
| $currentRank = $current->getRank(); |
| |
| |
| $targetRank = $currentRank + 1; |
| $targetRank = $currentRank + 1; |
| $target = $repo->findOneBy(array('rank' => $targetRank)); |
| $target = $repo->findOneBy(array('rank' => $targetRank)); |
| |
| |
| $app['orm.em']->persist($target->setRank($currentRank)); |
| $app['orm.em']->persist($target->setRank($currentRank)); |
| $app['orm.em']->persist($current->setRank($targetRank)); |
| $app['orm.em']->persist($current->setRank($targetRank)); |
| $app['orm.em']->flush(); |
| $app['orm.em']->flush(); |
| |
| |
| $app->addSuccess('admin.rank.move.complete', 'admin'); |
| $app->addSuccess('admin.rank.move.complete', 'admin'); |
| |
| |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| } |
| } |
| |
| |
| public function down(Application $app, $id) |
| public function down(Application $app, $id) |
| { |
| { |
| $this->isTokenValid($app); |
| $this->isTokenValid($app); |
| |
| |
| $repo = $app['orm.em']->getRepository('Eccube\Entity\Payment'); |
| $repo = $app['orm.em']->getRepository('Eccube\Entity\Payment'); |
| |
| |
| $current = $repo->find($id); |
| $current = $repo->find($id); |
| $currentRank = $current->getRank(); |
| $currentRank = $current->getRank(); |
| |
| |
| $targetRank = $currentRank - 1; |
| $targetRank = $currentRank - 1; |
| $target = $repo->findOneBy(array('rank' => $targetRank)); |
| $target = $repo->findOneBy(array('rank' => $targetRank)); |
| |
| |
| $app['orm.em']->persist($target->setRank($currentRank)); |
| $app['orm.em']->persist($target->setRank($currentRank)); |
| $app['orm.em']->persist($current->setRank($targetRank)); |
| $app['orm.em']->persist($current->setRank($targetRank)); |
| $app['orm.em']->flush(); |
| $app['orm.em']->flush(); |
| |
| |
| $app->addSuccess('admin.rank.move.complete', 'admin'); |
| $app->addSuccess('admin.rank.move.complete', 'admin'); |
| |
| |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| return $app->redirect($app->url('admin_setting_shop_payment')); |
| } |
| } |
| } |
| } |
| |
| |