ILIAS  trunk Revision v12.0_alpha-377-g3641b37b9db
MapDBRepository.php
Go to the documentation of this file.
1<?php
2
19declare(strict_types=1);
20
22
24{
25 protected \ilDBInterface $db;
26
27 public function __construct(
29 ) {
30 $this->db = $db;
31 }
32
33 public function saveScreenIdsForChapter(
34 int $a_chap,
35 array $a_ids
36 ): void {
37 $this->removeScreenIdsOfChapter($a_chap);
38 foreach ($a_ids as $id) {
39 $full_id = trim($id);
40 $id = trim($id);
41 $id = explode("/", $id);
42 if ($id[0] != "") {
43 if (($id[1] ?? "") == "") {
44 $id[1] = "-";
45 }
46 $pos2 = strpos($full_id, "/", strpos($full_id, "/") + 1);
47 if ($pos2 === false) {
48 $id2 = "";
49 } else {
50 $id2 = substr($full_id, $pos2 + 1);
51 }
52 $id2 = explode("#", ($id2 ?? ""));
53 if (($id2[0] ?? "") == "") {
54 $id2[0] = "-";
55 }
56 if (($id2[1] ?? "") == "") {
57 $id2[1] = "-";
58 }
59 // strip perm from full id
60 $pos = strpos($full_id, "#");
61 if ($pos !== false) {
62 $full_id = substr($full_id, 0, $pos);
63 }
64 $this->db->insert(
65 "help_map",
66 array("chap" => array("integer", $a_chap),
67 "perm" => array("text", $id2[1]),
68 "full_id" => array("text", trim($full_id)),
69 "module_id" => array("integer", 0)
70 ),
71 array()
72 );
73 }
74 }
75 }
76
77 public function saveMappingEntry(
78 int $a_chap,
79 string $a_comp,
80 string $a_screen_id,
81 string $a_screen_sub_id,
82 string $a_perm,
83 int $a_module_id = 0,
84 string $full_id = ""
85 ): void {
86 $this->db->insert(
87 "help_map",
88 array("chap" => array("integer", $a_chap),
89 "perm" => array("text", $a_perm),
90 "module_id" => array("integer", $a_module_id),
91 "full_id" => array("text", $full_id)
92 ),
93 array()
94 );
95 }
96
97 public function removeScreenIdsOfChapter(
98 int $a_chap,
99 int $a_module_id = 0
100 ): void {
101 $this->db->manipulate(
102 "DELETE FROM help_map WHERE " .
103 " chap = " . $this->db->quote($a_chap, "integer") .
104 " AND module_id = " . $this->db->quote($a_module_id, "integer")
105 );
106 }
107
108 public function getScreenIdsOfChapter(
109 int $a_chap,
110 int $a_module_id = 0
111 ): array {
112 $set = $this->db->query(
113 "SELECT * FROM help_map " .
114 " WHERE chap = " . $this->db->quote($a_chap, "integer") .
115 " AND module_id = " . $this->db->quote($a_module_id, "integer") .
116 " ORDER BY full_id"
117 );
118 $screen_ids = array();
119 while ($rec = $this->db->fetchAssoc($set)) {
120 $id = $rec["full_id"];
121 if ($rec["perm"] != "" && $rec["perm"] != "-") {
122 $id .= "#" . $rec["perm"];
123 }
124 $screen_ids[] = $id;
125 }
126 return $screen_ids;
127 }
128
129 public function getChaptersForScreenId(
130 string $a_screen_id,
131 array $module_ids
132 ): \Generator {
133 $chaps = [];
134 foreach ($module_ids as $module_id) {
135 $set = $this->db->query(
136 $q =
137 "SELECT chap, perm FROM help_map JOIN lm_tree" .
138 " ON (help_map.chap = lm_tree.child) " .
139 " WHERE full_id = " . $this->db->quote($a_screen_id, "text") .
140 " AND module_id = " . $this->db->quote($module_id, "integer") .
141 " ORDER BY lm_tree.lft"
142 );
143 while ($rec = $this->db->fetchAssoc($set)) {
144 yield $rec;
145 }
146 }
147 }
148
149 public function deleteEntriesOfModule(
150 int $a_id
151 ): void {
152 $this->db->manipulate("DELETE FROM help_map WHERE " .
153 " module_id = " . $this->db->quote($a_id, "integer"));
154 }
155
156}
$id
plugin.php for ilComponentBuildPluginInfoObjectiveTest::testAddPlugins
Definition: plugin.php:23
getScreenIdsOfChapter(int $a_chap, int $a_module_id=0)
removeScreenIdsOfChapter(int $a_chap, int $a_module_id=0)
saveMappingEntry(int $a_chap, string $a_comp, string $a_screen_id, string $a_screen_sub_id, string $a_perm, int $a_module_id=0, string $full_id="")
getChaptersForScreenId(string $a_screen_id, array $module_ids)
saveScreenIdsForChapter(int $a_chap, array $a_ids)
__construct(\ilDBInterface $db)
Interface ilDBInterface.
$q
Definition: shib_logout.php:23