f0985b5ea1d6f0afa12cd554674bd997fc8f1a7b
2 /***************************************************************************
3 * Copyright (C) 2003-2010 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the Free Software *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
26 var $nomsite = "PayPal";
33 $this->val_number
= $val;
36 function prepareform(&$pay)
39 // https://www.paypal.com/developer
40 // Warning: the automatic return only works if we force the
41 // users to create a paypal account. We do not use it; thus
42 // the user must come back on the site.
43 global $globals, $platal;
45 $this->urlform
= 'https://' . $globals->money
->paypal_site
. '/cgi-bin/webscr';
48 $roboturl = str_replace("https://","http://",$globals->baseurl
)
49 . '/' . $platal->ns
. "payment/paypal_return/" . S
::v('uid')
50 . "?comment=" . urlencode(Env
::v('comment'));
53 'commercant' => array(
54 'business' => $globals->money
->paypal_compte
,
56 'return' => $roboturl,
57 'cn' => 'Commentaires',
59 'cbt' => empty($GLOBALS['IS_XNET_SITE']) ?
'Revenir sur polytechnique.org.' : 'Revenir sur polytechnique.net.'
64 'first_name' => $user->firstName(),
65 'last_name' => $user->lastName(),
66 'email' => $user->bestEmail()
69 $res = XDB
::query("SELECT pa.text, gl.name AS city, pa.postalCode AS zip, pa.countryId AS country,
70 IF(pp1.display_tel != '', pp1.display_tel, pp2.display_tel) AS night_phone_b
71 FROM profile_addresses AS pa
72 LEFT JOIN profile_phones AS pp1 ON (pp1.pid = pa.pid AND pp1.link_type = 'address'
73 AND pp1.link_id = pa.id)
74 LEFT JOIN profile_phones AS pp2 ON (pp2.pid = pa.pid AND pp2.link_type = 'user'
76 LEFT JOIN geoloc_localities AS gl ON (gl.id = pa.localityId)
77 WHERE pa.pid = {?} AND FIND_IN_SET('current', pa.flags)
79 $user->profile()->id());
80 $this->infos
['client'] = array_map('replace_accent', array_merge($info_client, $res->fetchOneAssoc()));
81 list($this->infos
['client']['address1'], $this->infos
['client']['address2']) =
82 explode("\n", Geocoder
::getFirstLines($this->infos
['client']['text'],
83 $this->infos
['client']['zip'], 2));
84 unset($this->infos
['client']['text']);
86 // We build the transaction's reference
87 $prefix = ($pay->flags
->hasflag('unique')) ?
str_pad("", 15, "0") : rand_url_id();
88 $fullref = substr("$prefix-xorg-{$pay->id}", -15);
90 $this->infos
['commande'] = array(
91 'item_name' => replace_accent($pay->text
),
92 'amount' => $this->val_number
,
93 'currency_code' => 'EUR',
97 $this->infos
['divers'] = array('cmd' => '_xclick');
103 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: