HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/apklausos/application/libraries/ExtensionInstaller/VersionFetcher.php
<?php

/*
 * LimeSurvey
 * Copyright (C) 2007-2015 The LimeSurvey Project Team / Carsten Schmitz
 * All rights reserved.
 * License: GNU/GPL License v2 or later, see LICENSE.php
 * LimeSurvey is free software. This version may have been modified pursuant
 * to the GNU General Public License, and as distributed it includes or
 * is derivative of works licensed under the GNU General Public License or
 * other free or open source software licenses.
 * See COPYRIGHT.php for copyright notices and details.
 */

namespace LimeSurvey\ExtensionInstaller;

use SimpleXMLElement;
use Exception;

/**
 * @since 2018-09-26
 * @author LimeSurvey GmbH
 */
abstract class VersionFetcher
{
    /**
     * <updater> XML tag from config.xml.
     * @var SimpleXMLElement
     */
    protected $updaterXml;

    /**
     * Source.
     * From <source> tag.
     * @var string
     */
    protected $source;

    /**
     * Is this fetcher marked as stable or not?
     * From <stable> tag.
     * @var boolean
     */
    protected $stable;

    /**
     * Which extension name this fetcher belongs to.
     * @var string
     */
    protected $extensionName;

    /**
     * Which extension type this fetcher belongs to.
     * @var string
     */
    protected $extensionType;

    /**
     * @param SimpleXMLElement $updaterXml
     */
    public function __construct(SimpleXMLElement $updaterXml)
    {
        $this->updaterXml = $updaterXml;
        $this->setSource((string) $updaterXml->source);
        $this->setStable((string) $updaterXml->stable === '1');
    }

    /**
     * Set source to fetch version information. Can be URL to REST API, git repo, etc.
     * @param string $source
     * @return void
     */
    public function setSource(string $source)
    {
        $this->source = $source;
    }

    /**
     * @param boolean $stable
     * @return void
     */
    public function setStable(bool $stable)
    {
        $this->stable = $stable;
    }

    /**
     * @param string $name
     * @return void
     */
    public function setExtensionName(string $name)
    {
        $this->extensionName = $name;
    }

    /**
     * @param string $type
     */
    public function setExtensionType(string $type)
    {
        $this->extensionType = $type;
    }

    /**
     * @return ?string
     */
    public function getManualUpdateUrl()
    {
        if (empty($this->updaterXml->manualUpdateUrl)) {
            return null;
        } else {
            return (string) $this->updaterXml->manualUpdateUrl;
        }
    }

    /**
     * Get latest version for configured source.
     * @return string Semantic versioning string.
     */
    abstract public function getLatestVersion();

    /**
     * Get latest security version for configured source.
     * @return string Semantic versioning string.
     */
    abstract public function getLatestSecurityVersion();
}