Books
This commit is contained in:
		| @@ -1,9 +1,24 @@ | |||||||
| <?php | <?php | ||||||
|  |  | ||||||
| require_once __DIR__ . '/base.php'; | require_once 'website.php'; | ||||||
|  |  | ||||||
| class Books | class Books | ||||||
| { | { | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $staticData; | ||||||
|  |  | ||||||
|  | 	public function __construct() | ||||||
|  | 	{ | ||||||
|  | 		$this->load(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	private function load() | ||||||
|  | 	{ | ||||||
|  | 		$all = require (__DIR__ . '/../statics/blog/__all.php'); | ||||||
|  |  | ||||||
|  | 		$this->staticData = array_map(function($a){return self::readSingle($a);}, $all); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	public static function readSingle($a) | 	public static function readSingle($a) | ||||||
| 	{ | 	{ | ||||||
| 		$a['imgfront_url']      =              '/data/images/book_img/' . $a['id'] . '_front.png'; | 		$a['imgfront_url']      =              '/data/images/book_img/' . $a['id'] . '_front.png'; | ||||||
| @@ -31,27 +46,27 @@ class Books | |||||||
| 		return $a; | 		return $a; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function listAll() | 	public function listAll() | ||||||
| 	{ | 	{ | ||||||
| 		$all = require (__DIR__ . '/../statics/books/__all.php'); | 		return $this->staticData; | ||||||
|  |  | ||||||
| 		return array_map('self::readSingle', $all); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function listAllNewestFirst() | 	public function listAllNewestFirst() | ||||||
| 	{ | 	{ | ||||||
| 		$data = self::listAll(); | 		$data = $this->staticData; | ||||||
| 		usort($data, function($a, $b) { return strcasecmp($b['date'], $a['date']); }); | 		usort($data, function($a, $b) { return strcasecmp($b['date'], $a['date']); }); | ||||||
| 		return $data; | 		return $data; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function checkConsistency() | 	public function checkConsistency() | ||||||
| 	{ | 	{ | ||||||
| 		$warn = null; | 		$warn = null; | ||||||
|  |  | ||||||
|  | 		$this->load(); | ||||||
|  |  | ||||||
| 		$ids = []; | 		$ids = []; | ||||||
|  |  | ||||||
| 		foreach (self::listAll() as $prog) | 		foreach ($this->staticData as $prog) | ||||||
| 		{ | 		{ | ||||||
| 			if (in_array($prog['id'], $ids)) return ['result'=>'err', 'message' => 'Duplicate id ' . $prog['id']]; | 			if (in_array($prog['id'], $ids)) return ['result'=>'err', 'message' => 'Duplicate id ' . $prog['id']]; | ||||||
| 			$ids []= $prog['id']; | 			$ids []= $prog['id']; | ||||||
| @@ -79,7 +94,7 @@ class Books | |||||||
| 		return ['result'=>'ok', 'message' => '']; | 		return ['result'=>'ok', 'message' => '']; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function checkThumbnails() | 	public function checkThumbnails() | ||||||
| 	{ | 	{ | ||||||
| 		foreach (self::listAll() as $book) | 		foreach (self::listAll() as $book) | ||||||
| 		{ | 		{ | ||||||
| @@ -89,7 +104,7 @@ class Books | |||||||
| 		return ['result'=>'ok', 'message' => '']; | 		return ['result'=>'ok', 'message' => '']; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function createPreview($prog) | 	public function createPreview($prog) | ||||||
| 	{ | 	{ | ||||||
| 		global $CONFIG; | 		global $CONFIG; | ||||||
|  |  | ||||||
| @@ -103,7 +118,7 @@ class Books | |||||||
|  |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function getBook($id) | 	public function getBook($id) | ||||||
| 	{ | 	{ | ||||||
| 		foreach (self::listAll() as $book) { | 		foreach (self::listAll() as $book) { | ||||||
| 			if ($book['id'] == $id) return $book; | 			if ($book['id'] == $id) return $book; | ||||||
| @@ -111,7 +126,7 @@ class Books | |||||||
| 		return null; | 		return null; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function getRepositoryHost($book) | 	public function getRepositoryHost($book) | ||||||
| 	{ | 	{ | ||||||
| 		$r = $book['repository']; | 		$r = $book['repository']; | ||||||
| 		if (startsWith($r, "http://")) $r = substr($r, strlen("http://")); | 		if (startsWith($r, "http://")) $r = substr($r, strlen("http://")); | ||||||
|   | |||||||
| @@ -9,7 +9,12 @@ class Database | |||||||
|  |  | ||||||
| 	public function __construct(Website $site) | 	public function __construct(Website $site) | ||||||
| 	{ | 	{ | ||||||
| 		$dsn = "mysql:host=" . $site->config['host'] . ";dbname=" . $site->config['database'] . ";charset=utf8"; | 		$this->connect($site->config); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	private function connect(array $config) | ||||||
|  | 	{ | ||||||
|  | 		$dsn = "mysql:host=" . $config['host'] . ";dbname=" . $config['database'] . ";charset=utf8"; | ||||||
| 		$opt = | 		$opt = | ||||||
| 		[ | 		[ | ||||||
| 			PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION, | 			PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION, | ||||||
| @@ -17,14 +22,12 @@ class Database | |||||||
| 			PDO::ATTR_EMULATE_PREPARES   => false, | 			PDO::ATTR_EMULATE_PREPARES   => false, | ||||||
| 		]; | 		]; | ||||||
|  |  | ||||||
| 		$this->pdo = new PDO($dsn, $site->config['user'], $site->config['password'], $opt); | 		$this->pdo = new PDO($dsn, $config['user'], $config['password'], $opt); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function sql_query_num($query) | 	public function sql_query_num($query) | ||||||
| 	{ | 	{ | ||||||
| 		$r = $this->pdo->query($query)->fetch(PDO::FETCH_NUM)[0]; | 		return $this->pdo->query($query)->fetch(PDO::FETCH_NUM)[0]; | ||||||
|  |  | ||||||
| 		return $r; |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function sql_query_num_prep($query, $params) | 	public function sql_query_num_prep($query, $params) | ||||||
| @@ -37,16 +40,13 @@ class Database | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$stmt->execute(); | 		$stmt->execute(); | ||||||
| 		$r = $stmt->fetch(PDO::FETCH_NUM)[0]; |  | ||||||
|  |  | ||||||
| 		return $r; | 		return $stmt->fetch(PDO::FETCH_NUM)[0]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function sql_query_assoc($query) | 	public function sql_query_assoc($query) | ||||||
| 	{ | 	{ | ||||||
| 		$r = $this->pdo->query($query)->fetchAll(PDO::FETCH_ASSOC); | 		return $this->pdo->query($query)->fetchAll(PDO::FETCH_ASSOC); | ||||||
|  |  | ||||||
| 		return $r; |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public  function sql_query_assoc_prep($query, $params) | 	public  function sql_query_assoc_prep($query, $params) | ||||||
|   | |||||||
| @@ -17,8 +17,10 @@ class Website | |||||||
| 	/** @var array */ | 	/** @var array */ | ||||||
| 	public $config; | 	public $config; | ||||||
|  |  | ||||||
| 	/** @var Database|null */ | 	/** @var Database|null */     private $database = null; | ||||||
| 	private $database = null; | 	/** @var AdventOfCode|null */ private $adventOfCode = null; | ||||||
|  | 	/** @var Blog|null */         private $blog = null; | ||||||
|  | 	/** @var Books|null */        private $books = null; | ||||||
|  |  | ||||||
| 	public function init() | 	public function init() | ||||||
| 	{ | 	{ | ||||||
| @@ -50,7 +52,7 @@ class Website | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public static function getInstance() | 	public static function inst() | ||||||
| 	{ | 	{ | ||||||
| 		return self::$instance; | 		return self::$instance; | ||||||
| 	} | 	} | ||||||
| @@ -140,10 +142,6 @@ class Website | |||||||
| 		exit(); | 		exit(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param PageFrameOptions $pfo |  | ||||||
| 	 * @param URLRoute $route |  | ||||||
| 	 */ |  | ||||||
| 	private function output(PageFrameOptions $pfo, URLRoute $route) | 	private function output(PageFrameOptions $pfo, URLRoute $route) | ||||||
| 	{ | 	{ | ||||||
| 		if ($pfo->contentType !== null) header('Content-Type: ' . $pfo->contentType); | 		if ($pfo->contentType !== null) header('Content-Type: ' . $pfo->contentType); | ||||||
| @@ -160,16 +158,32 @@ class Website | |||||||
| 		require __DIR__ . '/../pages/frame/' . $FRAME_OPTIONS->frame; | 		require __DIR__ . '/../pages/frame/' . $FRAME_OPTIONS->frame; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function database() | 	public function Database() | ||||||
| 	{ | 	{ | ||||||
| 		if ($this->database === null) | 		if ($this->database === null) { require_once 'database.php'; $this->database = new Database($this); } | ||||||
| 		{ |  | ||||||
| 			require_once 'database.php'; |  | ||||||
| 			$this->database = new Database($this); |  | ||||||
| 		} |  | ||||||
| 		return $this->database; | 		return $this->database; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public function AdventOfCode() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->adventOfCode === null) { require_once 'adventofcode.php'; $this->adventOfCode = new AdventOfCode(); } | ||||||
|  | 		return $this->adventOfCode; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public function Blog() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->blog === null) { require_once 'blog.php'; $this->blog = new Blog(); } | ||||||
|  | 		return $this->blog; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public function Books() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->books === null) { require_once 'books.php'; $this->books = new Books(); } | ||||||
|  | 		return $this->books; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| 	 * @return bool | 	 * @return bool | ||||||
| 	 */ | 	 */ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user