SAREhub/PHP_Commons

View on GitHub
src/SAREhub/Commons/Misc/EnvironmentHelper.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

namespace SAREhub\Commons\Misc;


class EnvironmentHelper
{
    /**
     * Returns value of environment variable or default value
     * @param string $name
     * @param null $defaultValue
     * @return mixed value from env or defaultValue
     */
    public static function getVar(string $name, $defaultValue = null)
    {
        $value = getenv($name);
        return $value !== false ? $value : $defaultValue;
    }

    /**
     * Returns value of environment variable or throws Exception when is not defined
     * @param string $name
     * @return mixed value from env
     * @throws EnvVarNotFoundException
     */
    public static function getRequiredVar(string $name)
    {
        $value = getenv($name);
        if ($value === false) {
            throw EnvVarNotFoundException::create($name);
        }
        return $value;
    }

    /**
     * Returns values of environment variables defined in schema parameter
     * @param array $schema Format: ["variableName" => defaultValue]
     * @param string $prefix Its added to variableName when getting value from env
     * @return array ["variableName" => valueFromEnv|defaultValue]
     */
    public static function getVars(array $schema, string $prefix = ""): array
    {
        $env = [];
        foreach ($schema as $name => $default) {
            $env[$name] = self::getVar($prefix . $name, $default);
        }
        return $env;
    }
}