mirror of
https://github.com/ae-utbm/sith.git
synced 2024-11-25 02:24:26 +00:00
125 lines
4.9 KiB
PHP
125 lines
4.9 KiB
PHP
|
<?php
|
|||
|
|
|||
|
// --------------- VARIABLES A MODIFIER ---------------
|
|||
|
|
|||
|
// Ennonciation de variables
|
|||
|
$pbx_site = '1520411'; //variable de test 1999888
|
|||
|
$pbx_rang = '001'; //variable de test 32
|
|||
|
$pbx_identifiant = '650995411'; //variable de test 3
|
|||
|
$pbx_cmd = 'CMD_1'; //variable de test cmd_test1
|
|||
|
$pbx_porteur = 'skia@git.an'; //variable de test test@test.fr
|
|||
|
$pbx_total = '510'; //variable de test 100
|
|||
|
// Suppression des points ou virgules dans le montant
|
|||
|
$pbx_total = str_replace(",", "", $pbx_total);
|
|||
|
$pbx_total = str_replace(".", "", $pbx_total);
|
|||
|
|
|||
|
// Param<61>trage des urls de redirection apr<70>s paiement
|
|||
|
$pbx_effectue = 'http://www.votre-site.extention/page-de-confirmation';
|
|||
|
$pbx_annule = 'http://www.votre-site.extention/page-d-annulation';
|
|||
|
$pbx_refuse = 'http://www.votre-site.extention/page-de-refus';
|
|||
|
// Param<61>trage de l'url de retour back office site
|
|||
|
$pbx_repondre_a = 'http://www.votre-site.extention/page-de-back-office-site';
|
|||
|
// Param<61>trage du retour back office site
|
|||
|
$pbx_retour = 'Amount:M;BasketID:R;Auto:A;Error:E;Sig:K';
|
|||
|
|
|||
|
// Connection <20> la base de donn<6E>es
|
|||
|
// mysql_connect...
|
|||
|
// On r<>cup<75>re la cl<63> secr<63>te HMAC (stock<63>e dans une base de donn<6E>es par exemple) et que l<>on renseigne dans la variable $keyTest;
|
|||
|
//$keyTest = '0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF';
|
|||
|
$keyTest = '2d21b1f0d5b64bce056b342b5259db312dfc0176dcafb33eb804b6aaaa3acc07320742954ef3b052f36942b09f86ccb9d24c8814586c1a0d24319fd8985c19e5';
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// --------------- TESTS DE DISPONIBILITE DES SERVEURS ---------------
|
|||
|
|
|||
|
/*
|
|||
|
$serveurs = array('tpeweb.paybox.com', //serveur primaire
|
|||
|
'tpeweb1.paybox.com'); //serveur secondaire
|
|||
|
$serveurOK = "";
|
|||
|
//phpinfo(); <== voir paybox
|
|||
|
foreach($serveurs as $serveur){
|
|||
|
$doc = new DOMDocument();
|
|||
|
$doc->loadHTMLFile('https://'.$serveur.'/load.html');
|
|||
|
$server_status = "";
|
|||
|
$element = $doc->getElementById('server_status');
|
|||
|
if($element){
|
|||
|
$server_status = $element->textContent;}
|
|||
|
if($server_status == "OK"){
|
|||
|
// Le serveur est pr<70>t et les services op<6F>rationnels
|
|||
|
$serveurOK = $serveur;
|
|||
|
break;}
|
|||
|
// else : La machine est disponible mais les services ne le sont pas.
|
|||
|
}
|
|||
|
//curl_close($ch); <== voir paybox
|
|||
|
if(!$serveurOK){
|
|||
|
die("Erreur : Aucun serveur n'a <20>t<EFBFBD> trouv<75>");}
|
|||
|
// Activation de l'univers de pr<70>production
|
|||
|
//$serveurOK = 'preprod-tpeweb.paybox.com';
|
|||
|
|
|||
|
//Cr<43>ation de l'url cgi paybox
|
|||
|
$serveurOK = 'https://'.$serveurOK.'/cgi/MYchoix_pagepaiement.cgi';
|
|||
|
// echo $serveurOK;
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// --------------- TRAITEMENT DES VARIABLES ---------------
|
|||
|
|
|||
|
// On r<>cup<75>re la date au format ISO-8601
|
|||
|
$dateTime = date("c");
|
|||
|
$dateTime = "2016-07-26T15:38:11+02:00";
|
|||
|
|
|||
|
// On cr<63>e la cha<68>ne <20> hacher sans URLencodage
|
|||
|
$msg = "PBX_SITE=".$pbx_site.
|
|||
|
"&PBX_RANG=".$pbx_rang.
|
|||
|
"&PBX_IDENTIFIANT=".$pbx_identifiant.
|
|||
|
"&PBX_TOTAL=".$pbx_total.
|
|||
|
"&PBX_DEVISE=978".
|
|||
|
"&PBX_CMD=".$pbx_cmd.
|
|||
|
"&PBX_PORTEUR=".$pbx_porteur.
|
|||
|
// "&PBX_REPONDRE_A=".$pbx_repondre_a.
|
|||
|
"&PBX_RETOUR=".$pbx_retour.
|
|||
|
// "&PBX_EFFECTUE=".$pbx_effectue.
|
|||
|
// "&PBX_ANNULE=".$pbx_annule.
|
|||
|
// "&PBX_REFUSE=".$pbx_refuse.
|
|||
|
"&PBX_HASH=SHA512".
|
|||
|
"&PBX_TIME=".$dateTime;
|
|||
|
// echo $msg;
|
|||
|
|
|||
|
// Si la cl<63> est en ASCII, On la transforme en binaire
|
|||
|
$binKey = pack("H*", $keyTest);
|
|||
|
|
|||
|
// On calcule l<>empreinte (<28> renseigner dans le param<61>tre PBX_HMAC) gr<67>ce <20> la fonction hash_hmac et //
|
|||
|
// la cl<63> binaire
|
|||
|
// On envoi via la variable PBX_HASH l'algorithme de hachage qui a <20>t<EFBFBD> utilis<69> (SHA512 dans ce cas)
|
|||
|
// Pour afficher la liste des algorithmes disponibles sur votre environnement, d<>commentez la ligne //
|
|||
|
// suivante
|
|||
|
// print_r(hash_algos());
|
|||
|
echo $msg, "\n\n";
|
|||
|
var_dump($binKey);
|
|||
|
$hmac = strtoupper(hash_hmac('sha512', $msg, $binKey));
|
|||
|
|
|||
|
// La cha<68>ne sera envoy<6F>e en majuscule, d'o<> l'utilisation de strtoupper()
|
|||
|
// On cr<63>e le formulaire <20> envoyer
|
|||
|
// ATTENTION : l'ordre des champs est extr<74>mement important, il doit
|
|||
|
// correspondre exactement <20> l'ordre des champs dans la cha<68>ne hach<63>e
|
|||
|
?>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
<!------------------ ENVOI DES INFORMATIONS A PAYBOX (Formulaire) ------------------>
|
|||
|
<form method="POST" action="<?php echo $serveurOK; ?>">
|
|||
|
<input type="hidden" name="PBX_SITE" value="<?php echo $pbx_site; ?>">
|
|||
|
<input type="hidden" name="PBX_RANG" value="<?php echo $pbx_rang; ?>">
|
|||
|
<input type="hidden" name="PBX_IDENTIFIANT" value="<?php echo $pbx_identifiant; ?>">
|
|||
|
<input type="hidden" name="PBX_TOTAL" value="<?php echo $pbx_total; ?>">
|
|||
|
<input type="hidden" name="PBX_DEVISE" value="978">
|
|||
|
<input type="hidden" name="PBX_CMD" value="<?php echo $pbx_cmd; ?>">
|
|||
|
<input type="hidden" name="PBX_PORTEUR" value="<?php echo $pbx_porteur; ?>">
|
|||
|
<input type="hidden" name="PBX_RETOUR" value="<?php echo $pbx_retour; ?>">
|
|||
|
<input type="hidden" name="PBX_HASH" value="SHA512">
|
|||
|
<input type="hidden" name="PBX_TIME" value="<?php echo $dateTime; ?>">
|
|||
|
<input type="hidden" name="PBX_HMAC" value="<?php echo $hmac; ?>">
|
|||
|
<input type="submit" value="Envoyer">
|
|||
|
</form>
|