Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@retailmenot/roux
Advanced tools
The SDK for the Roux component architecture, Roux ingredient spec, and a node interface to a pantry.
npm install @retailmenot/roux
var roux = require('@retailmenot/roux');
var pantry = roux.initialize({
name: 'my-pantry',
path: 'path/to/my/pantry',
predicates: {
less: /^index.less$/
}
});
initialize
Initialize a Pantry
instance for a pantry of ingredients. This method returns
a promise of the initialized instance and also accepts an optional Node.js-style
callback that can be used in lieu of the promise.
config
- Configuration object for the Pantry
instance
name
- the name of the pantrypath
- the path to the pantry[predicates]
- optional object of entry point predicates which will be
checked against the files contained in each ingredient in the pantry[callback]
- Optional Node.js callbackThe pantry path
will always be given as the path to the root directory of the
module. To support better dev ergonomics and allow for more control of project
structure, pantry authors may optionally specify a subdirectory to use as the
base path for ingredients by supplying the roux.pantryRoot
property in the
pantry modules' package.json
file.
Entry point predicates are the mechanism for discovering the entry points an
ingredient exposes. For each predicate, every Ingredient
instance in the
pantry will have a corresponding property in their entryPoints
map. The value
of the property will be an object if the predicate matched a file in the
ingredient and null
otherwise. Predicates for several common entry points are
provided by default.
For example, given an ingredient containing the following files:
- ingredient.md
- index.js
- index.hbs
The entryPoints
map might look like:
{
handlebars: {
filename: 'index.hbs'
},
javaScript: {
filename: 'index.js'
},
model: null,
preview: null,
previewScript: null,
sass: null
}
Predicates may be functions or regular expressions (RegExp
instances). The
predicate will be tested against each file in the root of each ingredient until
either a match is found or all files have been checked.
Function predicates are passed the name of the file to be checked as their only
argument. If the predicate can decide synchronously, it should return true
if
the file matches and false
otherwise. If the predicate cannot decide
synchronously, it should return a promise that will be resolved to true
if the
file matches and false
otherwise.
The following predicates are configured by default:
assets
- /^assets$/
handlebars
- /^index.hbs$/
javaScript
- /^index.js$/
model
- /^model.js$/
preview
- /^preview.hbs$/
previewScript
- /^preview.js$/
sass
- /^index.scss$/
Pantry
Instances of this class represent a pantry of Roux ingredients. They have the following properties:
name
- the name of the pantrypath
- the path to the pantryingredients
- an object mapping from the name of each ingredient in the
pantry to a corresponding Ingredient
instanceIngredient
Instances of this class represent a Roux ingredient. They have the following properties:
name
- the name of the ingredientpath
- the path to the ingredientpantryName
- the name of the pantry this ingredient belongs toentryPoints
- an object mapping from the name of a logical entry point
('sass', e.g.) to an object describing the entry point as provided by the
ingredient or null
if the ingredient does not provide itentryPoints
The properties of this object are either null
or an object with the following
properties:
filename
: the name of the file the ingredient provides for this entry pointparseIngredientPath
Parse the pantry and ingredient names out of an ingredient path. If passed a valid Roux ingredient path, this function returns an object with the pantry and ingredient names:
pantry
- the name of the pantry, possibly including a namespaceingredient
the name of the ingredientIf passed a string that is not a valid path, it returns null
. If passed
anything else, it throws an Error
.
resolve
Resolve a pantry or ingredient to an instance or an entry point to an absolute path to the corresponding file.
If passed a valid pantry name, this function returns a promise of the
corresponding Pantry
instance. If passed valid names of a pantry and
ingredient, it returns a promise of the corresponding Ingredient
instance. If
passed valid names of a pantry, ingredient, and entry point, it returns a
promise of the absolute path to the corresponding entry point file. In all of
these cases, an optional configuration object can be passed as the last
argument.
If passed invalid names, it throws an error. If the pantry, ingredient, or entry point cannot be found, the returned promise is rejected with an error.
pantry
: pantry nameingredient
- optional ingredient nameentryPoint
- optional entry point nameconfig
- optional configuration objectconfig.pantries
- a cache of Pantry
instancesconfig.pantrySearchPaths
- the paths to search for pantries in if not found
in the cacheFAQs
Roux SDK and specification
We found that @retailmenot/roux demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 12 open source maintainers 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
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
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.