Proyectos de Subversion Moodle

Rev

Autoría | Ultima modificación | Ver Log |

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

namespace core_ai\form;

use moodleform;

defined('MOODLE_INTERNAL') || die();

require_once($CFG->libdir . '/formslib.php');

/**
 * AI provider instance form.
 *
 * @package    core_ai
 * @copyright  2024 Matt Porritt <matt.porritt@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class ai_provider_form extends moodleform {

    /**
     * Get the custom data.
     *
     * @return mixed The custom data.
     */
    public function get_customdata(): mixed {
        return $this->_customdata;
    }

    #[\Override]
    protected function definition() {
        global $PAGE;
        $PAGE->requires->js_call_amd('core_ai/providerchooser', 'init');

        $mform = $this->_form;
        $providerconfigs = $this->_customdata['providerconfigs'] ?? [];
        $returnurl = $this->_customdata['returnurl'] ?? null;

        // AI provider chooser.
        // Get all enabled AI provider plugins. Users can select one of them to create a new AI provider instance.
        $providerplugins = [];
        $enabledproviderplugins = \core\plugininfo\aiprovider::get_enabled_plugins();
        foreach ($enabledproviderplugins as $pluginname => $notusing) {
            $plugin = 'aiprovider_' . $pluginname;
            $providerplugins[$plugin] = get_string('pluginname', $plugin);
        }

        // Provider chooser.
        $mform->addElement(
            'select',
            'aiprovider',
            get_string('providertype', 'core_ai'),
            $providerplugins,
            ['data-aiproviderchooser-field' => 'selector'],
        );
        if (isset($providerconfigs['id'])) {
            $mform->hardFreeze('aiprovider');
        }

        // Provider instance name.
        $mform->addElement(
            'text',
            'name',
            get_string('providername', 'core_ai'),
            'maxlength="255" size="20"',
        );
        $mform->setType('name', PARAM_TEXT);
        $mform->addRule('name', get_string('required'), 'required', null, 'client');
        $mform->addRule('name', get_string('maximumchars', '', 255), 'maxlength', 255);

        $mform->registerNoSubmitButton('updateaiprovider');
        $mform->addElement(
            'submit',
            'updateaiprovider',
            'update AI provider',
            ['data-aiproviderchooser-field' => 'updateButton', 'class' => 'd-none']
        );

        // Dispatch a hook for plugins to add their fields.
        $providerplugindefault = array_key_first($providerplugins);
        $hook = new \core_ai\hook\after_ai_provider_form_hook(
            mform: $mform,
            plugin: $providerconfigs['aiprovider'] ?? $providerplugindefault,
        );
        \core\di::get(\core\hook\manager::class)->dispatch($hook);

        // Add the provider plugin name to form customdata.
        $this->_customdata['aiprovider'] = $hook->plugin;

        // Add rate limiting settings.
        // Setting to enable/disable global rate limiting.
        $mform->addElement(
            'checkbox',
            'enableglobalratelimit',
            get_string('enableglobalratelimit', 'core_ai'),
            get_string('enableglobalratelimit_help', 'core_ai'),
        );
        // Setting to set how many requests per hour are allowed for the global rate limit.
        // Should only be enabled when global rate limiting is enabled.
        $mform->addElement(
            'text',
            'globalratelimit',
            get_string('globalratelimit', 'core_ai'),
            'maxlength="10" size="4"',
        );
        $mform->setType('globalratelimit', PARAM_INT);
        $mform->addHelpButton('globalratelimit', 'globalratelimit', 'core_ai');
        $mform->hideIf('globalratelimit', 'enableglobalratelimit', 'notchecked');

        // Setting to enable/disable user rate limiting.
        $mform->addElement(
            'checkbox',
            'enableuserratelimit',
            get_string('enableuserratelimit', 'core_ai'),
            get_string('enableuserratelimit_help', 'core_ai'),
        );
        // Setting to set how many requests per hour are allowed for the user rate limit.
        // Should only be enabled when user rate limiting is enabled.
        $mform->addElement(
            'text',
            'userratelimit',
            get_string('userratelimit', 'core_ai'),
            'maxlength="10" size="4"',
        );
        $mform->setType('userratelimit', PARAM_INT);
        $mform->addHelpButton('userratelimit', 'userratelimit', 'core_ai');
        $mform->hideIf('userratelimit', 'enableuserratelimit', 'notchecked');

        // Form buttons.
        $buttonarray = [];
        // If provider config is empty this is a new instance.
        if (empty($providerconfigs['id'])) {
            $buttonarray[] = $mform->createElement('submit', 'createandreturn',
                get_string('btninstancecreate', 'core_ai'));
        } else {
            // We're updating an existing provider.
            $buttonarray[] = $mform->createElement('submit', 'updateandreturn',
                get_string('btninstanceupdate', 'core_ai'));
        }

        $buttonarray[] = $mform->createElement('cancel');
        $mform->addGroup($buttonarray, 'buttonar', '', [' '], false);
        $mform->closeHeaderBefore('buttonar');

        if ($returnurl) {
            $mform->addElement('hidden', 'returnurl', $returnurl);
            $mform->setType('returnurl', PARAM_LOCALURL);
        }

        if (isset($providerconfigs['id'])) {
            $mform->addElement('hidden', 'id', $providerconfigs['id']);
            $mform->setType('id', PARAM_INT);
        }

        $this->set_data($providerconfigs);
    }

    #[\Override]
    public function validation($data, $files) {
        $errors = parent::validation($data, $files);

        // Ensure both global/user rate limits (if enabled) contain positive values.
        if (!empty($data['enableglobalratelimit']) && $data['globalratelimit'] <= 0) {
            $errors['globalratelimit'] = get_string('err_positiveint', 'core_form');
        }
        if (!empty($data['enableuserratelimit']) && $data['userratelimit'] <= 0) {
            $errors['userratelimit'] = get_string('err_positiveint', 'core_form');
        }

        return $errors;
    }
}