moodle_local_treestudyplan/classes/studyitemconnection.php
2023-05-17 21:19:14 +02:00

110 lines
2.9 KiB
PHP

<?php
namespace local_treestudyplan;
require_once($CFG->libdir.'/externallib.php');
class studyitemconnection {
const TABLE = "local_treestudyplan_connect";
private $r;
private $id;
protected function __construct($r){
$this->r = $r;
$this->id = $r->id;
}
public static function structure($value=VALUE_REQUIRED){
return new \external_single_structure([
'id' => new \external_value(PARAM_INT, 'id of connection'),
'from_id' => new \external_value(PARAM_INT, 'id of start item'),
'to_id' => new \external_value(PARAM_INT, 'id of end item'),
],'',$value);
}
public function model(){
return ['id' => $this->r->id, 'from_id' => $this->r->from_id, 'to_id' => $this->r->to_id];
}
public function from_item(){
return studyitem::findById($this->r->from_id);
}
public function to_item(){
return studyitem::findById($this->r->to_id);
}
public function from_id(){
return $this->r->from_id;
}
public function to_id(){
return $this->r->to_id;
}
public static function find_outgoing($item_id){
global $DB;
$list = [];
$conn_out = $DB->get_records(self::TABLE,['from_id' => $item_id]);
foreach($conn_out as $c) {
$list[] = new self($c);
}
return $list;
}
public static function find_incoming($item_id){
global $DB;
$list = [];
$conn_in = $DB->get_records(self::TABLE,['to_id' => $item_id]);
foreach($conn_in as $c) {
$list[] = new self($c);
}
return $list;
}
public static function connect($from_id,$to_id)
{
global $DB;
//check if link already exists
if(!$DB->record_exists(self::TABLE, ['from_id' => $from_id, 'to_id' => $to_id]))
{
$id = $DB->insert_record(self::TABLE, [
'from_id' => $from_id,
'to_id' => $to_id,
]);
return new self($DB->get_record(self::TABLE,['id' => $id]));
} else {
return new self($DB->get_record(self::TABLE,['from_id' => $from_id, 'to_id' => $to_id]));
}
}
public static function disconnect($from_id,$to_id)
{
global $DB;
if($DB->record_exists(self::TABLE, ['from_id' => $from_id, 'to_id' => $to_id]))
{
$DB->delete_records(self::TABLE, [
'from_id' => $from_id,
'to_id' => $to_id,
]);
return success::success('Items Disconnected');
} else {
return success::success('Connection does not exist');
}
}
public static function clear($id) {
global $DB;
$DB->delete_records(self::TABLE, ['from_id' => $id]);
$DB->delete_records(self::TABLE, ['to_id' => $id]);
}
}