__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ 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/>.
namespace core;
use advanced_testcase;
/**
* Test encryption.
*
* @package core
* @copyright 2020 The Open University
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @covers \core\encryption
*/
final class encryption_test extends advanced_testcase {
/**
* Clear junk created by tests.
*/
protected function tearDown(): void {
global $CFG;
$keyfile = encryption::get_key_file(encryption::METHOD_OPENSSL);
if (file_exists($keyfile)) {
chmod($keyfile, 0700);
}
$keyfile = encryption::get_key_file(encryption::METHOD_SODIUM);
if (file_exists($keyfile)) {
chmod($keyfile, 0700);
}
remove_dir($CFG->dataroot . '/secret');
unset($CFG->nokeygeneration);
parent::tearDown();
}
protected function setUp(): void {
parent::setUp();
$this->tearDown();
require_once(__DIR__ . '/fixtures/testable_encryption.php');
}
/**
* Many of the tests work with both encryption methods.
*
* @return array[] Array of method options for test
*/
public static function encryption_method_provider(): array {
return [
'Sodium' => [encryption::METHOD_SODIUM],
];
}
/**
* Tests the create_keys and get_key functions.
*
* @param string $method Encryption method
* @dataProvider encryption_method_provider
*/
public function test_create_key(string $method): void {
encryption::create_key($method);
$key = testable_encryption::get_key($method);
$this->assertEquals(32, strlen($key));
$this->expectExceptionMessage('Key already exists');
encryption::create_key($method);
}
/**
* Test that we can create keys for legacy {@see encryption::METHOD_OPENSSL} content
*/
public function test_create_key_openssl(): void {
encryption::create_key(encryption::METHOD_OPENSSL);
$key = testable_encryption::get_key(encryption::METHOD_OPENSSL);
$this->assertEquals(32, strlen($key));
$this->expectExceptionMessage('Key already exists');
encryption::create_key(encryption::METHOD_OPENSSL);
}
/**
* Tests encryption and decryption with empty strings.
*/
public function test_encrypt_and_decrypt_empty(): void {
$this->assertEquals('', encryption::encrypt(''));
$this->assertEquals('', encryption::decrypt(''));
}
/**
* Tests encryption when the keys weren't created yet.
*
* @param string $method Encryption method
* @dataProvider encryption_method_provider
*/
public function test_encrypt_nokeys(string $method): void {
global $CFG;
// Prevent automatic generation of keys.
$CFG->nokeygeneration = true;
$this->expectExceptionMessage('Key not found');
encryption::encrypt('frogs', $method);
}
/**
* Test that attempting to encrypt with legacy {@see encryption::METHOD_OPENSSL} method falls back to Sodium
*/
public function test_encrypt_openssl(): void {
$encrypted = encryption::encrypt('Frogs', encryption::METHOD_OPENSSL);
$this->assertStringStartsWith(encryption::METHOD_SODIUM . ':', $encrypted);
$this->assertDebuggingCalledCount(1, ['Encryption using legacy OpenSSL is deprecated, reverting to Sodium']);
}
/**
* Tests decryption when the data has a different encryption method
*/
public function test_decrypt_wrongmethod(): void {
$this->expectExceptionMessage('Data does not match a supported encryption method');
encryption::decrypt('FAKE-CIPHER-METHOD:xx');
}
/**
* Tests decryption when not enough data is supplied to get the IV and some data.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_decrypt_tooshort(string $method): void {
$this->expectExceptionMessage('Insufficient data');
switch ($method) {
case encryption::METHOD_OPENSSL:
// It needs min 49 bytes (16 bytes IV + 32 bytes HMAC + 1 byte data).
$justtooshort = '0123456789abcdef0123456789abcdef0123456789abcdef';
break;
case encryption::METHOD_SODIUM:
// Sodium needs 25 bytes at least as far as our code is concerned (24 bytes IV + 1
// byte data); it splits out any authentication hashes itself.
$justtooshort = '0123456789abcdef01234567';
break;
}
encryption::decrypt($method . ':' .base64_encode($justtooshort));
}
/**
* Tests decryption when data is not valid base64.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_decrypt_notbase64(string $method): void {
$this->expectExceptionMessage('Invalid base64 data');
encryption::decrypt($method . ':' . chr(160));
}
/**
* Tests decryption when the keys weren't created yet.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_decrypt_nokeys(string $method): void {
global $CFG;
// Prevent automatic generation of keys.
$CFG->nokeygeneration = true;
$this->expectExceptionMessage('Key not found');
encryption::decrypt($method . ':' . base64_encode(
'0123456789abcdef0123456789abcdef0123456789abcdef0'));
}
/**
* Test that we can decrypt legacy {@see encryption::METHOD_OPENSSL} content
*/
public function test_decrypt_openssl(): void {
$key = testable_encryption::get_key(encryption::METHOD_OPENSSL);
// Construct encrypted string using openssl method/cipher.
$iv = random_bytes(openssl_cipher_iv_length(encryption::OPENSSL_CIPHER));
$encrypted = @openssl_encrypt('Frogs', encryption::OPENSSL_CIPHER, $key, OPENSSL_RAW_DATA, $iv);
$hmac = hash_hmac('sha256', $iv . $encrypted, $key, true);
$decrypted = encryption::decrypt(encryption::METHOD_OPENSSL . ':' . base64_encode($iv . $encrypted . $hmac));
$this->assertEquals('Frogs', $decrypted);
$this->assertDebuggingCalledCount(1, ['Decryption using legacy OpenSSL is deprecated, please upgrade to Sodium']);
}
/**
* Test automatic generation of keys when needed.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_auto_key_generation(string $method): void {
// Allow automatic generation (default).
$encrypted = encryption::encrypt('frogs', $method);
$this->assertEquals('frogs', encryption::decrypt($encrypted));
}
/**
* Checks that invalid key causes failures.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_invalid_key(string $method): void {
global $CFG;
// Set the key to something bogus.
$folder = $CFG->dataroot . '/secret/key';
check_dir_exists($folder);
file_put_contents(encryption::get_key_file($method), 'silly');
switch ($method) {
case encryption::METHOD_SODIUM:
$this->expectExceptionMessageMatches('/(should|must) be SODIUM_CRYPTO_SECRETBOX_KEYBYTES bytes/');
break;
case encryption::METHOD_OPENSSL:
$this->expectExceptionMessage('Invalid key');
break;
}
encryption::encrypt('frogs', $method);
}
/**
* Checks that modified data causes failures.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_modified_data(string $method): void {
$encrypted = encryption::encrypt('frogs', $method);
$mainbit = base64_decode(substr($encrypted, strlen($method) + 1));
$mainbit = substr($mainbit, 0, 16) . 'X' . substr($mainbit, 16);
$encrypted = $method . ':' . base64_encode($mainbit);
$this->expectExceptionMessage('Integrity check failed');
encryption::decrypt($encrypted);
}
/**
* Tests encryption and decryption for real.
*
* @dataProvider encryption_method_provider
* @param string $method Encryption method
*/
public function test_encrypt_and_decrypt_realdata(string $method): void {
// Encrypt short string.
$encrypted = encryption::encrypt('frogs', $method);
$this->assertNotEquals('frogs', $encrypted);
$this->assertEquals('frogs', encryption::decrypt($encrypted));
// Encrypt really long string (1 MB).
$long = str_repeat('X', 1024 * 1024);
$this->assertEquals($long, encryption::decrypt(encryption::encrypt($long, $method)));
}
}
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| analytics | Folder | 0777 |
|
|
| behat | Folder | 0777 |
|
|
| classes | Folder | 0777 |
|
|
| content | Folder | 0777 |
|
|
| context | Folder | 0777 |
|
|
| db | Folder | 0777 |
|
|
| event | Folder | 0777 |
|
|
| external | Folder | 0777 |
|
|
| fixtures | Folder | 0777 |
|
|
| hook | Folder | 0777 |
|
|
| hub | Folder | 0777 |
|
|
| lock | Folder | 0777 |
|
|
| moodlenet | Folder | 0777 |
|
|
| navigation | Folder | 0777 |
|
|
| oauth2 | Folder | 0777 |
|
|
| other | Folder | 0777 |
|
|
| output | Folder | 0777 |
|
|
| performance | Folder | 0777 |
|
|
| plugininfo | Folder | 0777 |
|
|
| privacy | Folder | 0777 |
|
|
| route | Folder | 0777 |
|
|
| router | Folder | 0777 |
|
|
| session | Folder | 0777 |
|
|
| task | Folder | 0777 |
|
|
| accesslib_has_capability_test.php | File | 29.76 KB | 0777 |
|
| accesslib_test.php | File | 245.63 KB | 0777 |
|
| adminlib_test.php | File | 7.42 KB | 0777 |
|
| admintree_test.php | File | 18.08 KB | 0777 |
|
| ajaxlib_test.php | File | 4.45 KB | 0777 |
|
| analysers_test.php | File | 12.71 KB | 0777 |
|
| antivirus_test.php | File | 11.98 KB | 0777 |
|
| attribute_helper_test.php | File | 8.41 KB | 0777 |
|
| authlib_test.php | File | 22.97 KB | 0777 |
|
| behat_lib_test.php | File | 3.3 KB | 0777 |
|
| blocklib_test.php | File | 36.31 KB | 0777 |
|
| check_test.php | File | 2.31 KB | 0777 |
|
| client_test.php | File | 4.32 KB | 0777 |
|
| collator_test.php | File | 12.1 KB | 0777 |
|
| completionlib_test.php | File | 92.46 KB | 0777 |
|
| component_test.php | File | 49.28 KB | 0777 |
|
| componentlib_test.php | File | 6.93 KB | 0777 |
|
| configonlylib_test.php | File | 8.95 KB | 0777 |
|
| content_test.php | File | 4.79 KB | 0777 |
|
| context_block_test.php | File | 4.17 KB | 0777 |
|
| context_helper_test.php | File | 22.28 KB | 0777 |
|
| context_test.php | File | 3.42 KB | 0777 |
|
| core_media_player_native_test.php | File | 6.44 KB | 0777 |
|
| core_renderer_template_exploit_test.php | File | 16.54 KB | 0777 |
|
| core_renderer_test.php | File | 7.57 KB | 0777 |
|
| core_userfeedback_test.php | File | 2.3 KB | 0777 |
|
| coverage.php | File | 3.27 KB | 0777 |
|
| cron_test.php | File | 6.82 KB | 0777 |
|
| csvclass_test.php | File | 5.66 KB | 0777 |
|
| curl_security_helper_test.php | File | 14.88 KB | 0777 |
|
| customcontext_test.php | File | 4.67 KB | 0777 |
|
| dataformat_test.php | File | 4.18 KB | 0777 |
|
| datalib_test.php | File | 48.97 KB | 0777 |
|
| datalib_update_with_unique_index_test.php | File | 6.12 KB | 0777 |
|
| date_legacy_test.php | File | 13.67 KB | 0777 |
|
| date_test.php | File | 30.4 KB | 0777 |
|
| deprecation_test.php | File | 15.78 KB | 0777 |
|
| di_test.php | File | 5.33 KB | 0777 |
|
| editorlib_test.php | File | 1.96 KB | 0777 |
|
| emoticon_manager_test.php | File | 4.2 KB | 0777 |
|
| encryption_test.php | File | 9.48 KB | 0777 |
|
| environment_test.php | File | 9.12 KB | 0777 |
|
| exporter_test.php | File | 16.83 KB | 0777 |
|
| externallib_test.php | File | 2.03 KB | 0777 |
|
| filelib_test.php | File | 83.89 KB | 0777 |
|
| filestorage_zip_archive_test.php | File | 2.54 KB | 0777 |
|
| filetypes_test.php | File | 10.09 KB | 0777 |
|
| filter_manager_test.php | File | 3.33 KB | 0777 |
|
| filterlib_test.php | File | 37.09 KB | 0777 |
|
| formatting_test.php | File | 26.09 KB | 0777 |
|
| formslib_test.php | File | 40.1 KB | 0777 |
|
| gdlib_test.php | File | 5.73 KB | 0777 |
|
| googlelib_test.php | File | 1.62 KB | 0777 |
|
| gradelib_test.php | File | 12.01 KB | 0777 |
|
| grades_external_test.php | File | 11.22 KB | 0777 |
|
| grading_external_test.php | File | 26.55 KB | 0777 |
|
| graphlib_test.php | File | 7.14 KB | 0777 |
|
| grouplib_test.php | File | 110.79 KB | 0777 |
|
| h5p_clean_orphaned_records_task_test.php | File | 3.17 KB | 0777 |
|
| html2text_test.php | File | 8.82 KB | 0777 |
|
| htmlpurifier_test.php | File | 23.11 KB | 0777 |
|
| http_client_test.php | File | 14.67 KB | 0777 |
|
| ip_utils_test.php | File | 19.55 KB | 0777 |
|
| jquery_test.php | File | 1.59 KB | 0777 |
|
| ldaplib_test.php | File | 17.77 KB | 0777 |
|
| licenselib_test.php | File | 11.84 KB | 0777 |
|
| locale_test.php | File | 4.96 KB | 0777 |
|
| lock_config_test.php | File | 3.48 KB | 0777 |
|
| lock_test.php | File | 5.34 KB | 0777 |
|
| markdown_test.php | File | 2.27 KB | 0777 |
|
| mathslib_test.php | File | 13.51 KB | 0777 |
|
| medialib_test.php | File | 19.68 KB | 0777 |
|
| message_test.php | File | 16.43 KB | 0777 |
|
| messagelib_test.php | File | 56.44 KB | 0777 |
|
| minify_test.php | File | 3.15 KB | 0777 |
|
| modinfolib_test.php | File | 99.71 KB | 0777 |
|
| moodle_page_test.php | File | 34.62 KB | 0777 |
|
| moodlelib_current_language_test.php | File | 7.68 KB | 0777 |
|
| moodlelib_partial_test.php | File | 4.48 KB | 0777 |
|
| moodlelib_test.php | File | 239.56 KB | 0777 |
|
| myprofilelib_test.php | File | 12.2 KB | 0777 |
|
| navigationlib_test.php | File | 32.56 KB | 0777 |
|
| notification_test.php | File | 4.37 KB | 0777 |
|
| oauth2_test.php | File | 23.16 KB | 0777 |
|
| outputcomponents_test.php | File | 34.31 KB | 0777 |
|
| outputfactories_test.php | File | 6.83 KB | 0777 |
|
| outputrenderers_test.php | File | 1.63 KB | 0777 |
|
| outputrequirementslib_test.php | File | 15.72 KB | 0777 |
|
| param_test.php | File | 4.11 KB | 0777 |
|
| pdflib_test.php | File | 3.21 KB | 0777 |
|
| persistent_test.php | File | 30.68 KB | 0777 |
|
| phpxmlrpc_test.php | File | 2.05 KB | 0777 |
|
| plugin_manager_test.php | File | 31.47 KB | 0777 |
|
| portfoliolib_test.php | File | 8.41 KB | 0777 |
|
| progress_display_test.php | File | 3.76 KB | 0777 |
|
| progress_test.php | File | 14.53 KB | 0777 |
|
| qrcode_test.php | File | 1.69 KB | 0777 |
|
| questionlib_test.php | File | 108.63 KB | 0777 |
|
| regex_test.php | File | 1.56 KB | 0777 |
|
| report_helper_test.php | File | 7 KB | 0777 |
|
| requirejs_test.php | File | 2.23 KB | 0777 |
|
| router_test.php | File | 3.85 KB | 0777 |
|
| rsslib_test.php | File | 7.41 KB | 0777 |
|
| rtlcss_test.php | File | 57.07 KB | 0777 |
|
| sample_questions.ser | File | 141.76 KB | 0777 |
|
| sample_questions.xml | File | 102.62 KB | 0777 |
|
| sample_questions_with_old_image_tag.ser | File | 4.85 KB | 0777 |
|
| sample_questions_with_old_image_tag.xml | File | 4.08 KB | 0777 |
|
| sample_questions_wrong.xml | File | 102.57 KB | 0777 |
|
| scss_test.php | File | 4.31 KB | 0777 |
|
| session_redis_cluster_test.php | File | 4.17 KB | 0777 |
|
| sessionlib_test.php | File | 12.37 KB | 0777 |
|
| setuplib_test.php | File | 20.21 KB | 0777 |
|
| statslib_test.php | File | 26.82 KB | 0777 |
|
| stored_progress_bar_test.php | File | 7.17 KB | 0777 |
|
| string_manager_standard_test.php | File | 10.23 KB | 0777 |
|
| system_clock_test.php | File | 2.42 KB | 0777 |
|
| text_test.php | File | 26.68 KB | 0777 |
|
| theme_config_test.php | File | 7.25 KB | 0777 |
|
| update_api_test.php | File | 6.65 KB | 0777 |
|
| update_checker_test.php | File | 10.91 KB | 0777 |
|
| update_code_manager_test.php | File | 9.12 KB | 0777 |
|
| update_validator_test.php | File | 18.32 KB | 0777 |
|
| upgrade_util_test.php | File | 5.36 KB | 0777 |
|
| upgradelib_test.php | File | 75.43 KB | 0777 |
|
| url_test.php | File | 25.48 KB | 0777 |
|
| user_menu_test.php | File | 3.83 KB | 0777 |
|
| user_test.php | File | 42.3 KB | 0777 |
|
| useragent_test.php | File | 67.06 KB | 0777 |
|
| weblib_format_text_test.php | File | 14.21 KB | 0777 |
|
| weblib_test.php | File | 42.12 KB | 0777 |
|
| xhprof_test.php | File | 10.05 KB | 0777 |
|
| xmlize_test.php | File | 2.57 KB | 0777 |
|
| xsendfilelib_test.php | File | 5 KB | 0777 |
|