Interpolate a Javascript Object (json) or string with (another) json - Advanced (or Substitution, as others may like to call it).
Minimalist & lightweight ;) approach to handle interpolation, which packs way more punch than simple string parameter replacement.
Supports:
${string}
interpolation${json}
interpolation${multi.level}
json notation- single
${= JavaScript.expression() =}
evaluation - custom
{{parameter_boundary}}
declaration
# with npm
npm install interpolate-json
# or with Yarn
yarn add interpolate-json
Imp: If you're using Node v12 then install the legacy version
"^2.3.0"
npm install interpolate-json@^2.3.0 // or yarn add interpolate-json@^2.3.0
// declare the varible at the beginning
const interpolation = require('interpolate-json').interpolation;
// or
const { interpolation } = require('interpolate-json');
// or the import syntax
import { interpolation } from 'interpolate-json';
// String
let someString = 'I want to be ${character} in ${business.type} by being a ${business.post}';
let values = {
character: 'a Hero',
business: {
type: 'saving people',
post: 'Doctor',
},
};
someString = interpolation.expand(someString, values);
console.log(someString);
// output: I want to be a Hero in saving people by being a Doctor
// or using ENVIRONMENT_VARIABLES
// test-string.js
let someString = "Hi, my name is '${USER_NAME}'. I'm ${USER_AGE}";
console.log(interpolation.expand(someString, process.env));
// execute using: USER_NAME='John' USER_AGE=19 node test-string.js
// output: Hi, my name is 'John'. I'm 19
// Json
let myJson = {
port: '8080',
server: 'www.example.com',
user: 'abcd',
password: 'P@ss#ord',
url: 'https://${user}:${= encodeURIComponent(${password}) =}@${server}:${port}'
};
console.log(interpolation.expand(myJson)); // Look for values inside itself
// output:
{
"port": "8080",
"server": "www.example.com",
"user": "abcd",
"password": "P@ss#ord",
"url": "https://abcd:P%40ss%23ord@www.example.com:8080"
}
// Let's sweeten the deal with ENVIRONMENT_VARIABLES
// test-json.js
let myJson = {
port: '${PORT}',
server: 'www.example.com',
user: '${=${USER_NAME}.toLowerCase()=}',
password: '${USER_PASSWORD}',
url: 'https://${user}:${= encodeURIComponent(${password}) =}@${server}:${port}'
};
console.log(interpolation.expand(myJson));
// execute using: PORT=8080 USER_NAME='John' USER_PASSWORD='P@ss#ord' node test-json.js
// output:
{
"port": "8080",
"server": "www.example.com",
"user": "john",
"password": "P@ss#ord",
"url": "https://john:P%40ss%23ord@www.example.com:8080"
}
Notice that
${= =}
notation. It's a cool way to use JavaScript expression (not expressions, yet, just a single line).
Syntax: interpolation.expand(obj, values = null, options = null);
The expand
function takes 3 parameters
- type:
string | json
The object to be interpolated. For string
type, values
must be provided. In case of json
type, it can interpolate itself if the required values are all present.
- type:
json
- default: null
The values for the interpolated parameter placeholders (i.e. ${param-name}
). In case of json
type obj
, the values
override any of the existing obj
properties (like, overriding with Environment variables). If any of the parameters is not present, it's replaced by empty string (''
).
- type:
json
- default:
{
prefix: '${',
suffix: '}',
subKeyPointer: '.',
funcSpecifier: '=', // *read-only
escapeSpecifier: '*' // *read-only
}
more in Configurations
- type:
string | json
Based upon the type of the obj
. In case of any unsupported types, original obj
will be returned.
[Note: it does not change the actual
obj
]
The options
setup. Each section can be individually set through Environment Variables INTERPOLATE_OPTION_[CONFIGNAME] (or you can also set it inside values
or json
type obj
. See an extreme Example)
- type:
string
- default:
${
- Environment Variable override:
INTERPOLATE_OPTION_PREFIX
The prefix notation for an interpolation parameter.
- type:
string
- default:
}
- Environment Variable override:
INTERPOLATE_OPTION_SUFFIX
The suffix notation for an interpolation parameter.
- type:
string
- default:
.
- Environment Variable override:
INTERPOLATE_OPTION_SUBKEYPOINTER
The json object tree sub-node pointer for interpolation parameter. The possible value is restricted to dot(.
), hash(#
), underscore(_
) & colon(:
) (or it's multiple, like: ::
etc)
let json = {
a: 'A',
b: 'B',
c: {
d: 'D',
e: 'E',
f: {
g: 'G',
},
},
};
// If subKeyPointer = '.'
{
reference: '${c.d}';
}
// If subKeyPointer = '#'
{
reference: '${c#f#g}';
}
- type:
string
- fixed value:
=
The notation after prefix
& before suffix
to describe a function expression boundary. (e.g. ${= Func(${param1}, ${param2}) =}
).
- type:
string
- fixed value:
*
The notation after prefix
to escape string expression for certain data-types (like number, boolean etc.).
This option is only applicable to
json
typeobj
let json = {
myKey: '${*keyValue}',
isKey: '${*boolValue}',
};
// values = {keyValue: 123.45, boolValue: false}
interpolatedJson = {
myKey: 123.45, // instead of myKey: "123.45"
isKey: false, // instead of isKey: "false"
};
// When declared as a variable at the beginning
const interpolation = require('interpolate-json');
Described so far since Declaration
& Definition
.
// Syntax I
const interpolation = require('interpolate-json').interpolation;
interpolation.expand(obj, value);
// Syntax II
const { interpolation } = require('interpolate-json');
interpolation.expand(obj, value);
Globally turn on debug
flag. If set to true
, it'll write console output of detailed operations to help debug why certain things are (not) working as expected.
Can also be turned on via setting Environment Variable INTERPOLATE_OPTION_DEBUG
to true
// to globally turn it on
const interpolation = require('interpolate-json').interpolation;
interpolation.debug();
// to globally turn off debugging output
interpolation.debug(false);