
Security News
pnpm 11.5 Adds Support for Recognizing npm Staged Publishes
pnpm 11.5 now recognizes npm staged publish approvals in release metadata, preventing those releases from being mistaken for lower-trust package publishes.
@forwardimpact/libconfig
Advanced tools
Environment-aware application settings — services and CLIs load configuration without custom plumbing.
Environment-aware application settings — services and CLIs load configuration without custom plumbing.
import { createConfig, createServiceConfig } from '@forwardimpact/libconfig';
const config = await createServiceConfig('myservice', { port: 3000 });
A product's init verb hands its starter material to bootstrapProject,
which writes config/config.json and .env under namespace-scoped
ownership semantics. Same-key-same-value writes are no-ops; same-key-
different-value writes refuse without explicit overwrite intent, so two
products with disjoint top-level namespaces can converge against the same
target directory.
import { bootstrapProject } from '@forwardimpact/libconfig';
await bootstrapProject({
target, // absolute path; defaults to process.cwd()
fragment: { // top-level keys are product-owned namespaces; {} or omitted is allowed
product: {
guide: { systemPrompt: '…' }, // fit-guide's slice under top-level `product`
},
service: {
mcp: { systemPrompt: '…' }, // fit-guide's slice under top-level `service`
},
},
env: { // .env entries; {} or omitted is allowed
SERVICE_SECRET: '…',
MCP_TOKEN: '…',
},
overwrites: { // explicit overwrite intent, partitioned per file
config: ['product'], // top-level namespace names (single segment)
env: ['MCP_TOKEN'], // bare keys
},
});
bootstrapProject({ target, fragment, env, overwrites }).
Returns void on success; throws a refusal Error whose cause carries
{ kind, path, overwriteSurface } when a write conflicts and the caller
did not signal overwrite intent.fragment are the
namespaces a product owns. Use the nested form ({ product: { guide: … } }) — that's the shape the libconfig reader resolves and the shape
every in-tree caller emits. Cross-namespace writes (different top-level
keys, or disjoint sub-keys under a shared top-level) never collide;
within a namespace, any leaf disagreement refuses with a leaf-path
diagnostic.overwrites.config: [topLevelKey] (single-
segment names) or overwrites.env: [bareKey] to opt in to replacing
a conflicting value. The refusal message names both the conflicting
leaf path (e.g. product.guide.systemPrompt) and the surface; the
overwrite-intent entry remains the top-level key (product) —
forgiving a single leaf forgives the whole namespace by design, so
pick the smallest top-level that contains the disputed leaf..env primitives — bootstrapProject delegates per-key .env
writes to @forwardimpact/libsecret's updateEnvFile, which preserves
comment lines, the trailing newline, and mode 0o600.bootstrapProject always materialises target/config/config.json (writing
{} when fragment is empty and the file is absent) so subsequent reader
invocations anchor locally rather than upward-walking into an ancestor
config/. .env is created only when at least one entry is supplied; an
empty env against an existing .env is a no-op.
FAQs
Environment-aware application settings — services and CLIs load configuration without custom plumbing.
We found that @forwardimpact/libconfig demonstrated a healthy version release cadence and project activity because the last version was released less than 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
pnpm 11.5 now recognizes npm staged publish approvals in release metadata, preventing those releases from being mistaken for lower-trust package publishes.

Security News
Federal audit finds NIST lacked a plan to clear the NVD backlog, wasted funds on duplicate work, and delayed use of CISA data.

Research
/Security News
A mini Shai-Hulud campaign compromised Red Hat Cloud Services npm packages to steal developer and CI/CD secrets during installation.