ILIAS  release_8 Revision v8.24
class.ilLearningSequenceSettingsDB.php
Go to the documentation of this file.
1<?php
2
3declare(strict_types=1);
4
25{
26 public const TABLE_NAME = 'lso_settings';
27
30
32 {
33 $this->database = $database;
34 $this->ls_filesystem = $ls_filesystem;
35 }
36
38 {
39 $uploads = $settings->getUploads();
40 foreach ($uploads as $pre => $info) {
41 $settings = $this->ls_filesystem->moveUploaded($pre, $info, $settings);
42 }
43
44 $deletions = $settings->getDeletions();
45 foreach ($deletions as $pre) {
46 $settings = $this->ls_filesystem->delete_image($pre, $settings);
47 }
48
49 $where = [
50 "obj_id" => ["integer", $settings->getObjId()]
51 ];
52
53 $values = [
54 "abstract" => ["text", $settings->getAbstract()],
55 "extro" => ["text", $settings->getExtro()],
56 "abstract_image" => ["text", $settings->getAbstractImage()],
57 "extro_image" => ["text", $settings->getExtroImage()],
58 "gallery" => ["integer", $settings->getMembersGallery()]
59 ];
60
61 $this->database->update(static::TABLE_NAME, $values, $where);
62 }
63
64 public function delete(int $obj_id): void
65 {
66 $settings = $this->getSettingsFor($obj_id);
67
69 $settings = $this->ls_filesystem->delete_image($pre, $settings);
70 }
71
72 $query =
73 "DELETE FROM " . static::TABLE_NAME . PHP_EOL
74 . "WHERE obj_id = " . $this->database->quote($obj_id, "integer") . PHP_EOL
75 ;
76
77 $this->database->manipulate($query);
78 }
79
80 public function getSettingsFor(int $lso_obj_id): ilLearningSequenceSettings
81 {
82 $data = $this->select($lso_obj_id);
83
84 if (count($data) == 0) {
85 $settings = $this->buildSettings($lso_obj_id);
86 $this->insert($settings);
87 } else {
88 $settings = $this->buildSettings(
89 $lso_obj_id,
90 $data['abstract'],
91 $data['extro'],
92 $data['abstract_image'],
93 $data['extro_image'],
94 (bool) $data['gallery']
95 );
96 }
97
98 return $settings;
99 }
100
104 protected function select(int $obj_id): array
105 {
106 $ret = [];
107 $query =
108 "SELECT abstract, extro, abstract_image, extro_image, gallery" . PHP_EOL
109 . "FROM " . static::TABLE_NAME . PHP_EOL
110 . "WHERE obj_id = " . $this->database->quote($obj_id, "integer") . PHP_EOL
111 ;
112
113 $result = $this->database->query($query);
114
115 if ($this->database->numRows($result) !== 0) {
116 // TODO PHP8 Review: Check array building, should be $ret[] = ... IMO
117 $ret = $this->database->fetchAssoc($result);
118 }
119
120 return $ret;
121 }
122
123 protected function buildSettings(
124 int $obj_id,
125 string $abstract = '',
126 string $extro = '',
127 string $abstract_image = null,
128 string $extro_image = null,
129 bool $gallery = false
132 $obj_id,
133 $abstract,
134 $extro,
135 $abstract_image,
136 $extro_image,
137 $gallery
138 );
139 }
140
142 {
143 $values = [
144 "obj_id" => ["integer", $settings->getObjId()],
145 "abstract" => ["text", $settings->getAbstract()],
146 "extro" => ["text", $settings->getExtro()],
147 "gallery" => ["integer", $settings->getMembersGallery()]
148 ];
149 $this->database->insert(static::TABLE_NAME, $values);
150 }
151}
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
buildSettings(int $obj_id, string $abstract='', string $extro='', string $abstract_image=null, string $extro_image=null, bool $gallery=false)
store(ilLearningSequenceSettings $settings)
__construct(ilDBInterface $database, ilLearningSequenceFilesystem $ls_filesystem)
insert(ilLearningSequenceSettings $settings)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
return['3gp', '7z', 'ai', 'aif', 'aifc', 'aiff', 'au', 'arw', 'avi', 'backup', 'bak', 'bas', 'bpmn', 'bpmn2', 'bmp', 'bib', 'bibtex', 'bz', 'bz2', 'c', 'c++', 'cc', 'cct', 'cdf', 'cer', 'class', 'cls', 'conf', 'cpp', 'crt', 'crs', 'crw', 'cr2', 'css', 'cst', 'csv', 'cur', 'db', 'dcr', 'des', 'dng', 'doc', 'docx', 'dot', 'dotx', 'dtd', 'dvi', 'el', 'eps', 'epub', 'f', 'f77', 'f90', 'flv', 'for', 'g3', 'gif', 'gl', 'gan', 'ggb', 'gsd', 'gsm', 'gtar', 'gz', 'gzip', 'h', 'hpp', 'htm', 'html', 'htmls', 'ibooks', 'ico', 'ics', 'ini', 'ipynb', 'java', 'jbf', 'jpeg', 'jpg', 'js', 'jsf', 'jso', 'json', 'latex', 'lang', 'less', 'log', 'lsp', 'ltx', 'm1v', 'm2a', 'm2v', 'm3u', 'm4a', 'm4v', 'markdown', 'm', 'mat', 'md', 'mdl', 'mdown', 'mid', 'min', 'midi', 'mobi', 'mod', 'mov', 'movie', 'mp2', 'mp3', 'mp4', 'mpa', 'mpeg', 'mpg', 'mph', 'mpga', 'mpp', 'mpt', 'mpv', 'mpx', 'mv', 'mw', 'mv4', 'nb', 'nbp', 'nef', 'nif', 'niff', 'obj', 'obm', 'odt', 'ods', 'odp', 'odg', 'odf', 'oga', 'ogg', 'ogv', 'old', 'p', 'pas', 'pbm', 'pcl', 'pct', 'pcx', 'pdf', 'pgm', 'pic', 'pict', 'png', 'por', 'pov', 'project', 'properties', 'ppa', 'ppm', 'pps', 'ppsx', 'ppt', 'pptx', 'ppz', 'ps', 'psd', 'pwz', 'qt', 'qtc', 'qti', 'qtif', 'r', 'ra', 'ram', 'rar', 'rast', 'rda', 'rev', 'rexx', 'ris', 'rf', 'rgb', 'rm', 'rmd', 'rmi', 'rmm', 'rmp', 'rt', 'rtf', 'rtx', 'rv', 's', 's3m', 'sav', 'sbs', 'sec', 'sdml', 'sgm', 'sgml', 'smi', 'smil', 'srt', 'sps', 'spv', 'stl', 'svg', 'swa', 'swf', 'swz', 'tar', 'tex', 'texi', 'texinfo', 'text', 'tgz', 'tif', 'tiff', 'ttf', 'txt', 'tmp', 'uvproj', 'vdf', 'vimeo', 'viv', 'vivo', 'vrml', 'vsdx', 'wav', 'webm', 'wmv', 'wmx', 'wmz', 'woff', 'wwd', 'xhtml', 'xif', 'xls', 'xlsx', 'xmind', 'xml', 'xsl', 'xsd', 'zip']
Interface ilDBInterface.
array $settings
Setting values (LTI parameters, custom parameters and local parameters).
Definition: System.php:200
$query