Commit | Line | Data |
---|---|---|
22c68a81 SR |
1 | <?php |
2 | // This file is part of Moodle - http://moodle.org/ | |
3 | // | |
4 | // Moodle is free software: you can redistribute it and/or modify | |
5 | // it under the terms of the GNU General Public License as published by | |
6 | // the Free Software Foundation, either version 3 of the License, or | |
7 | // (at your option) any later version. | |
8 | // | |
9 | // Moodle is distributed in the hope that it will be useful, | |
10 | // but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 | // GNU General Public License for more details. | |
13 | // | |
14 | // You should have received a copy of the GNU General Public License | |
15 | // along with Moodle. If not, see <http://www.gnu.org/licenses/>. | |
16 | ||
17 | /** | |
18 | * This file contains the \core_payment\local\local\callback\provider interface. | |
19 | * | |
20 | * Plugins should implement this if they use payment subsystem. | |
21 | * | |
22 | * @package core_payment | |
23 | * @copyright 2020 Shamim Rezaie <shamim@moodle.com> | |
24 | * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
25 | */ | |
26 | ||
27 | namespace core_payment\local\callback; | |
28 | ||
29 | defined('MOODLE_INTERNAL') || die(); | |
30 | ||
31 | /** | |
32 | * The provider interface for plugins to provide callbacks which are needed by the payment subsystem. | |
33 | * | |
34 | * @copyright 2020 Shamim Rezaie <shamim@moodle.com> | |
35 | * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | |
36 | */ | |
37 | interface provider { | |
38 | ||
39 | /** | |
61766b3d | 40 | * @param string $paymentarea |
d5a9d6e5 | 41 | * @param int $itemid An identifier that is known to the plugin |
6ff3087f | 42 | * @return array['amount' => float, 'currency' => string, 'accountid' => int] |
22c68a81 | 43 | */ |
d5a9d6e5 | 44 | public static function get_cost(string $paymentarea, int $itemid): array; |
22c68a81 SR |
45 | |
46 | /** | |
61766b3d | 47 | * @param string $paymentarea |
d5a9d6e5 | 48 | * @param int $itemid An identifier that is known to the plugin |
1d479dc0 | 49 | * @param int $paymentid payment id as inserted into the 'payments' table, if needed for reference |
22c68a81 SR |
50 | * @return bool Whether successful or not |
51 | */ | |
d5a9d6e5 | 52 | public static function deliver_order(string $paymentarea, int $itemid, int $paymentid): bool; |
22c68a81 | 53 | } |