定制 liftkit/environment-detection 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

liftkit/environment-detection

最新稳定版本:v1.0.3

Composer 安装命令:

composer require liftkit/environment-detection

包简介

A library for defining and detecting execution environments

README 文档

README

A simple library to detect the environment your application is currently executing in.

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.

$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.

Match the hostname of the current machine

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

$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.

$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.

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.

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

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

统计信息

  • 总下载量: 735
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: LGPL-2.1-only
  • 更新时间: 2017-07-06