%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /var/www/projetos/suporte.iigd.com.br/src/Http/
Upload File :
Create Path :
Current File : /var/www/projetos/suporte.iigd.com.br/src/Http/Firewall.php

<?php

/**
 * ---------------------------------------------------------------------
 *
 * GLPI - Gestionnaire Libre de Parc Informatique
 *
 * http://glpi-project.org
 *
 * @copyright 2015-2024 Teclib' and contributors.
 * @copyright 2003-2014 by the INDEPNET Development Team.
 * @licence   https://www.gnu.org/licenses/gpl-3.0.html
 *
 * ---------------------------------------------------------------------
 *
 * LICENSE
 *
 * This file is part of GLPI.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 *
 * ---------------------------------------------------------------------
 */

namespace Glpi\Http;

use Session;

/**
 * @since 10.0.10
 */
final class Firewall
{
    /**
     * Nothing to check. Entrypoint accepts anonymous access.
     */
    public const STRATEGY_NO_CHECK = 'no_check';

    /**
     * Check that user is authenticated.
     */
    public const STRATEGY_AUTHENTICATED = 'authenticated';

    /**
     * Check that user is authenticated and is using a profile based on central interface.
     */
    public const STRATEGY_CENTRAL_ACCESS = 'central_access';

    /**
     * Check that user is authenticated and is using a profile based on simplified interface.
     */
    public const STRATEGY_HELPDESK_ACCESS = 'helpdesk_access';

    /**
     * Check that FAQ access is allowed (unauthenticated if public FAQ is enabled, or by checking rights).
     */
    public const STRATEGY_FAQ_ACCESS = 'faq_access';

    /**
     * Security strategy to apply by default on core ajax/front scripts.
     *
     * @TODO In GLPI 10.1, raise default level to `self::STRATEGY_CENTRAL_ACCESS`.
     *       It will require to explicitely declare `$SECURITY_STRATEGY = 'authenticated';` or `$SECURITY_STRATEGY = 'helpdesk_access';`
     *       on endpoints that do not require a central access.
     */
    private const STRATEGY_DEFAULT_FOR_CORE = self::STRATEGY_AUTHENTICATED;

    /**
     * Security strategy to apply by default on plugin ajax/front scripts.
     *
     * @TODO In GLPI 10.1, raise default level to `self::STRATEGY_AUTHENTICATED`.
     */
    private const STRATEGY_DEFAULT_FOR_PLUGINS = self::STRATEGY_NO_CHECK;

    /**
     * GLPI URLs path prefix.
     * @var string
     */
    private string $path_prefix;

    /**
     * GLPI root directory.
     * @var string
     */
    private string $root_dir;

    /**
     * GLPI plugins root directories.
     * @var string[]
     */
    private array $plugins_dirs;

    /**
     * @param string $path_prefix   GLPI URLs path prefix
     * @param string $root_dir      GLPI root directory on filesystem
     * @param array $plugins_dirs   GLPI plugins root directories on filesystem
     */
    public function __construct(string $path_prefix, string $root_dir = GLPI_ROOT, array $plugins_dirs = PLUGINS_DIRECTORIES)
    {
        $this->path_prefix = $path_prefix;
        $this->root_dir = $root_dir;
        $this->plugins_dirs = $plugins_dirs;
    }

    /**
     * Apply the firewall strategy for given path.
     *
     * @param string $path      URL path
     * @param string $strategy  Strategy to apply, or null to fallback to default strategy
     * @return void
     */
    public function applyStrategy(string $path, ?string $strategy = null): void
    {
        if ($strategy === null) {
            $strategy = $this->computeDefaultStrategy($path);
        }

        switch ($strategy) {
            case self::STRATEGY_AUTHENTICATED:
                Session::checkLoginUser();
                break;
            case self::STRATEGY_CENTRAL_ACCESS:
                Session::checkCentralAccess();
                break;
            case self::STRATEGY_HELPDESK_ACCESS:
                Session::checkHelpdeskAccess();
                break;
            case self::STRATEGY_FAQ_ACCESS:
                Session::checkFaqAccess();
                break;
            case self::STRATEGY_NO_CHECK:
                // nothing to do
                break;
            default:
                trigger_error(sprintf('Invalid `%s` strategy.', $strategy), E_USER_WARNING);
                break;
        }
    }

    /**
     * Compute the default strategy for given path.
     *
     * @param string $path  URL path
     * @return string
     */
    private function computeDefaultStrategy(string $path): string
    {
        // Check if entrypoint is a GLPI core ajax/front script.
        if (
            str_starts_with($path, $this->path_prefix . '/ajax/')
            || str_starts_with($path, $this->path_prefix . '/front/')
        ) {
            return self::STRATEGY_DEFAULT_FOR_CORE;
        }

        // Check if entrypoint is a plugin ajax/front script.
        foreach ($this->plugins_dirs as $plugins_dir) {
            $relative_path = preg_replace(
                '/^' . preg_quote($this->normalizePath($this->root_dir), '/') . '/',
                '',
                $this->normalizePath($plugins_dir)
            );

            if (preg_match('/^' . preg_quote($this->path_prefix . $relative_path, '/') . '\/[^\/]+\/(ajax|front)\/' . '/', $path) === 1) {
                // Entrypoint is a plugin ajax/front script.
                return self::STRATEGY_DEFAULT_FOR_PLUGINS;
            }
        }

        // No default security strategy for other entrypoints.
        return self::STRATEGY_NO_CHECK;
    }

    /**
     * Normalize a path, to make comparisons and relative paths computation easier.
     *
     * @param string $path
     * @return string
     */
    private function normalizePath(string $path): string
    {
        $realpath = realpath($path);
        if ($realpath !== false) {
            // Use realpath if possible.
            // As `realpath()` will return `false` on streams, we cannot always use it, or we will not be able to do unit tests on this method.
            $path = $realpath;
        }

        // Normalize all directory separators to `/`.
        $path = preg_replace('/\\\/', '/', $path);
        return $path;
    }
}

Zerion Mini Shell 1.0