<?php
/*****************************************************************************
 * ViewPhoto.php
 * Contains the view photo controller
 *
 * Kabuki CMS (C) 2013-2016, Aaron van Geffen
 *****************************************************************************/

class ViewPhoto extends HTMLController
{
	public function __construct()
	{
		// Ensure we're logged in at this point.
		$user = Registry::get('user');
		if (!$user->isLoggedIn())
			throw new NotAllowedException();

		$photo = Asset::fromSlug($_GET['slug']);
		if (empty($photo))
			throw new NotFoundException();

		parent::__construct($photo->getTitle() . ' - ' . SITE_TITLE);

		$author = $photo->getAuthor();

		if (isset($_REQUEST['confirm_delete']) || isset($_REQUEST['delete_confirmed']))
			$this->handleConfirmDelete($user, $author, $photo);
		else
			$this->handleViewPhoto($user, $author, $photo);

		// Add an edit button to the admin bar.
		if ($user->isAdmin())
			$this->admin_bar->appendItem(BASEURL . '/editasset/?id=' . $photo->getId(), 'Edit this photo');
	}

	private function handleConfirmDelete(User $user, User $author, Asset $photo)
	{
		if (!($user->isAdmin() || $user->getUserId() === $author->getUserId()))
			throw new NotAllowedException();

		if (isset($_REQUEST['confirm_delete']))
		{
			$page = new ConfirmDeletePage($photo->getImage());
			$this->page->adopt($page);
		}
		else if (isset($_REQUEST['delete_confirmed']))
		{
			$album_url = $photo->getSubdir();
			$photo->delete();

			header('Location: ' . BASEURL . '/' . $album_url);
			exit;
		}
	}

	private function handleViewPhoto(User $user, User $author, Asset $photo)
	{
		if (!empty($_POST))
			$this->handleTagging($photo->getImage());

		$page = new PhotoPage($photo->getImage());

		// Exif data?
		$exif = EXIF::fromFile($photo->getFullPath());
		if ($exif)
			$page->setExif($exif);

		// What tag are we browsing?
		$tag = isset($_GET['in']) ? Tag::fromId($_GET['in']) : null;
		$id_tag = isset($tag) ? $tag->id_tag : null;

		// Find previous photo in set.
		$previous_url = $photo->getUrlForPreviousInSet($id_tag);
		if ($previous_url)
			$page->setPreviousPhotoUrl($previous_url);

		// ... and the next photo, too.
		$next_url = $photo->getUrlForNextInSet($id_tag);
		if ($next_url)
			$page->setNextPhotoUrl($next_url);

		if ($user->isAdmin() || $user->getUserId() === $author->getUserId())
			$page->setIsAssetOwner(true);

		$this->page->adopt($page);
		$this->page->setCanonicalUrl($photo->getPageUrl());
	}

	private function handleTagging(Image $photo)
	{
		header('Content-Type: text/json; charset=utf-8');

		// Are we tagging a photo?
		if (!isset($_POST['id_tag']))
		{
			echo json_encode(['error' => true, 'msg' => 'Invalid tag request.']);
			exit;
		}

		// We are!
		if (!isset($_POST['delete']))
		{
			$photo->linkTags([(int) $_POST['id_tag']]);
			echo json_encode(['success' => true]);
			exit;
		}

		// ... deleting, that is.
		else
		{
			$photo->unlinkTags([(int) $_POST['id_tag']]);
			echo json_encode(['success' => true]);
			exit;
		}
	}
}