Joomladay francophone 2018 à Paris 18 et 19 mai

cyberpaiement BP, message: Pb de sécurité

Réduire
X
  • Filtrer
  • Heure
  • Afficher
Tout effacer
nouveaux messages

  • cyberpaiement BP, message: Pb de sécurité

    Bonjour,

    J'utilise sur deux sites le cyberpaiement de la banque populaire. J'ai donc mis en place le module de Alatak qui fonctionnait très bien jusqu'à il y a quelque jours.

    J'ai eu un échange avec les techniciens de la banque qui me disent:

    Concernant le pb de sécurité, il faut mettre en place la clé d'acceptation champ 009.
    L'agreement PCI DSS en cours nous oblige à faire de nombreux changement dans les bases de données, cryptage des données, séparation physique des données, mise en place de nouvelle procédures. Le but de cette réorganisation est d'empêcher les " hacker " qui réussiraient à pénétrer notre système de récupérer des numéros de cartes. Nous avons donc fais une petite adaptation mineur pour vous permettre de fonctionner, cette adaptation est bien sur sans conséquence sur l'agreement PCI DSS.
    hem hem ouiouioui .

    Ils me donnent aussi un script a ajouter pour remplir le champ 009:
    http://www.cyberpaiement.tm.fr/doc/c...ept_bp.inc.php

    Tout ca c'est bien, mais je ne sais pas ou ajouter ce script... Je n'y connais rien en php ...

    Est-ce que je suis le seul a avoir ce problème? Et est-ce que quelqu'un a la solution?

    merci d'avance!
    Vincenzo

  • #2
    Moi aussi !

    La bpl m'a debloqué la situation en provisoire afin de ne pas rendre ce champ obligatoire. j'allais mettre en prod le site !
    Néanmoins j'ai tricoté un patch qui semble fonctionner, n'ayant pas eu de réponse des personnes qui ont développé ce module. Je suis tout prêt à te le donner sous réserves que la sécurité du biniou ne soit pas entamée et que tu m'en dégage toute responsabilité.

    www.drakkar-ac.fr vente en ligne de matériel HiFi et Home Cinéma haut de gamme.
    http//www.monptitloup.com

    Commentaire


    • #3
      Bonjour dgills,

      Merci pour ta réponse, Oui je suis intéressée, et non je ne te tiendrais pas pour responsable lol!

      L'idéal serait que tu indique tes modifications ici dans le forum, ainsi d'autres personnes pourront te relire et éventuellement corriger ton travail.

      Alatak pourra aussi mettre a jour son extension si tout est parfait

      Vincenzo

      Commentaire


      • #4
        Oui bien sur.

        Voici les fichiers modifiés contenant un lismoi.txt

        teste et dis nous si chez toi aussi ça marche.

        Important:

        VM 1.1.0
        J! 1.0.15
        PHP4

        www.drakkar-ac.fr (que du beau matériel )
        Fichiers joints
        http//www.monptitloup.com

        Commentaire


        • #5
          ok si je comprend, tu as mis les modifs de: http://forum.joomla.fr/showthread.php?t=70602

          + un lien vers le script php que nous a envoyé la banque.

          est-ce qu'il te serais possible d'afficher en rouge tes modifs, comme sur le post site si-dessus?

          La banque a aussi accepte de me débloquer les sites. Ils sont deja en production, je ferais les tests en direct au telephone avec les techs de la banque la semaine prochaine.

          Vincenzo

          Commentaire


          • #6
            voici les modifs en rouge pour cyberpaiement

            modifications pour cle_accept_bp.inc.php

            <?php
            defined('_VALID_MOS' ) or die('Direct Access to this location is not allowed.' );

            // ===============================================
            // CALCUL DE LA CLE D'ACCEPTATION EN FONCTION
            // DU DOSSIER = Solution BP CyberP@iement
            // ===============================================

            // JDM, 05/09/2005 (jdm.cc)


            // Source VB de la banque retranscrite en PHP
            // ===============================================

            // supprimer ou mettre en commentaires ces 3 lignes
            // Appel à la fonction de calcul de la clé
            // $cle_in=cle_accept_bp ("10,00", "76367", "1234567", "0000000034872", "6874509") ;
            // echo $cle_in ;


            /*
            Renvoie la clé d'acceptation en fonction des paramètres donnés, dans l'ordre :
            --------------

            voici les modification essentielles pour checkout.cyber_cc_form.php

            require_once(CLASSPATH . "payment/ps_cyberpayment.cfg.php" );
            require_once(PAGEPATH . 'cyberpayment/cle_accept_bp.inc.php' );
            global $mosConfig_absolute_path, $mosConfig_live_site, $mosConfig_lang, $cle_in, $prixadeclarer;
            global $PHPSHOP_LANG;

            if (file_exists(PAGEPATH . 'cyberpayment/languages/' . $mosConfig_lang . '.php' ) )
            require_once(PAGEPATH . 'cyberpayment/languages/' . $mosConfig_lang . '.php' );
            else
            require_once(PAGEPATH . 'cyberpayment/languages/french.php' );
            $url = URL;
            $url = str_replace ("/", "%2F", $url );
            $url = str_replace (":", "%3A", $url );
            $site = $mosConfig_live_site;
            $site = str_replace ("/", "%2F", $site );
            $site = str_replace (":", "%3A", $site );

            // interrogation BDD pour infos utilisateur
            $userid = $auth['user_id'];
            $dbg = new ps_DB;
            $q="SELECT first_name,last_name, user_email , address_1, address_2, city, zip, country FROM #__{vm}_user_info WHERE user_id = '$userid'";
            $dbg->query($q);
            $dbg->next_record();

            // calcul valeur prix a payer en cents dans la cle de retour
            $prixadeclarer = ($db->f("order_total" )) * 100 ;


            $champ = "CHAMP000=" . CYBER_INTERNET_ID; // No abonne internet
            $champ .= "&CHAMP001=" . CYBER_MERCHANT_ID; // Code Activite commerçant MCC
            $champ .= "&CHAMP002=" . CYBER_CONTRACT_ID; // No Contrat Commerçant

            // calcul de la cle de retour
            $cle_in = cle_accept_bp ( $prixadeclarer, CYBER_CONTRACT_ID, "0101010", $order_id, CYBER_ACCOUNT) ;


            $champ .= "&CHAMP003=" . CYBER_PAYMENT_TYPE; // I: Immediat, D: Differe
            $champ .= "&CHAMP004=" . $site; // Nom du serveur commerçant (informatif)
            $reponse005_std = $url . "index.php?page=checkout.cyber_response%26opti on=" . $option . "%26order_id=" . $db->f("order_id" ) . "%26CHAMPBPX"; // adresse de retour chez le commerçant
            $reponse005_rsts = $url . "index.php?page=checkout.cyber_rsts%26option=" . $option . "%26order_id=" . $db->f("order_id" ) . "%26CHAMPBPX"; // adresse 2 de retour chez le commerçant
            $reponse007_rsts = $url . "index.php?page=checkout.cyber_response%26opti on=" . $option . "%26order_id=" . $db->f("order_id" ); // adresse de retour chez le commerçant
            if (CYBER_VERSION == 'STD' ) {
            $champ .= "&CHAMP005=" . $reponse005_std; // adresse de retour chez le commerçant
            } else {
            $champ .= "&CHAMP005=" . $reponse005_rsts; // adresse de retour chez le commerçant
            $champ .= "&CHAMP007=" . $reponse007_rsts; // adresse 2 de retour chez le commerçant
            }

            $champ .= "&CHAMP006=" . $vendor_store_name; // Nom du commerçant

            $champ .= "&CHAMP008=" . $vendor_mail; // email de confirmation du commerçant
            $champ .= "&CHAMP009=" . $cle_in; // cle de retour
            // $champ .="&CHAMP010=".""; // Timer redirection automatique
            // CLIENT
            $champ .= "&CHAMP100=" . $dbg->f("last_name"); // Nom client
            $champ .= "&CHAMP101=" . $dbg->f("first_name"); // Prénom client
            $champ .= "&CHAMP102=" . "."; // Société
            $champ .= "&CHAMP103=" . "."; // Téléphone
            if (CYBER_MAIL_TO_CLIENT == '1' )
            $champ .= "&CHAMP104=" . $dbg->f("user_email"); // Adresse e mail client
            else
            $champ .= "&CHAMP104=" . "."; // Adresse e mail client
            $champ .= "&CHAMP106=" . "."; //$user->fax; // Fax

            $champ .= "&CHAMP107=" . $dbg->f("address_1") . " " . $dbg->f("address_2") ; // Adresse = numéro+rue
            $champ .= "&CHAMP108=" . $dbg->f("city"); // Ville
            $champ .= "&CHAMP109=" . $dbg->f("zip"); // Code Postal
            $champ .= "&CHAMP110=" . $dbg->f("country"); // Code Pays

            // Commande
            $champ .= "&CHAMP200=" . $db->f("order_id" ) ; // Référence commande
            // $amount=round( $db->f("order_subtotal")+$tax_total, 2)
            $champ .= "&CHAMP201=" . str_replace(".", ",", $db->f("order_total" ) ); // Montant (décimal=virgule)
            $champ .= "&CHAMP202=" . $_SESSION['vendor_currency']; // Devise (ISO lettre)

            // Divers
            $champ .= "&CHAMP900=" . "01"; // Banque
            $champ .= "&CHAMP901=" . "0101010"; // Banque

            // $champ.="&CHAMP905="."A1A1A1"; // Banque
            $link = "https://ecom.cimetz.com/telepaie/cgishell.exe/epaie01?" . $champ;

            ?>


            je pense n'avoir rien oublié. Donc je récapitule:

            le script cyberpaiement v 1.04 ALATAK (documentation incluse au pack ) et ces 2 fichiers, un à remplacer et un à ajouter (cf ci-dessus) et l'affaire est dans le sac.
            NB: sous PHP5 n'apparait pas l'onglet "configuration" dans les méthodes de paiement. Si c'est votre cas repasser en PHP4, excusez moi de le répéter mais j'ai suffisamment galéré avant de trouver.

            Je vous souhaite de bonnes ventes.

            Gilles.

            www.drakkar-ac.fr Votre salle de Cinéma Privée, ouverture imminente .

            Sous VM 1.1.0
            Joomla 1.0.15
            PHP4.
            http//www.monptitloup.com

            Commentaire


            • #7
              Peut on connaitre les resultats de tes tests ?

              STP

              www.drakkar-ac.fr Votre Auditorium privé.
              http//www.monptitloup.com

              Commentaire

              Annonce

              Réduire
              1 sur 2 < >

              C'est [Réglé] et on n'en parle plus ?

              A quoi ça sert ?
              La mention [Réglé] permet aux visiteurs d'identifier rapidement les messages qui ont trouvé une solution.

              Merci donc d'utiliser cette fonctionnalité afin de faciliter la navigation et la recherche d'informations de tous sur le forum.

              Si vous deviez oublier de porter cette mention, nous nous permettrons de le faire à votre place... mais seulement une fois
              Comment ajouter la mention [Réglé] à votre discussion ?
              1 - Aller sur votre discussion et éditer votre premier message :


              2 - Cliquer sur la liste déroulante Préfixe.

              3 - Choisir le préfixe [Réglé].


              4 - Et voilà… votre discussion est désormais identifiée comme réglée.

              2 sur 2 < >

              Assistance au forum - Outil de publication d'infos de votre site

              Compatibilité: PHP 4.1,PHP4, 5, 6DEV MySQL 3.2 - 5.5 MySQLi from 4.1 ( @ >=PHP 4.4.9)

              Support Version de Joomla! : | J!3.0 | J!2.5.xx | J!1.7.xx | J!1.6.xx | J1.5.xx | J!1.0.xx |

              Version française (FR) D'autres versions sont disponibles depuis la version originale de FPA

              UTILISER À VOS PROPRES RISQUES :
              L'exactitude et l'exhaustivité de ce script ainsi que la documentation ne sont pas garanties et aucune responsabilité ne sera acceptée pour tout dommage, questions ou confusion provoquée par l'utilisation de ce script.

              Problèmes connus :
              FPA n'est actuellement pas compatible avec des sites Joomla qui ont eu leur fichier configuration.php déplacé en dehors du répertoire public_html.

              Installation :

              1. Téléchargez l'archive souhaitée : http://afuj.github.io/FPA/

              Archive zip : https://github.com/AFUJ/FPA/zipball/master

              2. Décompressez le fichier de package téléchargé sur votre propre ordinateur (à l'aide de WinZip ou d'un outil de décompression natif).

              3. Lisez le fichier LISEZMOI inclus pour toutes les notes de versions spécifiques.

              4. LIRE le fichier de documentation inclus pour obtenir des instructions d'utilisation détaillées.

              5. Téléchargez le script fpa-fr.php à la racine de votre site Joomla!. C'est l'endroit que vous avez installé Joomla et ce n'est pas la racine principale de votre serveur. Voir les exemples ci-dessous.

              6. Exécutez le script via votre navigateur en tapant: http:// www. votresite .com/ fpa-fr.php
              et remplacer www. votresite .com par votre nom de domaine


              Exemples:
              Joomla! est installé dans votre répertoire web et vous avez installé la version française du fichier FPA:
              Télécharger le script fpa-fr.php dans: /public_html/
              Pour executer le script: http://www..com/fpa-fr.php

              Joomla! est installé dans un sous-répertoire nommé "cms" et vous avez installé la version française du fichier FPA:
              Télécharger le script fpa-fr.php dans: /public_html/cms/
              Pour executer le script: http://www..com/cms/fpa-fr.php

              En raison de la nature très sensible de l'information affichée par le script FPA, il doit être retiré immédiatement du serveur après son utilisation.

              Pour supprimer le script de votre site, utilisez le lien de script de suppression fourni en haut de la page du script. Si le lien de suppression échoue pour supprimer le script, utilisez votre programme FTP pour le supprimer manuellement ou changer le nom une fois que le script a généré les données du site et le message publié sur le forum. Si le script est toujours présent sur le site, il peut être utilisé pour recueillir suffisamment d'informations pour pirater votre site. Le retrait du script empêche des étrangers de l'utiliser pour jeter un oeil à la façon dont votre site est structuré et de détecter les défauts qui peuvent être utilisé à vos dépends.
              Voir plus
              Voir moins
              Travaille ...
              X