. */ require_once(ROOT_DIR . "/helpers/db.php"); require_once(ROOT_DIR . "/helpers/position.php"); /** * Track handling */ class uTrack { public $id; public $userId; public $name; public $comment; public $isValid = false; private static $db = null; /** * Constructor * * @param int $trackId Track id */ public function __construct($trackId = NULL) { if (!empty($trackId)) { $query = "SELECT id, user_id, name, comment FROM `" . self::db()->table('tracks') . "` WHERE id = ? LIMIT 1"; $stmt = self::db()->prepare($query); $stmt->bind_param('i', $trackId); $stmt->execute(); $stmt->bind_result($this->id, $this->userId, $this->name, $this->comment); if ($stmt->fetch()) { $this->isValid = true; } $stmt->close(); } } /** * Get db instance * * @return uDb instance */ private static function db() { if (is_null(self::$db)) { self::$db = uDb::getInstance(); } return self::$db; } /** * Add new track * * @param string $userId User id * @param string $name Name * @param string $comment Optional comment * @return int|bool New track id, false on error */ public static function add($userId, $name, $comment = NULL) { $trackId = false; if (!empty($userId) && !empty($name)) { $query = "INSERT INTO `" . self::db()->table('tracks') . "` (user_id, name, comment) VALUES (?, ?, ?)"; $stmt = self::db()->prepare($query); $stmt->bind_param('iss', $userId, $name, $comment); $stmt->execute(); if (!self::db()->error && !$stmt->errno) { $trackId = self::db()->insert_id; } $stmt->close(); } return $trackId; } /** * Add new position to track * * @param int $userId * @param int $time Unix time stamp * @param double $lat * @param double $lon * @param double $altitude Optional * @param double $speed Optional * @param double $bearing Optional * @param int $accuracy Optional * @param string $provider Optional * @param string $comment Optional * @param int $imageId Optional * @return int|bool New position id in database, false on error */ public function addPosition($userId, $timestamp, $lat, $lon, $altitude = NULL, $speed = NULL, $bearing = NULL, $accuracy = NULL, $provider = NULL, $comment = NULL, $imageId = NULL) { return $ret = uPosition::add($userId, $this->id, $timestamp, $lat, $lon, $altitude, $speed, $bearing, $accuracy, $provider, $comment, $imageId); } /** * Delete track with all positions * * @return bool True if success, false otherwise */ public function delete() { $ret = false; if ($this->isValid) { // delete positions if (uPosition::deleteAll($this->userId, $this->id) === false) { return false; } // delete track metadata $query = "DELETE FROM `" . self::db()->table('tracks') . "` WHERE id = ?"; $stmt = self::db()->prepare($query); $stmt->bind_param('i', $this->id); $stmt->execute(); if (!self::db()->error && !$stmt->errno) { $ret = true; $this->id = NULL; $this->userId = NULL; $this->name = NULL; $this->comment = NULL; $this->isValid = false; } $stmt->close(); } return $ret; } /** * Update track * * @param string|null $name New name (not empty string) or NULL if not changed * @param string|null $comment New comment or NULL if not changed (to remove content use empty string: "") * @return bool True if success, false otherwise */ public function update($name = NULL, $comment = NULL) { $ret = false; if (empty($name)) { $name = $this->name; } if (is_null($comment)) { $comment = $this->comment; } if ($comment == "") { $comment = NULL; } if ($this->isValid) { $query = "UPDATE `" . self::db()->table('tracks') . "` SET name = ?, comment = ? WHERE id = ?"; $stmt = self::db()->prepare($query); $stmt->bind_param('ssi', $name, $comment, $this->id); $stmt->execute(); if (!self::db()->error && !$stmt->errno) { $ret = true; $this->name = $name; $this->comment = $comment; } $stmt->close(); } return $ret; } /** * Delete all user's tracks * * @param string $userId User id * @return bool True if success, false otherwise */ public static function deleteAll($userId) { $ret = false; if (!empty($userId)) { // remove all positions if (uPosition::deleteAll($userId) === true) { // remove all tracks $query = "DELETE FROM `" . self::db()->table('tracks') . "` WHERE user_id = ?"; $stmt = self::db()->prepare($query); $stmt->bind_param('i', $userId); $stmt->execute(); if (!self::db()->error && !$stmt->errno) { $ret = true; } $stmt->close(); } } return $ret; } /** * Get all tracks * * @param int $userId Optional limit to user id * @return array|bool Array of uTrack tracks, false on error */ public static function getAll($userId = NULL) { if (!empty($userId)) { $where = "WHERE user_id='" . self::db()->real_escape_string($userId) ."'"; } else { $where = ""; } $query = "SELECT id, user_id, name, comment FROM `" . self::db()->table('tracks') . "` $where ORDER BY id DESC"; $result = self::db()->query($query); if ($result === false) { return false; } $trackArr = []; while ($row = $result->fetch_assoc()) { $trackArr[] = self::rowToObject($row); } $result->close(); return $trackArr; } /** * Convert database row to uTrack * * @param array $row Row * @return uTrack Track */ private static function rowToObject($row) { $track = new uTrack(); $track->id = $row['id']; $track->userId = $row['user_id']; $track->name = $row['name']; $track->comment = $row['comment']; $track->isValid = true; return $track; } } ?>