$type = $campagne['type_objectif'];
- $recu_fiscal = "";
+ $recu_fiscal = "off";
if ($type=="adhesion")
$recu_fiscal = "on";
$montant_explication = nl2br(lire_config("souscription/${type}_montants_description"));
return array('montant' => '',
+ 'montant_libre' => '',
'courriel' => '',
'recu_fiscal' => $recu_fiscal,
'envoyer_info' => 'on',
* Tableau des erreurs
*/
function formulaires_souscription_verifier_dist($id_souscription_campagne){
- $campagne = _request('id_souscription_campagne');
- $erreurs = formulaires_editer_objet_verifier('souscription', 'new',
- array('courriel',
- 'montant',
- 'id_souscription_campagne'));
-
- if (!$id_souscription_campagne || intval($id_souscription_campagne)!=intval($campagne)){
- $erreurs['message_erreur'] = "Campagne invalide";
- }
+ $erreurs = formulaires_editer_objet_verifier('souscription', 'new', array('courriel','montant'));
$campagne = sql_fetsel(array("type_objectif", "configuration_specifique", "type_saisie", "montants"),
- "spip_souscription_campagnes", "id_souscription_campagne=$id_souscription_campagne");
+ "spip_souscription_campagnes", "id_souscription_campagne=".intval($id_souscription_campagne));
$type_campagne = $campagne['type_objectif'];
- /* Le champ 'type' (hidden) doit être le même que celui défini dans
- * la campagne. */
- if (_request('type_souscription')!=$type_campagne)
- $erreurs['message_erreur'] = "Type de souscription invalide : " . _request('type_souscription');
-
if (!verifier_campagne($id_souscription_campagne, $type_campagne)){
- $erreurs['message_erreur'] = "La campagne à laquelle est associée cette souscription est invalide";
+ $erreurs['message_erreur'] = _T('souscription:erreur_souscription_campagne_invalide');
}
- if (_request('recu_fiscal') || $type_campagne=="adhesion"){
+ if (_request('recu_fiscal')==="on" || $type_campagne=="adhesion"){
foreach (array('prenom', 'nom', 'adresse', 'code_postal', 'ville', 'pays') as $obligatoire){
if (!_request($obligatoire)){
if ($type_campagne=="adhesion"){
- $erreurs[$obligatoire] = "Ce champ est obligatoire pour les adhésions";
+ $erreurs[$obligatoire] = _T('souscription:erreur_adhesion_champ_obligatoire');
} else {
- $erreurs[$obligatoire] = 'Ce champ est obligatoire (reçu fiscal demandé)';
+ $erreurs[$obligatoire] = _T('souscription:erreur_recu_fiscal_champ_obligatoire');
}
}
}
$ret = sql_select('nom', 'spip_pays', "code='${e}'");
if (sql_count($ret)!=1)
- $erreurs['pays'] = "Pays invalide";
+ $erreurs['pays'] = _T('souscription:erreur_pays_invalide');
/* Le code postal n'est vérifié que si on est dans le cas de la France */
elseif ($e = _request('pays') AND $e=="FR") {
if ($e = _request('code_postal') AND !preg_match("/^(2[ABab]|0[1-9]|[1-9][0-9])[0-9]{3}$/", $e)){
- $erreurs['code_postal'] = "Code postal invalide";
+ $erreurs['code_postal'] = _T('souscription:erreur_code_postal_invalide');
}
}
}
if ($e = _request('telephone') AND !preg_match("/^[0-9\+ \.]+$/", $e)){
- $erreurs['telephone'] = "Numéro de téléphone incorrect";
+ $erreurs['telephone'] = _T('souscription:erreur_telephone_invalide');
}
/* Vérification du montant. Si la campagne est configurée pour
* 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";
+ $erreurs['montant'] = _T("souscription:erreur_montant_invalide");
else {
if ($campagne['configuration_specifique']!=='on'){
$montant_type = lire_config("souscription/{$type_campagne}_type_saisie", 'input');
- $montant_datas = lire_config("souscription/${$type_campagne}_montants", array());
+ $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'] = _T('souscription:erreur_montant_specifie_invalide');
}
}
if (count($erreurs)>0){
- $erreurs['message_erreur'] = "Le formulaire contient des erreurs";
+ $erreurs['message_erreur'] = _T('souscription:erreur_formulaire');
}
return $erreurs;
$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);
-
- $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;
+ set_request('type_souscription',$campagne['type_objectif']);
+
+ // 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'] = _T('souscription:erreur_technique_formulaire');
+ }
+ 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'] = _T('souscription:erreur_echec_creation_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;