diff options
author | Simon Rettberg | 2019-07-23 13:57:20 +0200 |
---|---|---|
committer | Simon Rettberg | 2019-07-23 13:57:20 +0200 |
commit | 04828b94e9df8321feae0bfb99daa468c0d3d383 (patch) | |
tree | e3b00490dc14a0f5d6ffda5bab1ce7c82bafee52 /modules-available/roomplanner/inc/room.inc.php | |
parent | slx-fixes.js: Make .cachedScript more compatible to .getScript (diff) | |
download | slx-admin-04828b94e9df8321feae0bfb99daa468c0d3d383.tar.gz slx-admin-04828b94e9df8321feae0bfb99daa468c0d3d383.tar.xz slx-admin-04828b94e9df8321feae0bfb99daa468c0d3d383.zip |
[roomplanner] Support creating recursive/composed rooms
Diffstat (limited to 'modules-available/roomplanner/inc/room.inc.php')
-rw-r--r-- | modules-available/roomplanner/inc/room.inc.php | 176 |
1 files changed, 176 insertions, 0 deletions
diff --git a/modules-available/roomplanner/inc/room.inc.php b/modules-available/roomplanner/inc/room.inc.php new file mode 100644 index 00000000..855bdbcf --- /dev/null +++ b/modules-available/roomplanner/inc/room.inc.php @@ -0,0 +1,176 @@ +<?php + +abstract class Room +{ + + /** + * @var Room[] list of all rooms + */ + protected static $rooms = null; + + /** + * @var int id for this room + */ + private $locationId; + + /** + * @var string name of this room + */ + private $locationName; + + protected static function init() + { + if (self::$rooms !== null) + return; + /* get all rooms */ + self::$rooms = []; + $ret = Database::simpleQuery( + 'SELECT lr.locationid, lr.managerip, lr.tutoruuid, lr.roomplan, m.clientip as tutorip + FROM location_roomplan lr + LEFT JOIN machine m ON (lr.tutoruuid = m.machineuuid)'); + while ($row = $ret->fetch(PDO::FETCH_ASSOC)) { + $row = self::loadSingleRoom($row); + if ($row === false) + continue; + self::$rooms[$row->locationId] = $row; + } + foreach (self::$rooms as $room) { + $room->sanitize(); + } + } + + /** + * Instantiate ComposedRoom or MachineGroup depending on contents of $row + * @param array $row DB row from location_roomplan. + * @return Room|false Room instance, false on error + */ + private static function loadSingleRoom($row) + { + $locations = Location::getLocationsAssoc(); + settype($row['locationid'], 'int'); + if (!isset($locations[$row['locationid']])) + return false; + if ($locations[$row['locationid']]['isleaf']) + return new SimpleRoom($row); + return new ComposedRoom($row, false); + } + + /** + * Get array of all rooms with room plan + * @return Room[] + */ + public static function getAll() + { + self::init(); + return self::$rooms; + } + + /** + * Get room instance for given location + * @param int $locationId room to get + * @return Room|false requested room, false if not configured or not found + */ + public static function get($locationId) + { + if (self::$rooms === null) { + $room = Database::queryFirst( + 'SELECT lr.locationid, lr.managerip, lr.tutoruuid, lr.roomplan, m.clientip as tutorip + FROM location_roomplan lr + LEFT JOIN machine m ON (lr.tutoruuid = m.machineuuid) + WHERE lr.locationid = :lid', ['lid' => $locationId]); + if ($room === false) + return false; + $room = self::loadSingleRoom($room); + // If it's a leaf room we probably don't need any other rooms, return it + if ($room->isLeaf()) + return $room; + // Otherwise init the full tree so we can resolve composed rooms later + self::init(); + } + if (isset(self::$rooms[$locationId])) + return self::$rooms[$locationId]; + return false; + } + + public function __construct($row) + { + $locations = Location::getLocationsAssoc(); + $this->locationId = (int)$row['locationid']; + $this->locationName = $locations[$this->locationId]['locationname']; + } + + /** + * @return int number of machines in this room + */ + abstract public function machineCount(); + + /** + * Size of this room, returned by reference. + * @param int $width OUT width of room + * @param int $height OUT height of room + */ + abstract public function getSize(&$width, &$height); + + /** + * Get clients in this room in .ini format for PVS. + * Adjusted so the top/left client is at (0|0), which + * is further adjustable with $offX and $offY. + * @param int $i offset for indexing clients + * @param int $offX positional X offset for clients + * @param int $offY positional Y offset for clients + * @return string|false + */ + abstract public function getIniClientSection(&$i, $offX = 0, $offY = 0); + + /** + * Get clients in this room as array. + * Adjusted so the top/left client is at (0|0), which + *is further adjustable with $offX and $offY. + * @param int $offX + * @param int $offY + * @return array + */ + abstract public function getShiftedArray($offX = 0, $offY = 0); + + /** + * @return string|false IP address of manager. + */ + abstract public function getManagerIp(); + + /** + * @return string|false IP address of tutor client. + */ + abstract public function getTutorIp(); + + /** + * @return bool true if this is a simple/leaf room, false for composed rooms. + */ + abstract public function isLeaf(); + + /** + * @return bool should this room be skipped from output? true for empty SimpleRoom or disabled ComposedRoom. + */ + abstract public function shouldSkip(); + + /** + * Sanitize this room's data. + */ + abstract protected function sanitize(); + + /** + * @return string get room's name. + */ + public function locationName() + { + return $this->locationName; + } + + /** + * @return int get room's id. + */ + public function locationId() + { + return $this->locationId; + } + +}
\ No newline at end of file |