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 * Contains base class for payment gateways. 19 * 20 * @package core_payment 21 * @copyright 2019 Shamim Rezaie <shamim@moodle.com> 22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 23 */ 24 25 namespace core_payment; 26 27 /** 28 * Base class for payment gateways. 29 * 30 * @copyright 2019 Shamim Rezaie <shamim@moodle.com> 31 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 32 */ 33 abstract class gateway { 34 /** 35 * Returns the list of currencies that the payment gateway supports. 36 * 37 * @return string[] An array of the currency codes in the three-character ISO-4217 format 38 */ 39 public abstract static function get_supported_currencies(): array; 40 41 /** 42 * Configuration form for the gateway instance 43 * 44 * Use $form->get_mform() to access the \MoodleQuickForm instance 45 * 46 * @param \core_payment\form\account_gateway $form 47 */ 48 public abstract static function add_configuration_to_gateway_form(\core_payment\form\account_gateway $form): void; 49 50 /** 51 * Validates the gateway configuration form. 52 * 53 * Needs to be overridden to make sure the incomplete configuration can not be enabled. 54 * 55 * @param \core_payment\form\account_gateway $form 56 * @param \stdClass $data 57 * @param array $files 58 * @param array $errors form errors (passed by reference) 59 */ 60 public static function validate_gateway_form(\core_payment\form\account_gateway $form, 61 \stdClass $data, array $files, array &$errors): void { 62 if ($data->enabled) { 63 $errors['enabled'] = get_string('gatewaycannotbeenabled', 'payment'); 64 } 65 } 66 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body