Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
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 INTERPOLATE_OPTION_[CONFIGNAME] (or you can also set it inside values
or json
type obj
. See an extreme Example)
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. 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}';
}
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 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);
FAQs
Interpolate a Javascript Object or String with json - Advanced
The npm package interpolate-json receives a total of 12,251 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.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.