24hoursmedia/php-env-inject

Inject and interpolate environment variables into strings. Supports substituting default values for an env var, and escapers/formatters using callbacks. Partially supports POSIX compliant shell syntax.

1.1.1 2023-11-04 14:54 UTC

This package is auto-updated.

Last update: 2024-04-04 16:21:33 UTC


README

Inject/interpolate environment variables in strings.

  • Substitutes raw environment variables in strings
  • Supports default values if environment variable is not set
  • Supports escaping JSON strings
  • Supports a callback to write your own value modifiers / escapers

Security Considerations

⚠️ As often environment variables on a system may contain sensitive data, especially if you use dotenv, you should NEVER ALLOW USER INPUT into the interpolator.

⚠️ Only interpolate into strings that are under your control and fully trusted!

Install

composer require 24hoursmedia/php-env-inject

Usage

Interpolate env vars in a string

<?php
use T4\EnvInject\EnvInject;
putenv('YOUR_NAME=John Doe');

echo EnvInject::interpolate('Hello ${YOUR_NAME}! ${MESSAGE:-Have a nice day!}');
// Hello John Doe! Have a nice day!

Interpolation in JSON strings

Escape json values with JsonEnvInject::interpolate():

Substituting raw environment variables in JSON strings can result in failures if you have special characters in your values such as quotes. The JsonEnvInject class can escape JSON strings for you before interpolation.

<?php
use T4\EnvInject\JsonEnvInject;
putenv('FOO=f"o"o');
echo JsonEnvInject::interpolate('{"foo":"${FOO}"}');
// {"foo":"f\"o\"o"}

Modify values with a callback function

Use EnvInject::interpolateWithCallback(string $string, Closure $callback) to modify values with a callback function.

The callback function receives the value as first argument and the key as second argument. It should return the modified value to interpolate.

Use this to create your own escape functions or more complex modifiers.

Develop and run tests

Open project in a docker container:

docker run -it --rm -v $(pwd):/app -w /app php:8.0-cli-alpine /bin/sh
apk add php-curl php-mbstring php-openssl php-zip php-phar
curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin --filename=composer
composer install

# run tests
./vendor/bin/phpunit tests --testdox