<?php
/**
 * @file classes/security/authorization/HttpsPolicy.inc.php
 *
 * Copyright (c) 2013-2019 Simon Fraser University
 * Copyright (c) 2000-2019 John Willinsky
 * Distributed under the GNU GPL v2. For full terms see the file docs/COPYING.
 *
 * @class HttpsPolicy
 * @ingroup security_authorization
 *
 * @brief Class to control access to handler operations based on protocol.
 */

import('lib.pkp.classes.security.authorization.AuthorizationPolicy');

class HttpsPolicy extends AuthorizationPolicy {
	/** @var PKPRequest */
	var $_request;

	/**
	 * Constructor
	 *
	 * @param $request PKPRequest
	 */
	function HttpsPolicy(&$request) {
		parent::AuthorizationPolicy();
		$this->_request =& $request;

		// Add advice
		$callOnDeny = array($request, 'redirectSSL', array());
		$this->setAdvice(AUTHORIZATION_ADVICE_CALL_ON_DENY, $callOnDeny);
	}

	//
	// Implement template methods from AuthorizationPolicy
	//
	/**
	 * @see AuthorizationPolicy::applies()
	 */
	function applies() {
		return (boolean)Config::getVar('security', 'force_ssl');
	}

	/**
	 * @see AuthorizationPolicy::effect()
	 */
	function effect() {
		// Check the request protocol
		if ($this->_request->getProtocol() == 'https') {
			return AUTHORIZATION_PERMIT;
		} else {
			return AUTHORIZATION_DENY;
		}
	}
}

?>
