| 1 | <?php |
| 2 | /*************************************************************************** |
| 3 | * Copyright (C) 2003-2013 Polytechnique.org * |
| 4 | * http://opensource.polytechnique.org/ * |
| 5 | * * |
| 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. * |
| 10 | * * |
| 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. * |
| 15 | * * |
| 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 * |
| 18 | * Foundation, Inc., * |
| 19 | * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * |
| 20 | ***************************************************************************/ |
| 21 | |
| 22 | class PayPal |
| 23 | { |
| 24 | var $val_number; |
| 25 | var $urlform; |
| 26 | var $nomsite = "PayPal"; |
| 27 | var $text; |
| 28 | |
| 29 | var $infos; |
| 30 | |
| 31 | function PayPal($val) |
| 32 | { |
| 33 | $this->val_number = $val; |
| 34 | } |
| 35 | |
| 36 | function prepareform($pay, $user) |
| 37 | { |
| 38 | // Documentation: |
| 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; |
| 44 | |
| 45 | $this->urlform = 'https://' . $globals->money->paypal_site . '/cgi-bin/webscr'; |
| 46 | |
| 47 | $roboturl = str_replace("https://","http://",$globals->baseurl) |
| 48 | . '/' . $platal->ns . "payment/paypal_return/" . $user->id() |
| 49 | . "?comment=" . urlencode(Env::v('comment')) . '&display=' . Post::i('display'); |
| 50 | |
| 51 | $this->infos = array( |
| 52 | 'commercant' => array( |
| 53 | 'business' => $globals->money->paypal_compte, |
| 54 | 'rm' => 2, |
| 55 | 'return' => $roboturl, |
| 56 | 'cn' => 'Commentaires', |
| 57 | 'no_shipping' => 1, |
| 58 | 'cbt' => empty($GLOBALS['IS_XNET_SITE']) ? 'Revenir sur polytechnique.org.' : 'Revenir sur polytechnique.net.' |
| 59 | ) |
| 60 | ); |
| 61 | |
| 62 | $info_client = array( |
| 63 | 'first_name' => $user->firstName(), |
| 64 | 'last_name' => $user->lastName(), |
| 65 | 'email' => $user->bestEmail() |
| 66 | ); |
| 67 | |
| 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 |
| 82 | LIMIT 1", |
| 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']); |
| 89 | } else { |
| 90 | $this->infos['client'] = replace_accent($info_client); |
| 91 | } |
| 92 | |
| 93 | // We build the transaction's reference |
| 94 | $prefix = rand_url_id(); |
| 95 | $fullref = substr("$prefix-xorg-{$pay->id}", -15); |
| 96 | |
| 97 | $this->infos['commande'] = array( |
| 98 | 'item_name' => replace_accent($pay->text), |
| 99 | 'amount' => $this->val_number, |
| 100 | 'currency_code' => 'EUR', |
| 101 | 'custom' => $fullref |
| 102 | ); |
| 103 | |
| 104 | $this->infos['divers'] = array('cmd' => '_xclick'); |
| 105 | } |
| 106 | } |
| 107 | |
| 108 | $api = 'PayPal'; |
| 109 | |
| 110 | // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: |
| 111 | ?> |