public/plugin/buycourses/src/service_process.php
<?php
/* For license terms, see /license.txt */
use Chamilo\CoreBundle\Entity\Session;
use Chamilo\CourseBundle\Entity\CLp;
use Chamilo\UserBundle\Entity\User;
/**
* Process payments for the Buy Courses plugin.
*/
$cidReset = true;
require_once '../config.php';
if (!isset($_REQUEST['t'], $_REQUEST['i'])) {
header('Location: '.api_get_path(WEB_PLUGIN_PATH).'buycourses/src/service_catalog.php');
exit;
}
$currentUserId = api_get_user_id();
$serviceId = (int) $_REQUEST['i'];
$type = (int) $_REQUEST['t'];
if (empty($currentUserId)) {
api_not_allowed(true);
}
$htmlHeadXtra[] = '<link rel="stylesheet" type="text/css" href="'.api_get_path(
WEB_PLUGIN_PATH
).'buycourses/resources/css/style.css"/>';
$em = Database::getManager();
$plugin = BuyCoursesPlugin::create();
$includeServices = $plugin->get('include_services');
$paypalEnabled = 'true' === $plugin->get('paypal_enable');
$transferEnabled = 'true' === $plugin->get('transfer_enable');
$culqiEnabled = 'true' === $plugin->get('culqi_enable');
$additionalQueryString = '';
if ('true' !== $includeServices) {
api_not_allowed(true);
}
$typeUser = BuyCoursesPlugin::SERVICE_TYPE_USER === $type;
$typeCourse = BuyCoursesPlugin::SERVICE_TYPE_COURSE === $type;
$typeSession = BuyCoursesPlugin::SERVICE_TYPE_SESSION === $type;
$typeFinalLp = BuyCoursesPlugin::SERVICE_TYPE_LP_FINAL_ITEM === $type;
$queryString = 'i='.$serviceId.'&t='.$type.$additionalQueryString;
$serviceInfo = $plugin->getService($serviceId);
$userInfo = api_get_user_info($currentUserId);
$form = new FormValidator('confirm_sale');
$paymentTypesOptions = $plugin->getPaymentTypes();
if (!$paypalEnabled) {
unset($paymentTypesOptions[BuyCoursesPlugin::PAYMENT_TYPE_PAYPAL]);
}
if (!$transferEnabled) {
unset($paymentTypesOptions[BuyCoursesPlugin::PAYMENT_TYPE_TRANSFER]);
}
if (!$culqiEnabled) {
unset($paymentTypesOptions[BuyCoursesPlugin::PAYMENT_TYPE_CULQI]);
}
$form->addHtml(
Display::return_message(
$plugin->get_lang('PleaseSelectThePaymentMethodBeforeConfirmYourOrder'),
'info'
)
);
$form->addRadio('payment_type', null, $paymentTypesOptions);
$infoRequired = false;
if ($typeUser || $typeCourse || $typeSession || $typeFinalLp) {
$infoRequired = true;
$form->addHtml(
Display::return_message(
$plugin->get_lang('PleaseSelectTheCorrectInfoToApplyTheService'),
'info'
)
);
}
$selectOptions = [
0 => get_lang('None'),
];
if ($typeUser) {
$users = UserManager::getRepository()->findAll();
$selectOptions[$userInfo['user_id']] = api_get_person_name(
$userInfo['firstname'],
$userInfo['lastname']
).' ('.get_lang('Myself').')';
if (!empty($users)) {
/** @var User $user */
foreach ($users as $user) {
if (intval($userInfo['user_id']) !== intval($user->getId())) {
$selectOptions[$user->getId()] = $user->getCompleteNameWithUsername();
}
}
}
$form->addSelect('info_select', get_lang('User'), $selectOptions);
} elseif ($typeCourse) {
$user = api_get_user_entity($currentUserId);
$courses = $user->getCourses();
$checker = false;
foreach ($courses as $course) {
$checker = true;
$selectOptions[$course->getCourse()->getId()] = $course->getCourse()->getTitle();
}
if (!$checker) {
$form->addHtml(
Display::return_message(
$plugin->get_lang('YouNeedToBeRegisteredInAtLeastOneCourse'),
'error'
)
);
}
$form->addSelect('info_select', get_lang('Course'), $selectOptions);
} elseif ($typeSession) {
$sessions = [];
$user = api_get_user_entity($currentUserId);
$userSubscriptions = $user->getSessionRelCourseRelUsers();
foreach ($userSubscriptions as $userSubscription) {
$sessions[$userSubscription->getSession()->getId()] = $userSubscription->getSession()->getTitle();
}
$sessionsAsGeneralCoach = $user->getSessionsAsGeneralCoach();
/** @var Session $sessionAsGeneralCoach */
foreach ($sessionsAsGeneralCoach as $sessionAsGeneralCoach) {
$sessions[$sessionAsGeneralCoach->getId()] = $sessionAsGeneralCoach->getTitle();
}
if (!$sessions) {
$form->addHtml(Display::return_message($plugin->get_lang('YouNeedToBeRegisteredInAtLeastOneSession'), 'error'));
} else {
$selectOptions = $sessions;
$form->addSelect('info_select', get_lang('Session'), $selectOptions);
}
} elseif ($typeFinalLp) {
// We need here to check the current user courses first
$user = api_get_user_entity($currentUserId);
$courses = $user->getCourses();
$courseLpList = [];
$sessionLpList = [];
$checker = false;
foreach ($courses as $course) {
// Now get all the courses lp's
$thisLpList = $em->getRepository('ChamiloCourseBundle:CLp')->findBy(['cId' => $course->getCourse()->getId()]);
foreach ($thisLpList as $lp) {
$courseLpList[$lp->getCId()] = $lp->getTitle().' ('.$course->getCourse()->getTitle().')';
}
}
// Here now checking the current user sessions
$sessions = $user->getSessionRelCourseRelUsers();
foreach ($sessions as $session) {
$thisLpList = $em
->getRepository(CLp::class)
->findBy(['sessionId' => $session->getSession()->getId()]);
// Here check all the lpItems
foreach ($thisLpList as $lp) {
$thisLpItems = $em->getRepository('ChamiloCourseBundle:CLpItem')->findBy(['lpId' => $lp->getId()]);
foreach ($thisLpItems as $item) {
//Now only we need the final item and return the current LP
if (TOOL_LP_FINAL_ITEM == $item->getItemType()) {
$checker = true;
$sessionLpList[$lp->getCId()] = $lp->getTitle().' ('.$session->getSession()->getTitle().')';
}
}
}
$thisLpList = $em->getRepository('ChamiloCourseBundle:CLp')->findBy(['cId' => $session->getCourse()->getId()]);
// Here check all the lpItems
foreach ($thisLpList as $lp) {
$thisLpItems = $em->getRepository('ChamiloCourseBundle:CLpItem')->findBy(['lpId' => $lp->getId()]);
foreach ($thisLpItems as $item) {
//Now only we need the final item and return the current LP
if (TOOL_LP_FINAL_ITEM == $item->getItemType()) {
$checker = true;
$sessionLpList[$lp->getCId()] = $lp->getTitle().' ('.$session->getSession()->getTitle().')';
}
}
}
}
$selectOptions = $selectOptions + $courseLpList + $sessionLpList;
if (!$checker) {
$form->addHtml(
Display::return_message(
$plugin->get_lang('YourCoursesNeedAtLeastOneLearningPath'),
'error'
)
);
}
$form->addSelect('info_select', get_lang('LearningPath'), $selectOptions);
}
$form->addHidden('t', intval($_GET['t']));
$form->addHidden('i', intval($_GET['i']));
$form->addButton('submit', $plugin->get_lang('ConfirmOrder'), 'check', 'success');
if ($form->validate()) {
$formValues = $form->getSubmitValues();
if (!isset($formValues['payment_type'])) {
Display::addFlash(
Display::return_message($plugin->get_lang('NeedToSelectPaymentType'), 'error', false)
);
header('Location:'.api_get_self().'?'.$queryString);
exit;
}
$infoSelected = [];
if ($infoRequired) {
if (isset($formValues['info_select'])) {
$infoSelected = $formValues['info_select'];
} else {
Display::addFlash(
Display::return_message($plugin->get_lang('AdditionalInfoRequired'), 'error', false)
);
header('Location:'.api_get_self().'?'.$queryString);
exit;
}
}
$serviceSaleId = $plugin->registerServiceSale(
$serviceId,
$formValues['payment_type'],
$infoSelected
);
if (false !== $serviceSaleId) {
$_SESSION['bc_service_sale_id'] = $serviceSaleId;
header('Location: '.api_get_path(WEB_PLUGIN_PATH).'buycourses/src/service_process_confirm.php');
}
exit;
}
// View
$templateName = $plugin->get_lang('PaymentMethods');
$interbreadcrumb[] = [
'url' => 'service_catalog.php',
'name' => $plugin->get_lang('ListOfServicesOnSale'),
];
$tpl = new Template($templateName);
$tpl->assign('buying_service', true);
$tpl->assign('service', $serviceInfo);
$tpl->assign('user', api_get_user_info());
$tpl->assign('form', $form->returnForm());
$content = $tpl->fetch('buycourses/view/service_process.tpl');
$tpl->assign('content', $content);
$tpl->display_one_col_template();