Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
// This file is part of Moodle - http://moodle.org/
2
//
3
// Moodle is free software: you can redistribute it and/or modify
4
// it under the terms of the GNU General Public License as published by
5
// the Free Software Foundation, either version 3 of the License, or
6
// (at your option) any later version.
7
//
8
// Moodle is distributed in the hope that it will be useful,
9
// but WITHOUT ANY WARRANTY; without even the implied warranty of
10
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
// GNU General Public License for more details.
12
//
13
// You should have received a copy of the GNU General Public License
14
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
15
 
16
/**
17
 * PayPal repository module to encapsulate all of the AJAX requests that can be sent for PayPal.
18
 *
19
 * @module     paygw_paypal/repository
20
 * @copyright  2020 Shamim Rezaie <shamim@moodle.com>
21
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
22
 */
23
 
24
import Ajax from 'core/ajax';
25
 
26
/**
27
 * Return the PayPal JavaScript SDK URL.
28
 *
29
 * @param {string} component Name of the component that the itemId belongs to
30
 * @param {string} paymentArea The area of the component that the itemId belongs to
31
 * @param {number} itemId An internal identifier that is used by the component
32
 * @returns {Promise<{clientid: string, brandname: string, cost: number, currency: string}>}
33
 */
34
export const getConfigForJs = (component, paymentArea, itemId) => {
35
    const request = {
36
        methodname: 'paygw_paypal_get_config_for_js',
37
        args: {
38
            component,
39
            paymentarea: paymentArea,
40
            itemid: itemId,
41
        },
42
    };
43
 
44
    return Ajax.call([request])[0];
45
};
46
 
47
/**
48
 * Call server to validate and capture payment for order.
49
 *
50
 * @param {string} component Name of the component that the itemId belongs to
51
 * @param {string} paymentArea The area of the component that the itemId belongs to
52
 * @param {number} itemId An internal identifier that is used by the component
53
 * @param {string} orderId The order id coming back from PayPal
54
 * @returns {*}
55
 */
56
export const markTransactionComplete = (component, paymentArea, itemId, orderId) => {
57
    const request = {
58
        methodname: 'paygw_paypal_create_transaction_complete',
59
        args: {
60
            component,
61
            paymentarea: paymentArea,
62
            itemid: itemId,
63
            orderid: orderId,
64
        },
65
    };
66
 
67
    return Ajax.call([request])[0];
68
};