aba2f9a964f5a11b4739cf7711a693717b2adeef
2 /***************************************************************************
3 * Copyright (C) 2003-2011 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, $user)
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';
47 $roboturl = str_replace("https://","http://",$globals->baseurl
)
48 . '/' . $platal->ns
. "payment/paypal_return/" . S
::v('uid')
49 . "?comment=" . urlencode(Env
::v('comment')) . '?display=' . Post
::i('display');
52 'commercant' => array(
53 'business' => $globals->money
->paypal_compte
,
55 'return' => $roboturl,
56 'cn' => 'Commentaires',
58 'cbt' => empty($GLOBALS['IS_XNET_SITE']) ?
'Revenir sur polytechnique.org.' : 'Revenir sur polytechnique.net.'
63 'first_name' => $user->firstName(),
64 'last_name' => $user->lastName(),
65 'email' => $user->bestEmail()
68 if ($user->hasProfile()) {
69 $res = XDB
::query("SELECT pa.text, GROUP_CONCAT(pace2.short_name) AS city,
70 GROUP_CONCAT(pace3.short_name) AS zip, GROUP_CONCAT(pace1.short_name) AS country,
71 IF(pp1.display_tel != '', pp1.display_tel, pp2.display_tel) AS night_phone_b
72 FROM profile_addresses AS pa
73 LEFT JOIN profile_phones AS pp1 ON (pp1.pid = pa.pid AND pp1.link_type = 'address' AND pp1.link_id = pa.id)
74 LEFT JOIN profile_phones AS pp2 ON (pp2.pid = pa.pid AND pp2.link_type = 'user' AND pp2.link_id = 0)
75 LEFT JOIN profile_addresses_components AS pc ON (pa.pid = pc.pid AND pa.jobid = pc.jobid AND pa.groupid = pc.groupid
76 AND pa.type = pc.type AND pa.id = pc.id)
77 LEFT JOIN profile_addresses_components_enum AS pace1 ON (FIND_IN_SET('country', pace1.types) AND pace1.id = pc.component_id)
78 LEFT JOIN profile_addresses_components_enum AS pace2 ON (FIND_IN_SET('locality', pace2.types) AND pace2.id = pc.component_id)
79 LEFT JOIN profile_addresses_components_enum AS pace3 ON (FIND_IN_SET('postal_code', pace3.types) AND pace3.id = pc.component_id)
80 WHERE pa.pid = {?} AND FIND_IN_SET('current', pa.flags)
81 GROUP BY pa.pid, pa.jobid, pa.groupid, pa.id, pa.type
83 $user->profile()->id());
84 $this->infos
['client'] = array_map('replace_accent', array_merge($info_client, $res->fetchOneAssoc()));
85 list($this->infos
['client']['address1'], $this->infos
['client']['address2']) =
86 explode("\n", Geocoder
::getFirstLines($this->infos
['client']['text'],
87 $this->infos
['client']['zip'], 2));
88 unset($this->infos
['client']['text']);
90 $this->infos
['client'] = replace_accent($info_client);
93 // We build the transaction's reference
94 $prefix = ($pay->flags
->hasflag('unique')) ?
str_pad("", 15, "0") : rand_url_id();
95 $fullref = substr("$prefix-xorg-{$pay->id}", -15);
97 $this->infos
['commande'] = array(
98 'item_name' => replace_accent($pay->text
),
99 'amount' => $this->val_number
,
100 'currency_code' => 'EUR',
104 $this->infos
['divers'] = array('cmd' => '_xclick');
110 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: