ILIAS  trunk Revision v11.0_alpha-1702-gfd3ecb7f852
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilBadgeImageTemplate.php
Go to the documentation of this file.
1 <?php
2 
24 
26 {
27  protected ilDBInterface $db;
28  protected int $id = 0;
29  protected string $title = "";
30  protected string $image = "";
31  protected ?string $image_rid = "";
33  protected ?array $types = null;
37 
38  public function __construct(?int $a_id = null)
39  {
40  global $DIC;
41 
42  $this->resource_storage = $DIC->resourceStorage();
43  $this->upload_service = $DIC->upload();
44  $this->main_template = $DIC->ui()->mainTemplate();
45  $this->db = $DIC->database();
46  if ($a_id) {
47  $this->read($a_id);
48  }
49  }
50 
54  public static function getInstances(): array
55  {
56  global $DIC;
57 
58  $ilDB = $DIC->database();
59 
60  $res = array();
61 
62  $types = array();
63  $set = $ilDB->query("SELECT * FROM badge_image_templ_type");
64  while ($row = $ilDB->fetchAssoc($set)) {
65  $types[$row["tmpl_id"]][] = $row["type_id"];
66  }
67 
68  $set = $ilDB->query("SELECT * FROM badge_image_template" .
69  " ORDER BY title");
70  while ($row = $ilDB->fetchAssoc($set)) {
71  $row["types"] = (array) ($types[$row["id"]] ?? null);
72 
73  $obj = new self();
74  $obj->importDBRow($row);
75  $res[] = $obj;
76  }
77 
78  return $res;
79  }
80 
84  public static function getInstancesByType(string $a_type_unique_id): array
85  {
86  $res = [];
87 
88  foreach (self::getInstances() as $tmpl) {
89  if (!count($tmpl->getTypes()) || in_array($a_type_unique_id, $tmpl->getTypes(), true)) {
90  $res[] = $tmpl;
91  }
92  }
93 
94  return $res;
95  }
96 
97 
98  //
99  // setter/getter
100  //
101 
102  protected function setId(int $a_id): void
103  {
104  $this->id = $a_id;
105  }
106 
107  public function getId(): int
108  {
109  return $this->id;
110  }
111 
112  public function setTitle(string $a_value): void
113  {
114  $this->title = trim($a_value);
115  }
116 
117  public function getTitle(): string
118  {
119  return $this->title;
120  }
121 
122  protected function setImage(?string $a_value): void
123  {
124  if ($a_value !== null) {
125  $this->image = trim($a_value);
126  }
127  }
128 
132  public function getTypes(): ?array
133  {
134  return $this->types;
135  }
136 
137  public function setTypes(?array $types = null): void
138  {
139  $this->types = is_array($types)
140  ? array_unique($types)
141  : null;
142  }
143 
144  public function getImage(): string
145  {
146  return $this->image;
147  }
148 
153  public function uploadImage(array $a_upload_meta): void
154  {
155  if ($this->getId() &&
156  $a_upload_meta["tmp_name"]) {
157  $path = $this->getFilePath($this->getId());
158 
159  $filename = ilFileUtils::getValidFilename($a_upload_meta["name"]);
160 
161  $exp = explode(".", $filename);
162  $suffix = strtolower(array_pop($exp));
163  $tgt = $path . "img" . $this->getId() . "." . $suffix;
164 
165  if (ilFileUtils::moveUploadedFile($a_upload_meta["tmp_name"], "img" . $this->getId() . "." . $suffix, $tgt)) {
166  $this->setImage($filename);
167  $this->update();
168  }
169  }
170  }
171 
172  public function processImageUpload(ilBadgeImageTemplate $badge): void
173  {
174  try {
175  if (!$this->upload_service->hasBeenProcessed()) {
176  $this->upload_service->process();
177  }
178  if ($this->upload_service->hasUploads()) {
179  $array_result = $this->upload_service->getResults();
180  $array_result = array_pop($array_result);
181  if ($array_result->getName() !== '') {
182  $this->resource_storage->manage()->remove(new ResourceIdentification($badge->getImageRid()), new ilBadgeFileStakeholder());
183  $stakeholder = new ilBadgeFileStakeholder();
184  $identification = $this->resource_storage->manage()->upload($array_result, $stakeholder);
185  $this->resource_storage->flavours()->ensure($identification, new \ilBadgePictureDefinition());
186  $badge->setImageRid($identification);
187  $badge->update();
188  }
189  }
190  } catch (IllegalStateException $e) {
191  $this->main_template->setOnScreenMessage('failure', $e->getMessage(), true);
192  }
193  }
194 
195  public function getImagePath(): string
196  {
197  if ($this->getId()) {
198  if (is_file($this->getFilePath($this->getId()) . "img" . $this->getId())) { // formerly (early 5.2 versino), images have been uploaded with no suffix
199  return $this->getFilePath($this->getId()) . "img" . $this->getId();
200  }
201 
202  $exp = explode(".", $this->getImage());
203  $suffix = strtolower(array_pop($exp));
204  return $this->getFilePath($this->getId()) . "img" . $this->getId() . "." . $suffix;
205  }
206  return "";
207  }
208 
212  protected function getFilePath(
213  int $a_id,
214  ?string $a_subdir = null
215  ): string {
216  $storage = new ilFSStorageBadgeImageTemplate($a_id);
217  $storage->create();
218 
219  $path = $storage->getAbsolutePath() . "/";
220 
221  if ($a_subdir) {
222  $path .= $a_subdir . "/";
223 
224  if (!is_dir($path)) {
225  mkdir($path);
226  }
227  }
228 
229  return $path;
230  }
231 
232 
233  //
234  // crud
235  //
236 
237  protected function read(int $a_id): void
238  {
239  $ilDB = $this->db;
240 
241  $set = $ilDB->query("SELECT * FROM badge_image_template" .
242  " WHERE id = " . $ilDB->quote($a_id, "integer"));
243  if ($ilDB->numRows($set)) {
244  $row = $ilDB->fetchAssoc($set);
245  $row["types"] = $this->readTypes($a_id);
246  $this->importDBRow($row);
247  }
248  }
249 
250  protected function readTypes(int $a_id): ?array
251  {
252  $ilDB = $this->db;
253 
254  $res = array();
255 
256  $set = $ilDB->query("SELECT * FROM badge_image_templ_type WHERE tmpl_id = " . $ilDB->quote($a_id, "integer"));
257  while ($row = $ilDB->fetchAssoc($set)) {
258  $res[] = $row["type_id"];
259  }
260 
261  if (!count($res)) {
262  $res = null;
263  }
264 
265  return $res;
266  }
267 
268  protected function importDBRow(array $a_row): void
269  {
270  $this->setId($a_row["id"]);
271  $this->setTitle($a_row["title"]);
272  if (isset($a_row["image"])) {
273  $this->setImage($a_row["image"]);
274  }
275  if (isset($a_row["image_rid"])) {
276  $this->setImageRid($a_row["image_rid"]);
277  }
278  $this->setTypes($a_row["types"]);
279  }
280 
281  public function create(): void
282  {
283  $ilDB = $this->db;
284 
285  if ($this->getId()) {
286  $this->update();
287  return;
288  }
289 
290  $id = $ilDB->nextId("badge_image_template");
291  $this->setId($id);
292 
293  $fields = $this->getPropertiesForStorage();
294  $fields["id"] = array("integer", $id);
295 
296  $ilDB->insert("badge_image_template", $fields);
297 
298  $this->saveTypes();
299  }
300 
301  public function update(): void
302  {
303  $ilDB = $this->db;
304 
305  if (!$this->getId()) {
306  $this->create();
307  return;
308  }
309 
310  $fields = $this->getPropertiesForStorage();
311 
312  $ilDB->update(
313  "badge_image_template",
314  $fields,
315  array("id" => array("integer", $this->getId()))
316  );
317 
318  $this->saveTypes();
319  }
320 
321  public function delete(): void
322  {
323  $ilDB = $this->db;
324 
325  if (!$this->getId()) {
326  return;
327  }
328 
329  $path = $this->getFilePath($this->getId());
331 
332  $ilDB->manipulate("DELETE FROM badge_image_template" .
333  " WHERE id = " . $ilDB->quote($this->getId(), "integer"));
334  }
335 
339  protected function getPropertiesForStorage(): array
340  {
341  return [
342  "title" => ["text", $this->getTitle()],
343  "image" => ["text", $this->getImage()],
344  "image_rid" => ["text", $this->getImageRid()]
345  ];
346  }
347 
348  protected function saveTypes(): void
349  {
350  $ilDB = $this->db;
351 
352  if ($this->getId()) {
353  $ilDB->manipulate("DELETE FROM badge_image_templ_type" .
354  " WHERE tmpl_id = " . $ilDB->quote($this->getId(), "integer"));
355 
356  if ($this->getTypes()) {
357  foreach ($this->getTypes() as $type) {
358  $fields = array(
359  "tmpl_id" => array("integer", $this->getId()),
360  "type_id" => array("text", $type)
361  );
362  $ilDB->insert("badge_image_templ_type", $fields);
363  }
364  }
365  }
366  }
367 
368  public function getImageRid(): ?string
369  {
370  return $this->image_rid;
371  }
372 
373  public function setImageRid(?string $image_rid = null): void
374  {
375  $this->image_rid = $image_rid;
376  }
377 
378  public function getImageFromResourceId(
379  int $size = ilBadgeImage::IMAGE_SIZE_XS
380  ): string {
381  $image_src = '';
382 
383  if ($this->getImageRid()) {
384  $identification = $this->resource_storage->manage()->find($this->getImageRid());
385  if ($identification !== null) {
386  $flavour = $this->resource_storage->flavours()->get($identification, new ilBadgePictureDefinition());
387  $urls = $this->resource_storage->consume()->flavourUrls($flavour)->getURLsAsArray();
388  if (count($urls) === ilBadgeImage::IMAGE_URL_COUNT && isset($urls[$size])) {
389  $image_src = $urls[$size];
390  }
391  }
392  } elseif ($this->getImage()) {
393  $image_src = ilWACSignedPath::signFile($this->getImagePath());
394  }
395 
396  return $image_src;
397  }
398 }
uploadImage(array $a_upload_meta)
$res
Definition: ltiservices.php:66
static getInstancesByType(string $a_type_unique_id)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static getValidFilename(string $a_filename)
setImageRid(?string $image_rid=null)
getImageFromResourceId(int $size=ilBadgeImage::IMAGE_SIZE_XS)
$path
Definition: ltiservices.php:29
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static delDir(string $a_dir, bool $a_clean_only=false)
removes a dir and all its content (subdirs and files) recursively
global $DIC
Definition: shib_login.php:22
ilGlobalTemplateInterface $main_template
processImageUpload(ilBadgeImageTemplate $badge)
static moveUploadedFile(string $a_file, string $a_name, string $a_target, bool $a_raise_errors=true, string $a_mode="move_uploaded")
move uploaded file
Class FileUpload.
Definition: FileUpload.php:37
$filename
Definition: buildRTE.php:78
static signFile(string $path_to_file)
getFilePath(int $a_id, ?string $a_subdir=null)
Init file system storage.