
Product
Rubygems Ecosystem Support Now Generally Available
Socket's Rubygems ecosystem support is moving from beta to GA, featuring enhanced security scanning to detect supply chain threats beyond traditional CVEs in your Ruby dependencies.
@cyberalien/conditional-replacements
Advanced tools
This library is designed for build time import paths replacements.
It was created for Iconify Icon Finder build process, making it possible to substitute directories during build process. This makes it possible to use various language packs, icon packs, replace unused components with empty functions.
Replacements class is for replacing imports.
Example of original code:
import { React } from 'react';
// @iconify-replacement: '/components/default/'
import { Input } from './components/default/input';
import { Button } from './components/default/button';
// @iconify-replacement: '/phrases/'
import { lang } from '../phrases/';
Parser:
import { readFileSync, writeFileSync } from 'fs';
import { Replacements } from '@cyberalien/conditional-replacements';
const replacements = new Replacements(
{
'/components/default/': '/components/figma/',
'/phrases/': '/phrases_de/',
},
'@iconify-replacement'
);
// Parse ./lib/foo.js
let code = readFileSync('./lib/foo.js', 'utf8');
cost = replacements.parse(code);
writeFileSync('./lib/foo.js', code, 'utf8');
Parsed code:
import { React } from 'react';
import { Input } from './components/figma/input';
import { Button } from './components/figma/button';
import { lang } from '../phrases_de/';
In example above '/components/default/' was replaced with '/components/figma/', '/phrases/' was replaced with '/phrases_de/'.
There can only be one replacement active at a time.
Only lines following replacement comment are replaced. Any invalid line will break replacements.
Example:
// @iconify-replacement: '/components/default/'
import { Input } from './components/default/input';
import { Button } from './components/default/button';
will result in:
import { Input } from './components/figma/input';
import { Button } from './components/default/button';
Second import was not replaced because empty line above it broke pattern.
This library is dual-licensed under Apache 2.0 and GPL 2.0 license. You may select, at your option, one of the above-listed licenses.
SPDX-License-Identifier: Apache-2.0 OR GPL-2.0
© 2020 Vjacheslav Trushkin
FAQs
Replacements in code
The npm package @cyberalien/conditional-replacements receives a total of 1 weekly downloads. As such, @cyberalien/conditional-replacements popularity was classified as not popular.
We found that @cyberalien/conditional-replacements 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's Rubygems ecosystem support is moving from beta to GA, featuring enhanced security scanning to detect supply chain threats beyond traditional CVEs in your Ruby dependencies.
Research
The Socket Research Team investigates a malicious npm package that appears to be an Advcash integration but triggers a reverse shell during payment success, targeting servers handling transactions.
Security Fundamentals
The Socket Threat Research Team uncovers how threat actors weaponize shell techniques across npm, PyPI, and Go ecosystems to maintain persistence and exfiltrate data.