2017 © Pedro Peláez
 

library environment-detection

A library for defining and detecting execution environments

image

liftkit/environment-detection

A library for defining and detecting execution environments

  • Monday, January 29, 2018
  • by rwstream9
  • Repository
  • 1 Watchers
  • 0 Stars
  • 101 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 16 % Grown

The README.md

Environment Detection

A simple library to detect the environment your application is currently executing in., (*1)

Create a new Detector

use LiftKit\EnvironmentDetection\Detector;

$detector = new Detector;

Match HTTP_HOST

Match the value is $_SERVER['HTTP_HOST']. This value is passed to php from the web server as the domain the request was sent to., (*2)

$detector->ifHttpHost('something.localhost', 'local')
    ->ifHttpHost('test.something.com', 'test')
    ->ifHttpHost('www.something.com', 'production')
    ->ifHttpHost('*.something.com', 'subdomain')
    ->ifHttpHost('*', 'default'); // if no other pattern matches

$environment = $detector->resolve();

$environment will equal one of 'development', 'test', 'production', 'subdomain', or 'default', depending on the host the application was accessed at. Note that $_SERVER will not be populated if the application was accessed via CLI. None of these will pass, and $detector->resolve() will return null., (*3)

Match the hostname of the current machine

This tests against the output of the command uname -n (or the equivalent php_uname('n'))., (*4)

$detector->clear() // clear previous rules
    ->ifHostName('*.local', 'local') // default pattern for macOS
    ->ifHostName('*', 'default'); // will match all others

$environment = $detector->resolve();

Match an environment variable

This test against a variable in $_ENV., (*5)

$detector->clear() // clear previous rules
    ->ifEnv('environment', 'dev', 'local') // tests $_ENV['development'] == 'dev'
    ->ifEnv('environment', '*', 'default'); // will match all values of $_ENV['environment'], if $_ENV['environment'] is defined

$environment = $detector->resolve();

Match an arbitrary value

$detector->clear() // clear previous rules
    ->ifMatch(php_uname('s'), 'Darwin', 'mac') // if macOS
    ->ifMatch(php_uname('s'), 'Linux', 'linux'); // if Linux

$environment = $detector->resolve();

Note php_uname('s') reports the name of the operating system kernel., (*6)

Match a boolean expression and defaults

$detector->clear() // clear previous rules
    ->ifBool(defined('TEST_ENVIRONMENT'), 'test')
    ->defaultTo('production'); // default value

$environment = $detector->resolve();

You can also mix and match conditions

$detector->clear() // clear previous rules
    ->ifMatch(php_sapi_name(), 'cli', 'cli') // in CLI
    ->defaultTo('web'); // otherwise assume web request

$environment = $detector->resolve();

No matches

$detector->resolve() will return null if there is no default and no condition matches., (*7)

$detector->clear(); // clear previous rules

$environment = $detector->resolve(); // $environment === null

The Versions

29/01 2018

dev-master

9999999-dev

A library for defining and detecting execution environments

  Sources   Download

LGPL 2.1 LGPL-2.1-only

The Development Requires

29/01 2018

v1.0.3

1.0.3.0

A library for defining and detecting execution environments

  Sources   Download

LGPL-2.1-only

The Development Requires

07/07 2017

v1.0.2

1.0.2.0

A library for defining and detecting execution environments

  Sources   Download

LGPL 2.1

The Development Requires

07/07 2017

v1.0.1

1.0.1.0

A library for defining and detecting execution environments

  Sources   Download

LGPL 2.1

The Development Requires

06/07 2017

v1.0.0

1.0.0.0

A library for defining and detecting execution environments

  Sources   Download

LGPL 2.1

The Development Requires