123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- <?php
- /* For license terms, see /license.txt */
- use Chamilo\CoreBundle\Entity\Course;
- use Chamilo\CoreBundle\Entity\Session;
- use Chamilo\PluginBundle\Entity\ImsLti\ImsLtiTool;
- use Chamilo\UserBundle\Entity\User;
- require_once __DIR__.'/../../main/inc/global.inc.php';
- api_protect_course_script(false);
- api_block_anonymous_users(false);
- $em = Database::getManager();
- /** @var ImsLtiTool $tool */
- $tool = isset($_GET['id'])
- ? $em->find('ChamiloPluginBundle:ImsLti\ImsLtiTool', (int) $_GET['id'])
- : null;
- if (!$tool) {
- api_not_allowed(true);
- }
- /** @var ImsLtiPlugin $imsLtiPlugin */
- $imsLtiPlugin = ImsLtiPlugin::create();
- /** @var Session $session */
- $session = $em->find('ChamiloCoreBundle:Session', api_get_session_id());
- /** @var Course $course */
- $course = $em->find('ChamiloCoreBundle:Course', api_get_course_int_id());
- /** @var User $user */
- $user = $em->find('ChamiloUserBundle:User', api_get_user_id());
- $pluginPath = api_get_path(WEB_PLUGIN_PATH).'ims_lti/';
- $toolUserId = ImsLtiPlugin::generateToolUserId($user->getId());
- $platformDomain = str_replace(['https://', 'http://'], '', api_get_setting('InstitutionUrl'));
- $params = [];
- $params['lti_version'] = 'LTI-1p0';
- if ($tool->isActiveDeepLinking()) {
- $params['lti_message_type'] = 'ContentItemSelectionRequest';
- $params['content_item_return_url'] = $pluginPath.'item_return.php';
- $params['accept_media_types'] = '*/*';
- $params['accept_presentation_document_targets'] = 'iframe';
- //$params['accept_unsigned'];
- //$params['accept_multiple'];
- //$params['accept_copy_advice'];
- //$params['auto_create']';
- $params['title'] = $tool->getName();
- $params['text'] = $tool->getDescription();
- $params['data'] = 'tool:'.$tool->getId();
- } else {
- $params['lti_message_type'] = 'basic-lti-launch-request';
- $params['resource_link_id'] = $tool->getId();
- $params['resource_link_title'] = $tool->getName();
- $params['resource_link_description'] = $tool->getDescription();
- $toolEval = $tool->getGradebookEval();
- if (!empty($toolEval)) {
- $params['lis_result_sourcedid'] = json_encode(
- ['e' => $toolEval->getId(), 'u' => $user->getId(), 'l' => uniqid(), 'lt' => time()]
- );
- $params['lis_outcome_service_url'] = api_get_path(WEB_PATH).'lti/os';
- $params['lis_person_sourcedid'] = "$platformDomain:$toolUserId";
- $params['lis_course_section_sourcedid'] = "$platformDomain:".$course->getId();
- if ($session) {
- $params['lis_course_section_sourcedid'] .= ':'.$session->getId();
- }
- }
- }
- $params['user_id'] = $toolUserId;
- if ($tool->isSharingPicture()) {
- $params['user_image'] = UserManager::getUserPicture($user->getId());
- }
- $params['roles'] = ImsLtiPlugin::getUserRoles($user);
- if ($tool->isSharingName()) {
- $params['lis_person_name_given'] = $user->getFirstname();
- $params['lis_person_name_family'] = $user->getLastname();
- $params['lis_person_name_full'] = $user->getFirstname().' '.$user->getLastname();
- }
- if ($tool->isSharingEmail()) {
- $params['lis_person_contact_email_primary'] = $user->getEmail();
- }
- if (DRH === $user->getStatus()) {
- $scopeMentor = ImsLtiPlugin::getRoleScopeMentor($user);
- if (!empty($scopeMentor)) {
- $params['role_scope_mentor'] = $scopeMentor;
- }
- }
- $params['context_id'] = $course->getId();
- $params['context_type'] = 'CourseSection';
- $params['context_label'] = $course->getCode();
- $params['context_title'] = $course->getTitle();
- $params['launch_presentation_locale'] = api_get_language_isocode();
- $params['launch_presentation_document_target'] = 'iframe';
- $params['tool_consumer_info_product_family_code'] = 'Chamilo LMS';
- $params['tool_consumer_info_version'] = api_get_version();
- $params['tool_consumer_instance_guid'] = $platformDomain;
- $params['tool_consumer_instance_name'] = api_get_setting('siteName');
- $params['tool_consumer_instance_url'] = api_get_path(WEB_PATH);
- $params['tool_consumer_instance_contact_email'] = api_get_setting('emailAdministrator');
- $params['oauth_callback'] = 'about:blank';
- $customParams = $tool->parseCustomParams();
- $imsLtiPlugin->trimParams($customParams);
- $substitutables = ImsLti::getSubstitutableParams($user, $course, $session);
- $variables = array_keys($substitutables);
- foreach ($customParams as $customKey => $customValue) {
- if (in_array($customValue, $variables)) {
- $val = $substitutables[$customValue];
- if (is_array($val)) {
- $val = current($val);
- if (array_key_exists($val, $params)) {
- $customParams[$customKey] = $params[$val];
- continue;
- } else {
- $val = false;
- }
- }
- if (false === $val) {
- $customParams[$customKey] = $customValue;
- continue;
- }
- $customParams[$customKey] = $substitutables[$customValue];
- }
- }
- $params += $customParams;
- $imsLtiPlugin->trimParams($params);
- if (!empty($tool->getConsumerKey()) && !empty($tool->getSharedSecret())) {
- $consumer = new OAuthConsumer(
- $tool->getConsumerKey(),
- $tool->getSharedSecret(),
- null
- );
- $hmacMethod = new OAuthSignatureMethod_HMAC_SHA1();
- $request = OAuthRequest::from_consumer_and_token(
- $consumer,
- '',
- 'POST',
- $tool->getLaunchUrl(),
- $params
- );
- $request->sign_request($hmacMethod, $consumer, '');
- $params = $request->get_parameters();
- }
- $imsLtiPlugin->removeUrlParamsFromLaunchParams($tool, $params);
- ?>
- <!DOCTYPE html>
- <html>
- <head>
- <title>title</title>
- </head>
- <body>
- <form action="<?php echo $tool->getLaunchUrl() ?>" name="ltiLaunchForm" method="post"
- encType="application/x-www-form-urlencoded">
- <?php foreach ($params as $key => $value) { ?>
- <input type="hidden" name="<?php echo $key ?>" value="<?php echo htmlspecialchars($value) ?>">
- <?php } ?>
- </form>
- <script>document.ltiLaunchForm.submit();</script>
- </body>
- </html>
|