- if ($e = _request('montant') AND !(ctype_digit($e))) {
- /* FIXME: vérifier que le montant est compris dans les bornes. */
- $erreurs['montant'] = "Montant invalide";
+ if($e = _request('pays')) {
+ $ret = sql_select('nom', 'spip_pays', "code='${e}'");
+
+ if(sql_count($ret) != 1)
+ $erreurs['pays'] = "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";
+ }
+ }
+ }
+
+ if ($e = _request('telephone') AND !preg_match("/^[0-9\+ \.]+$/", $e)) {
+ $erreurs['telephone'] = "Numéro de téléphone incorrect";
+ }
+
+
+ if ($e = _request('montant')) {
+ if(!(ctype_digit($e)))
+ $erreurs['montant'] = "Montant invalide";
+ else {
+ $type_saisie = lire_config("souscription/${type}_type_saisie");
+
+ /* 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(($type_saisie != "input") AND !array_key_exists($e, lire_config("souscription/${type}_montants")))
+ $erreurs['montant'] = "Le montant spécifié est invalide";
+ }
+ }
+
+ if(count($erreurs) > 0) {
+ $erreurs['message_erreur'] = "Le formulaire contient des erreurs";