/* sort en affichant une erreur */
function cb_erreur($text) {
global $globals;
+ echo "Error.\n";
$mymail = new PlMailer();
$mymail->addTo($globals->money->email);
$mymail->setFrom("webmaster@" . $globals->mail->domain);
$mymail->setSubject("erreur lors d'un télépaiement (CyberPaiement)");
$mymail->setTxtBody("\n\n".var_export($_REQUEST,true));
$mymail->send();
+ echo "Notification sent.\n";
exit;
}
$s = strrev($nombre);
$sum = 0;
for ($i = 0; $i < strlen($s); $i++) {
- $dgt = $s{$i};
+ $dgt = $s{$i};
$sum += ($i % 2) ? (2*$dgt) % 9 : $dgt;
}
return $sum % 10;
function handlers()
{
return array(
- 'payment' => $this->make_hook('payment', AUTH_MDP),
+ 'payment' => $this->make_hook('payment', AUTH_MDP, 'payment'),
'payment/cyber_return' => $this->make_hook('cyber_return', AUTH_PUBLIC, 'user', NO_HTTPS),
'payment/cyber2_return' => $this->make_hook('cyber2_return', AUTH_PUBLIC, 'user', NO_HTTPS),
'payment/paypal_return' => $this->make_hook('paypal_return', AUTH_PUBLIC, 'user', NO_HTTPS),
{
global $globals;
- require_once 'profil.func.inc.php' ;
$this->load('money.inc.php');
if (!empty($GLOBALS['IS_XNET_SITE'])) {
if ($eid = $res->fetchOneCell()) {
require_once dirname(__FILE__) . '/xnetevents/xnetevents.inc.php';
$evt = get_event_detail($eid);
- subscribe_lists_event(0, $uid, $evt, $montant, true);
+ subscribe_lists_event($uid, $evt, 1, $montant, true);
}
/* on genere le mail de confirmation */
function handler_cyber2_return(&$page, $uid = null)
{
global $globals, $platal;
-
+
/* on vérifie la signature */
$vads_params = array();
foreach($_REQUEST as $key => $value)
- if(substr($key,0,5) == "vads_")
- $vads_params[$key] = $value;
+ if(substr($key,0,5) == "vads_")
+ $vads_params[$key] = $value;
ksort($vads_params);
$signature = sha1(join('+',$vads_params).'+'.$globals->money->cyperplus_key);
//if($signature != Env::v('signature')) {
// cb_erreur("signature invalide");
//}
-
+
/* on extrait les informations sur l'utilisateur */
$user = User::get(Env::v('vads_cust_id'));
if (!$user) {
cb_erreur("référence de commande invalide");
}
- echo ($ref = $matches[1]);
+ $ref = $matches[1];
$res = XDB::query("SELECT mail, text, confirmation
FROM payments
WHERE id={?}", $ref);
if (!list($conf_mail, $conf_title, $conf_text) = $res->fetchOneRow()) {
cb_erreur("référence de commande inconnue");
}
-
+
/* on extrait le montant */
if (Env::v('vads_currency') != "978") {
cb_erreur("monnaie autre que l'euro");
if (Env::v('vads_result') != "00") {
cb_erreur("erreur lors du paiement : ?? (".Env::v('vads_result').")");
}
-
+
/* on fait l'insertion en base de donnees */
XDB::execute("INSERT INTO payment_transactions (id, uid, ref, fullref, amount, pkey, comment)
VALUES ({?}, {?}, {?}, {?}, {?}, {?}, {?})",
Env::v('vads_trans_date'), $user->id(), $ref, Env::v('vads_order_id'), $montant, "", Env::v('vads_order_info'));
+ echo "Paiement stored.\n";
// We check if it is an Xnet payment and then update the related ML.
$res = XDB::query('SELECT eid
if ($eid = $res->fetchOneCell()) {
require_once dirname(__FILE__) . '/xnetevents/xnetevents.inc.php';
$evt = get_event_detail($eid);
- subscribe_lists_event(0, $uid, $evt, $montant, true);
+ subscribe_lists_event($user->id(), $evt, 1, $montant, true);
}
/* on genere le mail de confirmation */
$msg = 'utilisateur : ' . $user->login() . ' (' . $user->id() . ')' . "\n" .
'mail : ' . $user->forlifeEmail() . "\n\n" .
"paiement : $conf_title ($conf_mail)\n".
- "reference : $champ200\n".
+ "reference : " . Env::v('vads_order_id') . "\n".
"montant : $montant\n\n".
"dump de REQUEST:\n".
var_export($_REQUEST,true);
$mymail->setTxtBody($msg);
$mymail->send();
+ echo "Notifications sent.\n";
exit;
}
if ($eid = $res->fetchOneCell()) {
require_once dirname(__FILE__) . '/xnetevents/xnetevents.inc.php';
$evt = get_event_detail($eid);
- subscribe_lists_event(0, $uid, $evt, $montant, true);
+ subscribe_lists_event($user->id(), $evt, 1, $montant, true);
}
/* on genere le mail de confirmation */