<?php

set_include_path(get_include_path() . PATH_SEPARATOR . '../lib');

include_once("aur.inc.php");
set_lang();
include_once('pkgfuncs.inc.php');
check_sid();

/*
 * Retrieve package base ID and name, unless initialized by the routing
 * framework.
 */
if (!isset($base_id) || !isset($pkgbase_name)) {
	if (isset($_GET['ID'])) {
		$base_id = intval($_GET['ID']);
		$pkgbase_name = pkgbase_name_from_id($_GET['ID']);
	} else if (isset($_GET['N'])) {
		$base_id = pkgbase_from_name($_GET['N']);
		$pkgbase_name = $_GET['N'];
	} else {
		unset($base_id, $pkgbase_name);
	}

	if (isset($base_id) && ($base_id == 0 || $base_id == NULL || $pkgbase_name == NULL)) {
		header("HTTP/1.0 404 Not Found");
		include "./404.php";
		return;
	}
}

/* Set the title to package base name. */
$title = $pkgbase_name;

/* Grab the list of package base IDs to be operated on. */
$ids = array();
if (isset($_POST['IDs'])) {
	foreach ($_POST['IDs'] as $id => $i) {
		$id = intval($id);
		if ($id > 0) {
			$ids[] = $id;
		}
	}
}

/* Perform package base actions. */
$ret = false;
$output = "";
$fragment = "";
if (check_token()) {
	if (current_action("do_Flag")) {
		if (strlen($_POST['comments']) >= 3) {
			list($ret, $output) = pkgbase_flag($ids, $_POST['comments']);
		} else {
			$output = __("The selected packages have not been flagged, please enter a comment.");
			$ret = false;
		}
	} elseif (current_action("do_UnFlag")) {
		list($ret, $output) = pkgbase_unflag($ids);
	} elseif (current_action("do_Adopt")) {
		list($ret, $output) = pkgbase_adopt($ids, true, NULL);
	} elseif (current_action("do_Disown")) {
		if (isset($_POST['confirm'])) {
			$via = isset($_POST['via']) ? $_POST['via'] : NULL;
			list($ret, $output) = pkgbase_adopt($ids, false, $via);
		} else {
			$output = __("The selected packages have not been disowned, check the confirmation checkbox.");
			$ret = false;
		}
	} elseif (current_action("do_Vote")) {
		list($ret, $output) = pkgbase_vote($ids, true);
	} elseif (current_action("do_UnVote")) {
		list($ret, $output) = pkgbase_vote($ids, false);
	} elseif (current_action("do_Delete")) {
		if (isset($_POST['confirm'])) {
			$via = isset($_POST['via']) ? $_POST['via'] : NULL;
			if (!isset($_POST['merge_Into']) || empty($_POST['merge_Into'])) {
				list($ret, $output) = pkgbase_delete($ids, NULL, $via);
				unset($_GET['ID']);
				unset($base_id);
			}
			else {
				$merge_base_id = pkgbase_from_name($_POST['merge_Into']);
				if (!$merge_base_id) {
					$output = __("Cannot find package to merge votes and comments into.");
					$ret = false;
				} elseif (in_array($merge_base_id, $ids)) {
					$output = __("Cannot merge a package base with itself.");
					$ret = false;
				} else {
					list($ret, $output) = pkgbase_delete($ids, $merge_base_id, $via);
					unset($_GET['ID']);
					unset($base_id);
				}
			}
		}
		else {
			$output = __("The selected packages have not been deleted, check the confirmation checkbox.");
			$ret = false;
		}
	} elseif (current_action("do_Notify")) {
		list($ret, $output) = pkgbase_notify($ids);
	} elseif (current_action("do_UnNotify")) {
		list($ret, $output) = pkgbase_notify($ids, false);
	} elseif (current_action("do_DeleteComment")) {
		list($ret, $output) = pkgbase_delete_comment();
	} elseif (current_action("do_SetKeywords")) {
		list($ret, $output) = pkgbase_set_keywords($base_id, preg_split("/[\s,;]+/", $_POST['keywords'], -1, PREG_SPLIT_NO_EMPTY));
	} elseif (current_action("do_FileRequest")) {
		list($ret, $output) = pkgreq_file($ids, $_POST['type'], $_POST['merge_into'], $_POST['comments']);
	} elseif (current_action("do_CloseRequest")) {
		list($ret, $output) = pkgreq_close($_POST['reqid'], $_POST['reason'], $_POST['comments']);
	} elseif (current_action("do_EditComaintainers")) {
		list($ret, $output) = pkgbase_set_comaintainers($base_id, explode("\n", $_POST['users']));
	} elseif (current_action("do_AddComment")) {
		$uid = uid_from_sid($_COOKIE["AURSID"]);
		list($ret, $output) = pkgbase_add_comment($base_id, $uid, $_REQUEST['comment']);
		$fragment = '#news';
	} elseif (current_action("do_EditComment")) {
		list($ret, $output) = pkgbase_edit_comment($_REQUEST['comment']);
		if ($ret && isset($_POST["comment_id"])) {
			$fragment = '#comment-' . intval($_POST["comment_id"]);
		}
	}

	if ($ret) {
		if (current_action("do_CloseRequest") ||
		    (current_action("do_Delete") && $_POST['via'])) {
			/* Redirect back to package request page on success. */
			header('Location: ' . get_pkgreq_route());
			exit();
		} if (isset($base_id)) {
			/* Redirect back to package base page on success. */
			header('Location: ' . get_pkgbase_uri($pkgbase_name) . $fragment);
			exit();
		} else {
			/* Redirect back to package search page. */
			header('Location: ' . get_pkg_route());
			exit();
		}
	}
}

$pkgs = pkgbase_get_pkgnames($base_id);
if (!$output && count($pkgs) == 1) {
	/* Not a split package. Redirect to the package page. */
	if (empty($_SERVER['QUERY_STRING'])) {
		header('Location: ' . get_pkg_uri($pkgs[0]) . $fragment);
	} else {
		header('Location: ' . get_pkg_uri($pkgs[0]) . '?' . $_SERVER['QUERY_STRING'] . $fragment);
	}
}

$details = pkgbase_get_details($base_id);
html_header($title, $details);
?>

<?php if ($output): ?>
<?php if ($ret): ?>
<p class="pkgoutput"><?= htmlspecialchars($output) ?></p>
<?php else: ?>
<ul class="errorlist"><li><?= htmlspecialchars($output) ?></li></ul>
<?php endif; ?>
<?php endif; ?>

<?php
include('pkg_search_form.php');
if (isset($_COOKIE["AURSID"])) {
	pkgbase_display_details($base_id, $details, $_COOKIE["AURSID"]);
} else {
	pkgbase_display_details($base_id, $details, null);
}

html_footer(AURWEB_VERSION);