<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Davide Gullo, Consulente web &#187; payment gateway</title>
	<atom:link href="http://www.m4ss.net/tag/payment-gateway/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.m4ss.net</link>
	<description>&#34;E il mare il web concederà ad ogni uomo nuove speranze, come il sonno i sogni...&#34; Cristoforo Colombo</description>
	<lastBuildDate>Sat, 28 Jan 2012 18:05:48 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
<xhtml:meta xmlns:xhtml="http://www.w3.org/1999/xhtml" name="robots" content="noindex" />
		<item>
		<title>XT:Commerce, plugin Payment Gateway Consorzio Triveneto</title>
		<link>http://www.m4ss.net/2011/11/02/xt-commerce-plugin-payment-gateway-consorzio-triveneto/</link>
		<comments>http://www.m4ss.net/2011/11/02/xt-commerce-plugin-payment-gateway-consorzio-triveneto/#comments</comments>
		<pubDate>Wed, 02 Nov 2011 11:40:41 +0000</pubDate>
		<dc:creator>Jazzo</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[Consorzio Triveneto]]></category>
		<category><![CDATA[payment gateway]]></category>
		<category><![CDATA[xt commerce]]></category>

		<guid isPermaLink="false">http://www.m4ss.net/?p=1214</guid>
		<description><![CDATA[<a href="http://www.m4ss.net/2011/11/02/xt-commerce-plugin-payment-gateway-consorzio-triveneto/"><img align="left" hspace="5" width="150" src="http://www.m4ss.net/wp-content/uploads/2011/11/Schermata-2011-11-02-a-12.27.06.png" class="alignleft wp-post-image tfe" alt="" title="Schermata 2011-11-02 a 12.27.06" /></a>Michael Rogger (michael dot rogger at gmail dot com), basandosi sul codice sorgente della classe PgConsTriv, ha sviluppato il pluging per i pagamenti con carta di credito tramite il Payment gateway del Consorzio Triveneto sulla piattaforma xt:commerce. Abbiamo creato un&#8217;area apposita per le release che verrano rilasciate su SourceForge. Scarica il plugin ora. Di seguito invece [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.m4ss.net/wp-content/uploads/2011/11/Schermata-2011-11-02-a-12.27.06.png"><img class="alignnone size-full wp-image-1215" title="Schermata 2011-11-02 a 12.27.06" src="http://www.m4ss.net/wp-content/uploads/2011/11/Schermata-2011-11-02-a-12.27.06.png" alt="" width="331" height="107" /></a></p>
<p>Michael Rogger (michael dot rogger at gmail dot com), basandosi sul codice sorgente della <a title="Payment Gateway del Consorzio Triveneto PHP Class - TUTORIAL" href="/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/">classe PgConsTriv</a>, ha sviluppato il pluging per i <strong>pagamenti con carta di credito</strong> tramite il <a href="http://www.m4ss.net/os-open-source/payment-gateway-consorzio-triveneto-php-class/">Payment gateway del Consorzio Triveneto</a> sulla piattaforma <a href="http://www.xt-commerce.co.uk/">xt:commerce</a>.</p>
<p>Abbiamo creato un&#8217;area apposita per le release che verrano rilasciate su <strong>SourceForge</strong>.<br />
<a href="http://sourceforge.net/projects/pg-constriv/files/xt_commerce_plugin/">Scarica il plugin ora</a>.</p>
<p>Di seguito invece un breve <strong>Tutorial</strong> su come installare il plugin:</p>
<p>===<br />
This plugin is tested with <strong>xt commerce 4.0.14</strong>.</p>
<p>INSTALL<br />
1)    Edit xt_trivento/classes/PgConsTriv.inc.php to configure the gateway.<br />
Compulsory: merchant data (_PG_ID_Merchant_Test,_PG_Password_Test,_PG_ID_Merchant_Production,_PG_Password_Production) and _PG_URL_base.</p>
<p>2)     Copy folder xt_triveneto to shop/plugins/<br />
Note for debugging: make sure xt_triveneto/classes/debug.txt, xt_triveneto/classes/pgconstriv.txt and xt_triveneto/callback/debug.txt is writeable for webserver, these files are used for logging.</p>
<p>3)     Install the plugin using xt_commerce admin interface</p>
<p>4)     After successful testing you can change the mode from &#8220;Test&#8221; to &#8220;Production&#8221; in PgConsTriv.inc.php</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<div id="crp_related"><h2>Articoli correlati:</h2><ul><li><a href="http://www.m4ss.net/2010/05/12/payment-gateway-del-consorzio-triveneto-aggiornamento-1-3/" rel="bookmark" class="crp_title">Payment Gateway del Consorzio Triveneto (Aggiornamento 1.3)</a></li><li><a href="http://www.m4ss.net/2009/11/17/tutorial-multilingua-consorzio-triveneto-payment-gateway-tutorial/" rel="bookmark" class="crp_title">Tutorial per uso multilingua del Payment Gateway del Consorzio Triveneto</a></li><li><a href="http://www.m4ss.net/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/" rel="bookmark" class="crp_title">Tutorial per il Payment Gateway del Consorzio Triveneto SpA</a></li><li><a href="http://www.m4ss.net/2009/11/03/modbus-e-php/" rel="bookmark" class="crp_title">Modbus e PHP</a></li><li><a href="http://www.m4ss.net/2011/03/31/wordpress-problema-installazione-informazioni-connessioni-ftp/" rel="bookmark" class="crp_title">WordPress, risolvere problema Informazioni Connessioni FTP</a></li></ul></div>  ]]></content:encoded>
			<wfw:commentRss>http://www.m4ss.net/2011/11/02/xt-commerce-plugin-payment-gateway-consorzio-triveneto/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Payment Gateway del Consorzio Triveneto (Aggiornamento 1.3)</title>
		<link>http://www.m4ss.net/2010/05/12/payment-gateway-del-consorzio-triveneto-aggiornamento-1-3/</link>
		<comments>http://www.m4ss.net/2010/05/12/payment-gateway-del-consorzio-triveneto-aggiornamento-1-3/#comments</comments>
		<pubDate>Wed, 12 May 2010 14:23:58 +0000</pubDate>
		<dc:creator>Jazzo</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[carte di credito]]></category>
		<category><![CDATA[Consorzio Triveneto]]></category>
		<category><![CDATA[payment gateway]]></category>

		<guid isPermaLink="false">http://www.m4ss.net/?p=947</guid>
		<description><![CDATA[<a href="http://www.m4ss.net/2010/05/12/payment-gateway-del-consorzio-triveneto-aggiornamento-1-3/"><img align="left" hspace="5" width="150" src="/wp-content/uploads/2009/09/e-commerce-payment-gateway.jpg" class="alignleft wp-post-image tfe" alt="e-commerce payment gateway" title="" /></a>Ho aggiornato la classe PgConsTriv che implementa una serie di metodi utili alla realizzazione di siti e-commerce che necessitano di interfacciarsi al Payment Gateway del Consorzio Triveneto S.p.A. La gestione multi lingua era un po&#8217; ostica e ho preferito metterci mano risolvendo il problema a monte. Dalla nuova versione (Rel. 1.3) in poi la lingua [...]]]></description>
			<content:encoded><![CDATA[<p><img src="/wp-content/uploads/2009/09/e-commerce-payment-gateway.jpg" alt="e-commerce payment gateway" width="233" height="122" /></p>
<p>Ho aggiornato la classe <strong><a title="Payment Gateway del  Consorzio Triveneto PHP Class" href="http://www.m4ss.net/os-open-source/payment-gateway-consorzio-triveneto-php-class/">PgConsTriv</a></strong> che implementa una serie di metodi utili alla realizzazione di siti <strong>e-commerce</strong> che necessitano di interfacciarsi al <a title="Payment Gateway del  Consorzio Triveneto SpA" href="http://www.constriv.it/index.php?option=com_content&amp;task=view&amp;id=68&amp;Itemid=114"><strong>Payment  Gateway</strong> del Consorzio Triveneto S.p.A.</a></p>
<p>La gestione multi lingua era un po&#8217; ostica e ho preferito metterci mano risolvendo il problema a monte. Dalla nuova versione (<strong>Rel. 1.3</strong>) in poi la lingua verrà passata direttamente secondo i codici standard della <a title="List_of_ISO_639-1_codes by Wikipedia" href="http://en.wikipedia.org/wiki/List_of_ISO_639-1_codes">codifica ISO  639-1</a>.</p>
<p>La piattaforma del Payment Gateway accetta un codice (<strong>langid</strong>) per impostare la lingua con cui verrà visualizzata la HPP al Cardholder. I codici consentiti (come da Documentazione) sono:</p>
<ul>
<li><strong>ITA</strong> = Italiano</li>
<li><strong>USA</strong> = Inglese</li>
<li><strong>FRA</strong> = Francese</li>
<li><strong>DEU</strong> = Tedesco</li>
<li><strong>ESP</strong> = Spagnolo</li>
<li><strong>SLO</strong> = Sloveno</li>
</ul>
<p>Io invece preferisco l&#8217;utilizzo dei <strong>codici standard</strong> secondo la codifica <a title="List_of_ISO_639-1_codes by Wikipedia" href="http://en.wikipedia.org/wiki/List_of_ISO_639-1_codes">ISO  639-1</a>. A questo punto le due cose cozzavano e quindi ho messo mano alla classe. Ora il parametro dovrà essere passato secondo la <strong>codifica standard (it, en, fr, de, es, sl)</strong> e non quella del PG qui sopra. La classe (tramite l&#8217;array $arLingue &#8211; proprietà della classe) converte poi il valore automaticamente quando deve essere passato al PG.</p>
<p>Già che c&#8217;ero ho <strong>rinominato i file</strong> (classe e file di configurazione). Mi sono trovato ad installarlo su Zend Framework e c&#8217;erano troppi underscore e meno di troppo! <img src='http://www.m4ss.net/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </p>
<div id="crp_related"><h2>Articoli correlati:</h2><ul><li><a href="http://www.m4ss.net/2009/11/17/tutorial-multilingua-consorzio-triveneto-payment-gateway-tutorial/" rel="bookmark" class="crp_title">Tutorial per uso multilingua del Payment Gateway del Consorzio Triveneto</a></li><li><a href="http://www.m4ss.net/2011/11/02/xt-commerce-plugin-payment-gateway-consorzio-triveneto/" rel="bookmark" class="crp_title">XT:Commerce, plugin Payment Gateway Consorzio Triveneto</a></li><li><a href="http://www.m4ss.net/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/" rel="bookmark" class="crp_title">Tutorial per il Payment Gateway del Consorzio Triveneto SpA</a></li><li><a href="http://www.m4ss.net/2009/11/03/modbus-e-php/" rel="bookmark" class="crp_title">Modbus e PHP</a></li><li><a href="http://www.m4ss.net/2009/08/18/phpmailer-multi-language-class/" rel="bookmark" class="crp_title">PHPMailer multi lingua</a></li></ul></div>  ]]></content:encoded>
			<wfw:commentRss>http://www.m4ss.net/2010/05/12/payment-gateway-del-consorzio-triveneto-aggiornamento-1-3/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Tutorial per il Payment Gateway del Consorzio Triveneto SpA</title>
		<link>http://www.m4ss.net/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/</link>
		<comments>http://www.m4ss.net/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/#comments</comments>
		<pubDate>Thu, 01 Oct 2009 13:37:58 +0000</pubDate>
		<dc:creator>Jazzo</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[payment gateway]]></category>
		<category><![CDATA[PHP]]></category>

		<guid isPermaLink="false">http://www.m4ss.net/?p=716</guid>
		<description><![CDATA[<a href="http://www.m4ss.net/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/"><img align="left" hspace="5" width="150" src="http://www.m4ss.net/wp-content/uploads/2009/09/e-commerce-payment-gateway.jpg" class="alignleft wp-post-image tfe" alt="e-commerce payment gateway" title="" /></a>Lo sviluppo di un&#8217;applicativo e-commerce B2B per un cliente mi ha portato ad analizzare a fondo il Payment Gateway del Consorzio Triveneto S.p.A. Prima di iniziare mi complimento con il consorzio per aver redatto una documentazione molto precisa. Lo stesso gateway lo trovo veramente ben fatto ma su questo potrò darvi maggiori dettagli tra qualche [...]]]></description>
			<content:encoded><![CDATA[<p><img class="alignnone size-full wp-image-717" src="http://www.m4ss.net/wp-content/uploads/2009/09/e-commerce-payment-gateway.jpg" alt="e-commerce payment gateway" width="233" height="122" /></p>
<p>Lo sviluppo di un&#8217;<strong>applicativo e-commerce B2B</strong> per un cliente mi ha portato ad analizzare a fondo il <a title="Payment Gateway del Consorzio Triveneto SpA" href="http://www.constriv.it/index.php?option=com_content&amp;task=view&amp;id=68&amp;Itemid=114"><strong>Payment Gateway</strong> del Consorzio Triveneto S.p.A.</a> Prima di iniziare mi complimento con il consorzio per aver redatto una documentazione molto precisa. Lo stesso gateway lo trovo veramente ben fatto ma su questo potrò darvi maggiori dettagli tra qualche mese, quando il cliente sarà in produzione.</p>
<h2>Introduzione</h2>
<p>In un&#8217;applicativo web-based di <strong>e-commerce</strong> solitamente le figure (sarebbe meglio parlare di macchine, PC, server, ecc.) con cui abbiamo a che fare sono tre:</p>
<ol>
<li>L&#8217;utente che acquista e che naviga il sito (definito <strong>Cardholder</strong>)</li>
<li>Il negozio online: il server del sito di e-commerce (definito <strong>Merchant</strong>)</li>
<li>Il Gateway per i pagamenti, in parole povere: il server che si occupa delle transazioni con carta di credito (denifito <strong>Payment Gateway</strong>, qui di seguito <strong>Gateway</strong>)</li>
</ol>
<p>Dal punto di vista pratico quindi avremo il Cardholder che naviga il sito del Merchant ed esegue le sue operazioni di acquisto (ordini, carrello, ecc.). Una volta terminata la sessione di acquisti si dirige alla pagina del pagamento e qui entra in azione tutto quello che vedremo in questo <strong>Tutorial</strong>.</p>
<p>L&#8217;intero processo prevede comunicazioni tra le tre figure sopra elencate. Le comunicazioni tra Merchant e Gateway possono essere definite <strong>server-to-server</strong>, l&#8217;utente infatti non sempre interagisce con esse. I server si scambiano messaggi tra loro per ovvi <strong>motivi di sicurezza</strong>.</p>
<p>Sulla pagina del Merchant quindi deve essere predisposta una pagina che si occupa di inviare i dati (codice identificativo, importo da pagare, numero ordine, ecc.) al Gateway. Quando il Cardholder clicca sul famoso &#8220;<em>Paga ora!</em>&#8221; tali dati vengono inviati al server del Gateway che, dopo averli elaborati e controllati, restituisce una risposta al server del Merchant. In questo frangente il Cardholder resta in attesa davanti al pc!<br />
Una volta ricevuta la risposta dal Gateway la nostra procedura (Merchant) elabora i dati ricevuti e decide se proseguire o meno. In caso di errori potrebbe visualizzare una pagina al Cardholder perchè qualcosa è andato storto, in caso sia tutto ok invece potrebbe direttamente <strong>redirezionare il Cardholder</strong> verso la <strong>HPP</strong> (<strong>pagina del Gateway</strong> su cui l&#8217;utente inserisce i dati della sua carta di credito).<br />
Questa prima transazione (e relativo scambio di messaggi), nel modello predisposto dal Consorzio Triveneto, prende il nome di <strong>PaymentInit</strong>.</p>
<p>Il nostro utente (Cardholder) quindi, se i dati passati al Gateway sono congrui, viene redirezionato sulla HPP dove potrà <strong>inserire i dati della sua carta di credito</strong>. L&#8217;utente effettua quindi l&#8217;operazione compilando tutti i campi e poi dà l&#8217;invio.<br />
Qui scattano nuovamente diverse comunicazioni prima di restituire l&#8217;esito al Cardholder.<br />
Per prima cosa il Gateway deve interfacciarsi a sua volta ad altri server, quelli del <strong>Centro autorizzativo</strong>, e verificare la validità della carta, la disponibilità e quant&#8217;altro. Eseguita questa operazione ricontatta il Merchant riportando l&#8217;esito dell&#8217;operazione che, anche questa volta, può essere positivo o negativo. In base all&#8217;esito il server del Merchant restituisce un <strong>URL verso cui redirezionare il Cardholder</strong>. Il Gateway quindi si occupa poi di redirezionare il Cardholder sulla pagina dell&#8217;esito.<br />
Questa seconda transazione (e relativo scambio di messaggi), nel modello predisposto dal Consorzio Triveneto, prende il nome di <strong>NotificationMessage</strong>.</p>
<p>Ora passiamo alla pratica, successivamente vedremo perchè il NotificationMessage è così importante dal punto di vista della sicurezza.</p>
<h2>La Classe PgConsTriv</h2>
<p>Ho implementato questa classe e l&#8217;ho rilasciata sotto licenza <strong>GNU Lesser General Public License</strong> su <a title="Payment Gateway del Consorzio Triveneto PHP Class - SourceForge" href="https://sourceforge.net/projects/pg-constriv">SourceForge</a>.<br />
Questa la pagina che ho predisposto per la <a title="Consorzio Triveneto Payment Gateway (php Class)" href="http://www.m4ss.net/os-open-source/payment-gateway-consorzio-triveneto-php-class/">documentazione tecnica per la classe <strong>PgConsTriv</strong></a> e qui link per il <a title="Payment Gateway del Consorzio Triveneto PHP Class - SourceForge" href="http://sourceforge.net/projects/pg-constriv/"><strong>download</strong></a> dell&#8217;<strong>ultima release</strong> (PgConsTriv.zip).<br />
Insieme alla classe trovate una cartella <em>example</em>, in cui risiedono i file di esempio che vedremo insieme in questo <strong>Tutorial</strong>, e il file di configurazione. In dettaglio:</p>
<ul>
<li><em>PgConsTriv.php</em> (classe)</li>
<li><em>PgConsTriv.inc.php</em> (file di configurazione)</li>
<li>example/
<ul>
<li><em>paynow.php</em><br />
Pagina per predisposizione e invio del <strong>PaymentInit</strong></li>
<li><em>responseURL.php</em><br />
Pagina per ricezione ed elaborazione del <strong>NotificationMessage</strong></li>
<li><em>errorURL.php</em><br />
Pagina per esito negativo</li>
<li><em>goodURL.php</em><br />
Pagina per esito positivo</li>
<li><em>test_PG.php</em><br />
Form che invia POST per testare la pagina del Response URL</li>
</ul>
</li>
</ul>
<p>Prima di iniziare dovete <a title="Consorzio Triveneto Payment Gateway (php Class) - Configurazione parametri" href="http://www.m4ss.net/os-open-source/payment-gateway-consorzio-triveneto-php-class/#classe_documentazione"><strong>configurare</strong> i parametri della classe</a> presenti nel file <em>PgConsTriv.inc.php</em></p>
<h2>Il PaymentInit e l&#8217;inizio della transazione</h2>
<p>Come dicevamo sopra, tutto ha inizio con l&#8217;invio da parte del Merchant del PaymentInit. Da questo riceveremo una prima risposta che ci fornirà:</p>
<ul>
<li>In caso di <strong>esito positivo</strong>: l&#8217;indirizzo verso cui redirezionare il Cardholder e il <strong>PaymentID</strong></li>
<li>In caso di <strong>esito negativo</strong>: una stringa con <strong>!ERROR!</strong> e relativa descrizione</li>
</ul>
<p>Analizziamo ora il file <strong><em>paynow.php</em></strong> in dettaglio.</p>
<blockquote><p><strong>N.B.:</strong> Preferisco creare una pagina separata alla quale passo via GET l&#8217;id dell&#8217;ordine. Tramite questo recupero dal database tutti i dati necessari dell&#8217;ordine e avvio la procedura. In questo modo si ha una <strong>maggiore sicurezza</strong> perchè se, ad esempio, invio tutti i dati via POST o GET direttamente alla pagina l&#8217;utente &#8220;furbetto&#8221; potrebbe intercettarli e variarli.</p></blockquote>
<p>Al <em>paynow.php</em> quindi arriva il mio id ordine ($idp), poi recupero i dati dal database e li sistemo in un array ($arRp).<br />
A questo punto verifico i dati e decido se procedere o meno:</p>
<p><code>// VERIFICO se può accedere all'ordine<br />
if( count($arRp) &gt; 0 &amp;&amp;<br />
$idp &gt; 0 &amp;&amp;<br />
isset($arRp["stato"]) &amp;&amp;<br />
($arRp["stato"] == "NEW" || $arRp["stato"] == "PAYMENT_INIT" )<br />
) {</code></p>
<blockquote><p><strong>N.B.:</strong> Nel mio ordine gestisco un campo <strong>stato</strong>. E&#8217; lo stesso che poi andrò ad aggiornare tramite risposte del server del Gateway in base ai vari esiti e passaggi. In questo modo avrò sempre sotto controllo l&#8217;andamento dell&#8217;ordine.<br />
Qui sopra, infatti, verifico che lo stato sia consono a ciò che sto per effettuare: il PaymentInit. Il mio ordine quindi deve essere o in stato Nuovo (NEW) o in PaymentInit. Questo secondo caso lo lascio passare perchè ipotizzo la situazione in cui l&#8217;utente clicca su &#8220;Paga ora!&#8221; e, dopo aver visualizzato la HPP del Gateway, chiude il browser.</p></blockquote>
<p>A questo punto siamo pronti per inviare il PaymentInit che altro non è che l&#8217;invio di una serie di <strong>dati via POST</strong> ad un indirizzo specifico. Creando un&#8217;istanza della classe andremo ad inserire i soli dati che potranno variare da ordine ad ordine mentre tutti gli altri dati saranno gestiti dalla classe stessa.<br />
Vediamo ora l&#8217;istanza della classe e la preparazione del PaymentInit con l&#8217;invio dei dati al Gateway.</p>
<p><code>// init </code><code>PgConsTriv </code><code>Class<br />
$pg = new <strong>PgConsTriv</strong>($lng);<br />
$pg-&gt;setAction('Purchase');<br />
$pg-&gt;<strong>setSecurityCode_PI</strong>( $secCode );<br />
$pg-&gt;<strong>sendVal_PI</strong>($importo, $idp);</code></p>
<p>Per istanziare la classe devo passare il parametro della <strong>lingua</strong> ($lng). Tale parametro è opzionale e nel caso non venga passato la classe utilizzerà la lingua di default settata nel file di configurazione. Per maggiori dettagli leggi il <a title="PgConsTriv Class multi lingua" href="http://www.m4ss.net/2009/11/17/tutorial-multilingua-consorzio-triveneto-payment-gateway-tutorial/">Tutorial multi lingua</a>.<br />
Il metodo <em>setAction</em> imposta l&#8217;Action. <strong>Purchase</strong> si occupa di eseguire direttamente l&#8217;accredito dell&#8217;importo (vedi documentazione del Gateway, Appendice A).</p>
<p>Veniamo ora al discorso sicurezza e il parametro <strong>SecurityCode</strong>.</p>
<blockquote><p>N.B.: Nella documentazione del Consorzio (pag. 23) si raccomanda di verificare sempre l&#8217;autenticità del NotificationMessage. Una delle soluzioni proposte è quella di inviare via PaymentInit un valore che il Cardholder non vede e non può conoscere. Lo stesso valore verrà poi restituito al Merchant successivamente attraverso il NotificationMessage. In questo modo potremo verificare il dato ricostruendolo e confrontandolo con quello passato dal NotificationMessage.</p></blockquote>
<p>Impostiamo quindi il nostro SecurityCode (<em>$secCode</em>). Per generare un codice univoco potreste crearvi una stringa criptando in md5 alcuni dati presenti nel database (es: data ordine, idordine, importo, ecc.). In questo modo, successivamente, all&#8217;arrivo del NotificationMessage sarete in grado di ricostruirla con la stessa logica e verificarla con quella che vi verrà passata dal Gateway.</p>
<p>A questo punto punto siamo pronti per <strong>inviare il PaymentInit</strong>. Il metodo <em>sendVal_PI</em> riceve 2 valori:</p>
<ul>
<li>$importo &#8211; Importo della transazione</li>
<li>$idp &#8211; Denominato trackid nella Documentazione del Gateway e deve essere un id univoco dell&#8217;ordine</li>
</ul>
<p>Il metodo <em>sendVal_PI</em> invia i dati al Gateway e ne elabora la risposta.<br />
Ora vediamo come gestire tale risposta:</p>
<p><code>// Verifico esito del PaymentInit<br />
if( $pg-&gt;<strong>hasError_PI</strong>() )<br />
{<br />
// SEGNALAZIONE ERRORE!<br />
echo "&lt;h1&gt;ERRORE: ".$pg-&gt;getError_PI()."&lt;/h1&gt;";<br />
} else {<br />
// Registro il PaymentID nel database e invio l'utente alla HPP del Gateway<br />
mysql_query("UPDATE ordini SET .... ....");<br />
header("Location: " . $pg-&gt;getPaymentURL_PI() );<br />
}</code></p>
<p>Il metodo <em>hasError_PI</em> ci restituisce true se si sono verificati errori, in tal caso l&#8217;errore lo possiamo recuperare con il metodo <em>getError_PI</em>.<br />
In caso di <strong>esito positivo</strong> recuperiamo i dati con:</p>
<ul>
<li><strong>getID_PI</strong> &#8211; PaymentID generato dal Gateway</li>
<li><strong>getPaymentURL_PI</strong> &#8211; URL della HPP</li>
</ul>
<p>Redirezionando l&#8217;utente <strong>verso la HPP del Gateway</strong> abbiamo concluso le operazioni del PaymentInit. Il Cardholder (utente) caricherà tale pagina e potrà inserire i dati della sua carta di credito. Solo dopo che avrà dato l&#8217;invio sulla HPP il Gateway ci contatterà per inviarci il <strong>NotificationMessage</strong>.</p>
<h2>Il NotificationMessage e la chiusura della transazione</h2>
<p>Nel momento in cui l&#8217;utente invia i dati della sua carta di credito al Gateway questo, dopo averli controllati presso il Centro Autorizzativo, contatta il server del Merchant inviando il NotificationMessage. Il Merchant risponde con un stringa che include l&#8217;indirizzo verso cui redirezionare il Cardholder.<br />
La pagina di esempio che si occupa di tutto ciò è <em>responseURL.php</em>.</p>
<p>La prima operazione è creare una nuova istanza della classe per poi passargli i dati ricevuti via POST.</p>
<p><code>// init </code><code>PgConsTriv </code><code>Class<br />
$pg = new PgConsTriv($lng);<br />
$pg-&gt;setAction('Purchase');<br />
$pg-&gt;<strong>setVal_NM</strong>($_POST);</code></p>
<p><em>setVal_NM</em> si occupa appunto di registrare tutti i dati nella classe.<br />
A questo punto iniziamo i nostri controlli per verificare la validità dei dati ricevuti.</p>
<p><code>// get paymentid<br />
$paymentid = $pg-&gt;<strong>getPaymentID_NM</strong>();<br />
// Verifico se esiste il PaymentID<br />
if( $paymentid !== false ){<br />
// Recupero Ordine dal database in base al PaymentID settato in fase di PaymentInit</code></p>
<p>Nel caso in cui qualcosa fosse andato storto o il PaymentID non risulta correttamente impostato il valore restituito da <em>getPaymentID_NM</em> è <strong>false</strong>. Lo verifichiamo e proseguiamo.<br />
A questo punto posso recuperare i dati dell&#8217;ordine agganciando il PaymentID che mi ero registrato nel database in fase di PaymentInit. Recuperando i dati dal DB posso generare nuovamente il SecurityCode e verificarlo:</p>
<p><code>// set Security Code per verifica validità del Notification Message<br />
$pg-&gt;setSecurityCode_PI( $secCode );<br />
// Verifico autenticità del NotificationMessage<br />
if( $pg-&gt;<strong>isValid_NM</strong>() ) {</code></p>
<p>Il metodo <em>isValid_NM</em> si occupa della verifica del <em>SecurityCode</em>. Controlla quello passato dal metodo <em>setSecurityCode_PI</em> con quello appena ricevuto dai dati POST.<br />
Una volta superata questa verifica i nostri dati sono stati validati e possiamo ora procedere alla verifica dell&#8217;esito della transazione.<br />
Nel caso abbia avuto <strong>esisto positivo</strong> avremo:</p>
<p><code> # Transazione Elaborata<br />
if( $pg-&gt;isTransGood_NM() &amp;&amp;<br />
$arRp["stato"] == "PAYMENT_INIT" &amp;&amp;<br />
$pg-&gt;getVal_NM("trackid") == $idp		// Verifico idp<br />
) {<br />
// OK, Registro STATO e dati TRANSAZIONE nel DB<br />
$stato = $pg-&gt;getVal_NM("result");<br />
$TranID = $pg-&gt;getVal_NM("tranid");<br />
$Auth = $pg-&gt;getVal_NM("auth");<br />
mysql_query("UPDATE .... SET ....");<br />
// Verifico se elaborare l'ordine o meno a seconda del campo result</code></p>
<p>Per prima cosa verifichiamo con <strong>isTransGood_NM</strong> l&#8217;esito positivo della transazione. Poi (vedi documentazione del Gateway a pag.18) controlliamo che effettivamente sia il primo NotificationMessage che riceviamo. Potrebbero verificarsi dei casi in cui ne vengono inviati anche più di uno. La documentazione a riguardo dice di <strong>considerare attendibile sempre e solo il primo.</strong> Noi quindi, verificando lo stato, ci assicuriamo di ciò (lo stato infatti viene poi modificato e il secondo eventuale NotificationMessage non passa). Superati questi controlli possiamo prelevare i dati con il metodo <strong>getVal_NM</strong> (vedi documentazione del Gateway per elenco dei campi disponibili).</p>
<p><strong>Attenzione</strong>: fino ad ora abbiamo parlato di <strong>esito della transazione</strong>. Parliamo in termini di <strong>elaborazione effettuata</strong> e non di effettivo accredito dell&#8217;importo prelevato dalla carta di credito (esito dell&#8217;acquisto). Per questo esistono altri metodi che controllano il <strong>campo result</strong> dei dati inviati tramite NotificationMessage.<br />
I metodi sono diversi in base al valore che il campo result può assumere:</p>
<ul>
<li><strong>isCaptured_NM</strong>()</li>
<li><strong>isNotCaptured_NM</strong>()</li>
<li><strong>isApproved_NM</strong>()</li>
<li><strong>isNotApproved_NM</strong>()</li>
<li><strong>isDeniedByRisk_NM</strong>()</li>
<li><strong>isHostTimeout_NM</strong>()</li>
</ul>
<p>Nel nostro caso (Action = <strong>Purchase</strong>) il valore che corrisponde all&#8217;effettivo accredito dell&#8217;importo è “<strong>CAPTURED</strong>”.</p>
<p>Nel caso in cui la transazione invece dovesse avere esito negativo la funzione <strong>isTransError_NM</strong> restituisce true e noi possiamo procedere alla registrazione dell&#8217;errore nel DB:</p>
<p><code># Transazione NON Elaborata a causa di errori tecnici<br />
if( $pg-&gt;isTransError_NM() ) {<br />
// ERROR, Registro Errore nel DB</code></p>
<p>Anche in questo caso registro comunque lo <strong>stato ERROR</strong> nel campo del mio ordine (questo per quanto spiegato sopra sul discorso di un eventuale doppio NotificationMessage) e anche l&#8217;eventuale errore recuperato con <em>getVal_NM(&#8220;ErrorText&#8221;)</em>.<br />
A questo punto non resta che comunicare al Gateway l&#8217;URL verso cui deve redirezionare il Cardholder:</p>
<p><code>// Restituisco al Gateway l'URL su cui redirezionare il Cardholder<br />
echo "REDIRECT=". $pg-&gt;getURL_NM();</code></p>
<p>Il metodo <strong>getURL_NM</strong> restituisce il <em>goodURL</em> o <em>errorURL</em> a seconda che l&#8217;esito della transazione sia positivo o negativo. Esso considera inoltre, <strong>in base all&#8217;action impostato</strong>, anche l&#8217;esito dell&#8217;acquisto (accredito importo).</p>
<p>A questo punto si concludono anche le operazioni del NotificationMessage.<br />
Resta un&#8217;ultima considerazione da fare come ben rappresentanto nella documentazione del Gateway (pag. 23).</p>
<h4>Se il NotificationMessage non viene eseguito regolarmente</h4>
<p>Cosa accade se, ad esempio, il Gateway invia il messaggio ma per qualsiasi motivo<strong> il server del Merchant non lo riceve?</strong><br />
In questo caso, sia che la transazione abbia esito positivo, sia negativo, <strong>il Gateway reindirizza il Cardholder verso la pagina ErrorURL</strong>. In questo caso l&#8217;utente vede esisto negativo mentre la transazione magari è andata a buon fine e, ad esempio, anche l&#8217;esito dell&#8217;acquisto è positivo (con tanto di accredito dell&#8217;importo).<br />
Come da documentazione:</p>
<blockquote><p>E’ quindi importante che <strong>il Merchant prepari l’ErrorURL</strong> in modo tale da <strong>ricavare informazioni utili</strong> per poter investigare l’accaduto e <strong>informare successivamente il Cardholder</strong> sull’esito dell’acquisto.</p></blockquote>
<p>- -</p>
<p>Bene, siamo giunti alla fine del Tutorial.<br />
Spero di implementare presto anche la tipologia di messaggio Payment (per operazioni in differita tra Merchant e Gateway, es: storno, riaccredito, ecc.).</p>
<p>Nel frattempo spero che questo <strong>Tutorial</strong> sia risultato chiaro e utile.<br />
Buon lavoro! <img src='http://www.m4ss.net/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<div id="crp_related"><h2>Articoli correlati:</h2><ul><li><a href="http://www.m4ss.net/2010/05/12/payment-gateway-del-consorzio-triveneto-aggiornamento-1-3/" rel="bookmark" class="crp_title">Payment Gateway del Consorzio Triveneto (Aggiornamento 1.3)</a></li><li><a href="http://www.m4ss.net/2011/11/02/xt-commerce-plugin-payment-gateway-consorzio-triveneto/" rel="bookmark" class="crp_title">XT:Commerce, plugin Payment Gateway Consorzio Triveneto</a></li><li><a href="http://www.m4ss.net/2009/11/17/tutorial-multilingua-consorzio-triveneto-payment-gateway-tutorial/" rel="bookmark" class="crp_title">Tutorial per uso multilingua del Payment Gateway del Consorzio Triveneto</a></li><li><a href="http://www.m4ss.net/2009/11/03/modbus-e-php/" rel="bookmark" class="crp_title">Modbus e PHP</a></li><li><a href="http://www.m4ss.net/2009/08/31/zend-framework-teoria-di-base-front-controller-action/" rel="bookmark" class="crp_title">Zend Framework, teoria di base (Controller)</a></li></ul></div>  ]]></content:encoded>
			<wfw:commentRss>http://www.m4ss.net/2009/10/01/consorzio-triveneto-payment-gateway-tutorial/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

