| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305 | 
							- <?php
 
- ###
 
- # @name			Admin Access
 
- # @copyright	2015 by Tobias Reich
 
- ###
 
- if (!defined('LYCHEE')) exit('Error: Direct access is not allowed!');
 
- if (!defined('LYCHEE_ACCESS_ADMIN')) exit('Error: You are not allowed to access this area!');
 
- class Admin extends Access {
 
- 	public function check($fn) {
 
- 		switch ($fn) {
 
- 			# Album functions
 
- 			case 'getAlbums':			$this->getAlbums(); break;
 
- 			case 'getAlbum':			$this->getAlbum(); break;
 
- 			case 'addAlbum':			$this->addAlbum(); break;
 
- 			case 'setAlbumTitle':		$this->setAlbumTitle(); break;
 
- 			case 'setAlbumDescription':	$this->setAlbumDescription(); break;
 
- 			case 'setAlbumPublic':		$this->setAlbumPublic(); break;
 
- 			case 'deleteAlbum':			$this->deleteAlbum(); break;
 
- 			# Photo functions
 
- 			case 'getPhoto':			$this->getPhoto(); break;
 
- 			case 'setPhotoTitle':		$this->setPhotoTitle(); break;
 
- 			case 'setPhotoDescription':	$this->setPhotoDescription(); break;
 
- 			case 'setPhotoStar':		$this->setPhotoStar(); break;
 
- 			case 'setPhotoPublic':		$this->setPhotoPublic(); break;
 
- 			case 'setPhotoAlbum':		$this->setPhotoAlbum(); break;
 
- 			case 'setPhotoTags':		$this->setPhotoTags(); break;
 
- 			case 'duplicatePhoto':		$this->duplicatePhoto(); break;
 
- 			case 'deletePhoto':			$this->deletePhoto(); break;
 
- 			# Add functions
 
- 			case 'upload':				$this->upload(); break;
 
- 			case 'importUrl':			$this->importUrl(); break;
 
- 			case 'importServer':		$this->importServer(); break;
 
- 			# Search functions
 
- 			case 'search':				$this->search(); break;
 
- 			# Session functions
 
- 			case 'init':				$this->init(); break;
 
- 			case 'login':				$this->login(); break;
 
- 			case 'logout':				$this->logout(); break;
 
- 			# Settings functions
 
- 			case 'setLogin':			$this->setLogin(); break;
 
- 			case 'setSorting':			$this->setSorting(); break;
 
- 			case 'setDropboxKey':		$this->setDropboxKey(); break;
 
- 			# $_GET functions
 
- 			case 'getAlbumArchive':		$this->getAlbumArchive(); break;
 
- 			case 'getPhotoArchive':		$this->getPhotoArchive(); break;
 
- 			# Error
 
- 			default:					exit('Error: Function not found! Please check the spelling of the called function.');
 
- 										return false; break;
 
- 		}
 
- 		return true;
 
- 	}
 
- 	# Album functions
 
- 	private function getAlbums() {
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, null);
 
- 		echo json_encode($album->getAll(false));
 
- 	}
 
- 	private function getAlbum() {
 
- 		Module::dependencies(isset($_POST['albumID']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, $_POST['albumID']);
 
- 		echo json_encode($album->get());
 
- 	}
 
- 	private function addAlbum() {
 
- 		Module::dependencies(isset($_POST['title']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, null);
 
- 		echo $album->add($_POST['title']);
 
- 	}
 
- 	private function setAlbumTitle() {
 
- 		Module::dependencies(isset($_POST['albumIDs'], $_POST['title']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, $_POST['albumIDs']);
 
- 		echo $album->setTitle($_POST['title']);
 
- 	}
 
- 	private function setAlbumDescription() {
 
- 		Module::dependencies(isset($_POST['albumID'], $_POST['description']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, $_POST['albumID']);
 
- 		echo $album->setDescription($_POST['description']);
 
- 	}
 
- 	private function setAlbumPublic() {
 
- 		Module::dependencies(isset($_POST['albumID'], $_POST['password'], $_POST['visible'], $_POST['downloadable']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, $_POST['albumID']);
 
- 		echo $album->setPublic($_POST['password'], $_POST['visible'], $_POST['downloadable']);
 
- 	}
 
- 	private function deleteAlbum() {
 
- 		Module::dependencies(isset($_POST['albumIDs']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, $_POST['albumIDs']);
 
- 		echo $album->delete();
 
- 	}
 
- 	# Photo functions
 
- 	private function getPhoto() {
 
- 		Module::dependencies(isset($_POST['photoID'], $_POST['albumID']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoID']);
 
- 		echo json_encode($photo->get($_POST['albumID']));
 
- 	}
 
- 	private function setPhotoTitle() {
 
- 		Module::dependencies(isset($_POST['photoIDs'], $_POST['title']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoIDs']);
 
- 		echo $photo->setTitle($_POST['title']);
 
- 	}
 
- 	private function setPhotoDescription() {
 
- 		Module::dependencies(isset($_POST['photoID'], $_POST['description']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoID']);
 
- 		echo $photo->setDescription($_POST['description']);
 
- 	}
 
- 	private function setPhotoStar() {
 
- 		Module::dependencies(isset($_POST['photoIDs']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoIDs']);
 
- 		echo $photo->setStar();
 
- 	}
 
- 	private function setPhotoPublic() {
 
- 		Module::dependencies(isset($_POST['photoID']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoID']);
 
- 		echo $photo->setPublic();
 
- 	}
 
- 	private function setPhotoAlbum() {
 
- 		Module::dependencies(isset($_POST['photoIDs'], $_POST['albumID']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoIDs']);
 
- 		echo $photo->setAlbum($_POST['albumID']);
 
- 	}
 
- 	private function setPhotoTags() {
 
- 		Module::dependencies(isset($_POST['photoIDs'], $_POST['tags']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoIDs']);
 
- 		echo $photo->setTags($_POST['tags']);
 
- 	}
 
- 	private function duplicatePhoto() {
 
- 		Module::dependencies(isset($_POST['photoIDs']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoIDs']);
 
- 		echo $photo->duplicate();
 
- 	}
 
- 	private function deletePhoto() {
 
- 		Module::dependencies(isset($_POST['photoIDs']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_POST['photoIDs']);
 
- 		echo $photo->delete();
 
- 	}
 
- 	# Add functions
 
- 	private function upload() {
 
- 		Module::dependencies(isset($_FILES, $_POST['albumID'], $_POST['tags']));
 
- 		$photo = new Photo($this->database, $this->plugins, $this->settings, null);
 
- 		echo $photo->add($_FILES, $_POST['albumID'], '', $_POST['tags']);
 
- 	}
 
- 	private function importUrl() {
 
- 		Module::dependencies(isset($_POST['url'], $_POST['albumID']));
 
- 		echo Import::url($_POST['url'], $_POST['albumID']);
 
- 	}
 
- 	private function importServer() {
 
- 		Module::dependencies(isset($_POST['albumID'], $_POST['path']));
 
- 		echo Import::server($_POST['albumID'], $_POST['path']);
 
- 	}
 
- 	# Search function
 
- 	private function search() {
 
- 		Module::dependencies(isset($_POST['term']));
 
- 		echo json_encode(search($this->database, $this->settings, $_POST['term']));
 
- 	}
 
- 	# Session functions
 
- 	private function init() {
 
- 		global $dbName;
 
- 		Module::dependencies(isset($_POST['version']));
 
- 		$session = new Session($this->plugins, $this->settings);
 
- 		echo json_encode($session->init($this->database, $dbName, false, $_POST['version']));
 
- 	}
 
- 	private function login() {
 
- 		Module::dependencies(isset($_POST['user'], $_POST['password']));
 
- 		$session = new Session($this->plugins, $this->settings);
 
- 		echo $session->login($_POST['user'], $_POST['password']);
 
- 	}
 
- 	private function logout() {
 
- 		$session = new Session($this->plugins, $this->settings);
 
- 		echo $session->logout();
 
- 	}
 
- 	# Settings functions
 
- 	private function setLogin() {
 
- 		Module::dependencies(isset($_POST['username'], $_POST['password']));
 
- 		if (!isset($_POST['oldPassword'])) $_POST['oldPassword'] = '';
 
- 		$this->settings = new Settings($this->database);
 
- 		echo $this->settings->setLogin($_POST['oldPassword'], $_POST['username'], $_POST['password']);
 
- 	}
 
- 	private function setSorting() {
 
- 		Module::dependencies(isset($_POST['type'], $_POST['order']));
 
- 		$this->settings = new Settings($this->database);
 
- 		echo $this->settings->setSorting($_POST['type'], $_POST['order']);
 
- 	}
 
- 	private function setDropboxKey() {
 
- 		Module::dependencies(isset($_POST['key']));
 
- 		$this->settings = new Settings($this->database);
 
- 		echo $this->settings->setDropboxKey($_POST['key']);
 
- 	}
 
- 	# Get functions
 
- 	private function getAlbumArchive() {
 
- 		Module::dependencies(isset($_GET['albumID']));
 
- 		$album = new Album($this->database, $this->plugins, $this->settings, $_GET['albumID']);
 
- 		$album->getArchive();
 
- 	}
 
- 	private function getPhotoArchive() {
 
- 		Module::dependencies(isset($_GET['photoID']));
 
- 		$photo = new Photo($this->database, $this->plugins, null, $_GET['photoID']);
 
- 		$photo->getArchive();
 
- 	}
 
- }
 
 
  |