$montant_explication = nl2br(lire_config("souscription/${type}_montants_description"));
return array('montant' => '',
+ 'montant_libre' => '',
'courriel' => '',
'recu_fiscal' => $recu_fiscal,
'envoyer_info' => 'on',
* paramètres globaux.
*/
if ($e = _request('montant')){
+ $libre = false;
+ if ($e=="libre"){
+ $e = _request('montant_libre');
+ $libre = true;
+ }
if (!(ctype_digit($e)))
$erreurs['montant'] = "Montant invalide";
else {
$montant_datas = lire_config("souscription/{$type_campagne}_montants", array());
} else {
$montant_type = $campagne['type_saisie'];
- $montant_datas = montants_str2array($campagne['montants']);
+ $montant_datas = $campagne['montants'];
}
/* On ne vérifie strictement la valeur du montant que si on
* n'utilise pas le type de saisie « entrée libre » (input) pour
* le montant. */
- if (($montant_type!="input") AND !array_key_exists($e, $montant_datas))
- $erreurs['montant'] = "Le montant spécifié est invalide" . var_export($campagne, true);
+ if (($montant_type!=="input")
+ AND !$libre
+ AND !array_key_exists($e, montants_str2array($montant_datas)))
+ $erreurs['montant'] = "Le montant spécifié est invalide";
}
}
$row = array();
$hidden = '';
$retour = '';
+ $ret = array();
$campagne = sql_fetsel(array("type_objectif", "configuration_specifique", "type_saisie", "montants"),
"spip_souscription_campagnes", "id_souscription_campagne=".intval($id_souscription_campagne));
set_request("id_souscription_campagne",$id_souscription_campagne);
set_request('type_souscription',$campagne['type_objectif']);
- $ret = formulaires_editer_objet_traiter('souscription',
- 'new',
- '',
- $lier_trad,
- $retour,
- $config_fonc,
- $row,
- $hidden);
-
- $redirect = "";
- $row = sql_fetsel("transaction_hash,id_transaction",
- "spip_transactions LEFT JOIN spip_souscriptions USING(id_transaction)",
- "id_souscription=" . $ret['id_souscription']);
-
- if (!$row){
- spip_log(sprintf("Erreur lors de la création de la transaction liée à la souscription [%s].", $ret['id_souscription']), "souscription");
- $ret['message_erreur'] = "Echec creation de la transaction";
- } else {
- spip_log(sprintf("La souscription [%s], associée à la transaction [%s] a bien été crée.", $ret['id_souscription'], $row['id_transaction']), "souscription");
- $hash = $row['transaction_hash'];
- $id_transaction = $row['id_transaction'];
- $redirect = generer_url_public("payer-acte", "id_transaction=$id_transaction&transaction_hash=$hash", false, false);
- $ret['redirect'] = $redirect;
+ // generer la transaction et l'associer a la souscription
+ $inserer_transaction = charger_fonction('inserer_transaction', 'bank');
+ $montant = _request('montant');
+ if ($montant=="libre")
+ $montant = _request('montant_libre');
+
+ $id_auteur = (isset($GLOBALS['visiteur_session']['id_auteur'])?$GLOBALS['visiteur_session']['id_auteur']:0);
+ $id_transaction = $inserer_transaction($montant,
+ $montant, /* montant_ht */
+ $id_auteur, /* id_auteur */
+ '', /* auteur_id */
+ _request('courriel'));
+
+ if (!$id_transaction){
+ $ret['message_erreur'] = "Erreur technique : impossible de preparer la transaction..."; /* FIXME: à rendre traduisible. */
+ }
+ else {
+
+ set_request("id_transaction",$id_transaction);
+
+ $ret = formulaires_editer_objet_traiter('souscription',
+ 'new',
+ '',
+ $lier_trad,
+ $retour,
+ $config_fonc,
+ $row,
+ $hidden);
+
+ $redirect = "";
+ $row = sql_fetsel("transaction_hash,id_transaction",
+ "spip_transactions LEFT JOIN spip_souscriptions USING(id_transaction)",
+ "id_souscription=" . $ret['id_souscription']);
+
+ if (!$row){
+ spip_log(sprintf("Erreur lors de la création de la transaction liée à la souscription [%s].", $ret['id_souscription']), "souscription");
+ $ret['message_erreur'] = "Echec creation de la transaction";
+ } else {
+ spip_log(sprintf("La souscription [%s], associée à la transaction [%s] a bien été crée.", $ret['id_souscription'], $row['id_transaction']), "souscription");
+ $hash = $row['transaction_hash'];
+ $id_transaction = $row['id_transaction'];
+ $redirect = generer_url_public("payer-acte", "id_transaction=$id_transaction&transaction_hash=$hash", false, false);
+ $ret['redirect'] = $redirect;
+ }
}
-
return $ret;
}
/* Si la campagne doit être fermée lorsque l'objectif est atteint,
* alors on bloque. */
- elseif ($campagne['objectif_limiter'] &&
+ elseif ($campagne['objectif_limiter'] == 'on' &&
calcul_avancement_campagne($id_souscription_campagne, $campagne['type_objectif'], $campagne['objectif_initial'])>=$campagne['objectif']
)
return false;