MDL-69166 core_payment: Use promises instead of callbacks
[moodle.git] / payment / gateway / paypal / amd / src / repository.js
CommitLineData
9a7aed4a
SR
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 *
6b3d163a
SR
19 * @module paygw_paypal/repository
20 * @package paygw_paypal
9a7aed4a
SR
21 * @copyright 2020 Shamim Rezaie <shamim@moodle.com>
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23 */
24
25import Ajax from 'core/ajax';
26
27/**
28 * Return the PayPal JavaScript SDK URL.
29 *
52305c9a
SR
30 * @param {string} component Name of the component that the itemId belongs to
31 * @param {string} paymentArea The area of the component that the itemId belongs to
32 * @param {number} itemId An internal identifier that is used by the component
0fb7847e 33 * @returns {Promise<{clientid: string, brandname: string, cost: number, currency: string}>}
9a7aed4a 34 */
52305c9a 35export const getConfigForJs = (component, paymentArea, itemId) => {
9a7aed4a 36 const request = {
6b3d163a 37 methodname: 'paygw_paypal_get_config_for_js',
7d10f352
SR
38 args: {
39 component,
40 paymentarea: paymentArea,
52305c9a 41 itemid: itemId,
7d10f352 42 },
9a7aed4a
SR
43 };
44
45 return Ajax.call([request])[0];
46};
0fb7847e
SR
47
48/**
49 * Call server to validate and capture payment for order.
50 *
51 * @param {string} component Name of the component that the itemId belongs to
52 * @param {string} paymentArea The area of the component that the itemId belongs to
53 * @param {number} itemId An internal identifier that is used by the component
54 * @param {string} orderId The order id coming back from PayPal
55 * @returns {*}
56 */
57export const markTransactionComplete = (component, paymentArea, itemId, orderId) => {
58 const request = {
59 methodname: 'paygw_paypal_create_transaction_complete',
60 args: {
61 component,
62 paymentarea: paymentArea,
63 itemid: itemId,
64 orderid: orderId,
65 },
66 };
67
68 return Ajax.call([request])[0];
69};