
Research
/Security News
npm Author Qix Compromised via Phishing Email in Major Supply Chain Attack
npm author Qix’s account was compromised, with malicious versions of popular packages like chalk-template, color-convert, and strip-ansi published.
@umbrellio/cofman
Advanced tools
Node.js configuration engine
const { Cofman, FileSource, EnvSourc, ObjectSource } = require("@umbrellio/cofman")
const instance = new Cofman()
instance.use(new FileSource({ path: "/path/to/file.yml" }))
instance.use(new FileSource({ path: "/path/to/file.json" }))
instance.use(new ObjectSource({ custom: "value" }))
instance.use(new EnvSource({ prefix: "APP" }))
const config = instance.parse()
config.get("database.url")
$ yarn add @umbrellio/cofman
const instance = new Cofman()
Methods
.use(source)
– setup a config source (see sources docs).parse()
– parse sources and return Config
objectMethods
.get(key: string, default: any)
– returns a value by corresponding key or default value
key
can be nested by using .
. For example – database.password
.asObject()
– returns config as a plain object
Cofman supports multiple sources for getting values in different ways.
Get values from env variables. All keys becomes camelCase.
new EnvSource(options)
Options
prefix: string
(optional, default: ""
) – prefix for filtering env vars
eg. if prefix: "APP"
cofman will only get vars starts with APP_
(APP_DATABASE_URL
, APP_NAME
, etc.)tryParse: boolean
(optional, default: true
) – try to parse value as a jsonnestingDelitemer: string
(optional, default: __
) – delimeter for getting nesting values
eg. SOME__NESTING_VALUE=1
becomes some: { nestingValue: 1 }
Reads config from json
and yaml
files.
new FileSource(options)
Options
path: string
(required) – path to config fileparser: Parser
(optional, determinites by file extension) – parser to use for this file contentfailMissing: boolean
(optional, default: false
) – fail when file missing or notYou can use custom file parsers using following interface:
interface Parser {
extensions: string[] // supported file extensions
parse(content: string): Object // takes file content and returns parsed object
}
Just your custom object
new ObjectSource(object)
Bug reports and pull requests are welcome on GitHub at https://github.com/umbrellio/cofman.
Released under MIT License.
Created by Aleksei Bespalov.
FAQs
Node.js configuration engine
We found that @umbrellio/cofman demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 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.
Research
/Security News
npm author Qix’s account was compromised, with malicious versions of popular packages like chalk-template, color-convert, and strip-ansi published.
Research
Four npm packages disguised as cryptographic tools steal developer credentials and send them to attacker-controlled Telegram infrastructure.
Security News
Ruby maintainers from Bundler and rbenv teams are building rv to bring Python uv's speed and unified tooling approach to Ruby development.