This repository has been archived on 2025-01-01. You can view files and clone it, but cannot push or open issues or pull requests.
moodle-local_treestudyplan/classes/local/forms/formbase.php

76 lines
2.7 KiB
PHP
Raw Normal View History

<?php
namespace local_treestudyplan\local\forms;
use moodleform;
abstract class formbase extends moodleform {
/**
* Create the form while providing the correct defaults for our type of forms
* @param array $ajaxformdata Provide submitted form data through Ajax here
2023-10-20 14:03:13 +02:00
* @throws \moodle_exception if parameters are invalid or access is denied for a specific reason.
*/
2023-10-20 14:03:13 +02:00
public function __construct($params, $ajaxformdata=null) {
$customdata = static::init_customdata($params);
if (static::check_security($customdata)) {
parent::__construct(null, (array)$customdata, 'post', '', null, true, $ajaxformdata);
// Initialize the initial data based on the parameter validation
$this->set_data($this->init_formdata((object)$this->_customdata));
} else {
throw new \moodle_exception('accessexception', 'core');
}
}
2023-10-20 14:03:13 +02:00
/**
2023-10-20 14:03:13 +02:00
* Generate custom data from parameters
* Also validate parameters and access permissions here
*
2023-10-19 17:48:43 +02:00
* @param object $params The parameters for form initialization
2023-10-20 14:03:13 +02:00
* @return object Form data based on parameters
*/
abstract public static function init_customdata(object $params);
/**
* Generate form data from parameters
* Also validate parameters and access permissions here
*
* @param object $customdata The parameters for form initialization
* @return array Form data based on parameters
*/
2023-10-20 14:03:13 +02:00
abstract public function init_formdata(object $customdata);
/**
* Validate security access for this form based on the provided parameters
* Return true if validation passes, false or throw an exception if it does not.
*
2023-10-19 17:48:43 +02:00
* @param object $params The parameters for form initialization
* @return bool True if security validation passes.
* @throws \moodle_exception if access denied for a specific reason.
*/
2023-10-20 14:03:13 +02:00
abstract public static function check_security(object $customdata);
/**
* Process the submission and perform necessary actions
2023-10-20 14:03:13 +02:00
* @param object $entry The processed form data
* @return bool True if submission successful
* @throws \moodle_exception if an error must be given for a specific reason.
*/
2023-10-20 14:03:13 +02:00
abstract protected function process_submitted_data(object $entry);
/**
* Process the submission and perform necessary actions
* @return bool True if submission successful
* @throws \moodle_exception if an error must be given for a specific reason.
*/
public function process_submission() {
$data = $this->get_data();
if($data) {
$this->process_submitted_data($data);
}
}
}