Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
interpolate-json
Advanced tools
Interpolate a Javascript Object or string with 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${= JavaScript.expression() =}
evaluation{{parameter boundary}}
declaration# with npm
npm install interpolate-json
# or with Yarn
yarn add interpolate-json
// declare the varible at the beginning
const interpolation = require('interpolate-json').interpolation;
// or
const { interpolation } = require('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
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.
json
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 (''
).
json
{
prefix: '${',
suffix: '}',
subKeyPointer: '.',
funcSpecifier: '=', // *read-only
escapeSpecifier: '*' // *read-only
}
more in Configurations
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 INTERPOLATEOPTION[CONFIGNAME] (or you can also set it inside values
or json
type obj
. See an extreme Example)
boolean
false
INTERPOLATE_OPTION_DEBUG
Set it true to turn on logging to help debug why certain things are not working as expected. Can be turned on globally.
string
${
INTERPOLATE_OPTION_PREFIX
The prefix notation for an interpolation parameter.
string
}
INTERPOLATE_OPTION_SUFFIX
The suffix notation for an interpolation parameter.
string
.
INTERPOLATE_OPTION_SUBKEYPOINTER
The json object tree sub-node pointer for interpolation parameter.
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}';
}
string
=
The notation after prefix
& before suffix
to describe a function expression boundary. (e.g. ${= Func(${param1}, ${param2}) =}
).
string
*
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.
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);
FAQs
Interpolate a Javascript Object or String with json - Advanced
The npm package interpolate-json receives a total of 17,395 weekly downloads. As such, interpolate-json popularity was classified as popular.
We found that interpolate-json demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.