yatero/enivronment-picker

Choose a labeled environment based on environment variables or URL.

v1.0.2 2019-03-15 14:44 UTC

This package is auto-updated.

Last update: 2024-09-16 03:26:20 UTC


README

This class lets your applications determine which labeled environment is it running in, based on:

  • an environment variable (detected with getenv())
  • a passed URL to the EnvironmentPicker::get() function
  • the current URL (when not run trouh CLI)

Usage

By default, if an environment could not be determined from an environment variable or an URL, the class returns a default label, which is production.

Using host detection

Please note, that when using EnvironmentPicker::get() the getenv() value always gets precedence when both the environment value and labeled regex expressions are present.

$environments = array(
    'local'   => '/^(localhost(:{d}+)?)|(127\.0\.0\.1(:{d}+)?)$/i',
    'staging' => '/^(demo\.my-website\.com)|(8\.8\.8\.8)$/i'
);

// Initialize environments
\Yatero\EnvironmentPicker\EnvironmentPicker::init($environments);

// Returns the label of the environment for the current URL
\Yatero\EnvironmentPicker\EnvironmentPicker::get();


// Return the label of the environment for the given URL
\Yatero\EnvironmentPicker\EnvironmentPicker::get('https://demo.my-website.com/foo/bar');

Using a predefined environment value

You can set the environment variable in your server configurations, in your .htaccess file (if you are using Apache) or on runtime while calling export ENGINE_ENV=staging.

Be careful and initialize the allowed environments beforehand. By default only environments from the list are allowed as values. If you would like to allow ENGINE_ENV to take any value, you should call EnvironmentPicker::strict(false)

$environments = array(
    'local'   => null,
    'staging' => null
);

// Initialize environments
\Yatero\EnvironmentPicker\EnvironmentPicker::init($environments);

// Before getting the current environment make sure that you have the right variable name
\Yatero\EnvironmentPicker\EnvironmentPicker::envVarKey('MY_VAR');

\Yatero\EnvironmentPicker\EnvironmentPicker::get();

You can set labled regex values as a fallback, if the variable is not set or empty.

$environments = array(
    'local'   => '/^(localhost(:{d}+)?)|(127\.0\.0\.1(:{d}+)?)$/i',
    'staging' => '/^(demo\.my-website\.com)|(8\.8\.8\.8)$/i'
);

// Initialize environments
\Yatero\EnvironmentPicker\EnvironmentPicker::init($environments);

// Before getting the current environment make sure that you have the right variable name
\Yatero\EnvironmentPicker\EnvironmentPicker::envVarKey('MY_VAR');

\Yatero\EnvironmentPicker\EnvironmentPicker::get();