Skip to content

Commit

Permalink
feat (afup#950): mcrypt CBC replace by openssl
Browse files Browse the repository at this point in the history
  • Loading branch information
stakovicz committed Nov 19, 2023
1 parent de58252 commit b5e15c6
Show file tree
Hide file tree
Showing 5 changed files with 83 additions and 4 deletions.
1 change: 1 addition & 0 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
"ext-json": "*",
"ext-dom": "*",
"ext-libxml": "*",
"ext-openssl": "*",
"beberlei/assert": "^2.9",
"league/oauth2-github": "^0.2.1",
"symfony/symfony": "^3.4",
Expand Down
2 changes: 1 addition & 1 deletion htdocs/pages/administration/compta_facture.php
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
if ($action == 'lister') {
$ecritures = $comptaFact->obtenirFacture();
foreach ($ecritures as &$e) {
$e['link'] = urlencode(base64_encode(mcrypt_cbc(MCRYPT_TripleDES, 'PaiementFactureAFUP_AFUP', $e['id'], MCRYPT_ENCRYPT, '@PaiFact')));;
$e['link'] = urlencode(cryptFromId($e['id']));
}
$smarty->assign('ecritures', $ecritures);
} elseif ($action == 'telecharger_facture') {
Expand Down
2 changes: 1 addition & 1 deletion htdocs/pages/paiement/index.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@

$comptaFact = new Facture($bdd);

$ref = trim(mcrypt_cbc (MCRYPT_TripleDES, 'PaiementFactureAFUP_AFUP', base64_decode(str_replace(' ', '+', urldecode($_GET['ref']))), MCRYPT_DECRYPT, '@PaiFact'));
$ref = \Afup\Site\Utils\Utils::decryptFromRef(urldecode($_GET['ref']));

$facture = $comptaFact->obtenir($ref);
if ($facture) {
Expand Down
28 changes: 26 additions & 2 deletions sources/Afup/Utils/Utils.php
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,30 @@ public static function get_gravatar($email, $s = 80, $d = 'mm', $r = 'g', $img =
}
return $url;
}
}

?>
public static function cryptFromId($id)
{
return base64_encode(mcrypt_cbc(MCRYPT_TripleDES, 'PaiementFactureAFUP_AFUP', $id, MCRYPT_ENCRYPT, '@PaiFact'));

if (strlen($id) % 8) {
$id = str_pad($id, strlen($id) + 8 - strlen($id) % 8, "\0");
}

$key = 'PaiementFactureAFUP_AFUP';
$iv = '@PaiFact';

return base64_encode(openssl_encrypt($id, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA | OPENSSL_ZERO_PADDING, $iv));
}

public static function decryptFromRef($ref)
{
return trim(mcrypt_cbc(MCRYPT_TripleDES, 'PaiementFactureAFUP_AFUP', base64_decode(str_replace(' ', '+', $ref)), MCRYPT_DECRYPT, '@PaiFact'));

$ref = base64_decode(str_replace(' ', '+', $ref));

$key = 'PaiementFactureAFUP_AFUP';
$iv = '@PaiFact';

return trim(openssl_decrypt($ref, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA | OPENSSL_ZERO_PADDING, $iv));
}
}
54 changes: 54 additions & 0 deletions tests/units/Afup/Utils/Utils.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
<?php

namespace Afup\Site\Utils\tests\units;

use Afup\Site\Utils\Utils as UtilsToTest;

class Utils extends \atoum
{
protected function dataProvider()
{
return [
[
'decrypted' => 1,
'encrypted' => '03bITNI5Ono=',
],
[
'decrypted' => '1',
'encrypted' => '03bITNI5Ono=',
],
[
'decrypted' => '12345',
'encrypted' => 'EIx0Y/wJQ+I=',
],
[
'decrypted' => 'abcdef',
'encrypted' => 'UvM1BUAJ5jQ=',
],
[
'decrypted' => 'L\'AFUP est trop mortelle !',
'encrypted' => '6MSKdnJmUMW7YrnxXDe/5mKySbAiO2C9ubfR3NcG/fc=',
],
];
}

/**
* @dataProvider dataProvider
*/
public function testCryptFromId($decrypted, $encrypted)
{
$this
->string(UtilsToTest::cryptFromId($decrypted))
->isEqualTo($encrypted);
}

/**
* @dataProvider dataProvider
*/
public function testDecryptFromRef($decrypted, $encrypted)
{
$this
->string(UtilsToTest::decryptFromRef($encrypted))
->isEqualTo($decrypted);
}
}

0 comments on commit b5e15c6

Please sign in to comment.