Find and load configuration from a package.json
property, rc
file, or CommonJS
module. It has smart defaults based on traditional expectations in the JavaScript ecosystem. But it's also flexible enough to search anywhere you want and load whatever you want.
$ npm i auto-config-loader
import load from 'auto-config-loader';
const data = load('namespace', {
defaults: {
testItem2: 'some value'
}
});
Load the JS file and return the result, support .js
, .cjs
, .mjs
, .ts
.
// => app.config.js
export default {
name: 'app'
}
import { loadConf } from 'auto-config-loader/load-conf';
interface Config {
name: string;
}
const result = loadConf<Config>('./app/app.config.js');
// => { name: 'app' }
import { LoadConfOption } from 'auto-config-loader';
export type LoaderFunc<T> = (filepath: string, content: string, jsOption?: LoadConfOption) => T;
export type Loader<T> = Record<string, LoaderFunc<T>>;
export interface AutoConfOption<T> {
searchPlaces?: string[];
/** An object that maps extensions to the loader functions responsible for loading and parsing files with those extensions. */
loaders?: Loader<T>;
/** Specify default configuration. It has the lowest priority and is applied after extending config. */
defaluts?: T;
/** Resolve configuration from this working directory. The default is `process.cwd()` */
cwd?: string;
/** Default transform js configuration */
jsOption?: LoadConfOption;
}
/**
* Find and load configuration from a `package.json` property, `rc` file, or `CommonJS` module.
* @param namespace {string} Configuration base name. The default is `autoconf`.
* @param option
*/
export default function autoConf<T>(namespace?: string, option?: AutoConfOption<T>): {} & T;
Default searchPlaces
:
Discover configurations in the specified directory order.
[
'package.json',
`.${moduleName}rc`,
`.${moduleName}rc.json`,
`.${moduleName}rc.yaml`,
`.${moduleName}rc.yml`,
`.${moduleName}rc.toml`,
`.${moduleName}rc.js`,
`.${moduleName}rc.ts`,
`.${moduleName}rc.cjs`,
`.${moduleName}rc.mjs`,
`.config/${moduleName}rc`,
`.config/${moduleName}rc.json`,
`.config/${moduleName}rc.yaml`,
`.config/${moduleName}rc.yml`,
`.config/${moduleName}rc.toml`,
`.config/${moduleName}rc.js`,
`.config/${moduleName}rc.ts`,
`.config/${moduleName}rc.cjs`,
`.config/${moduleName}rc.mjs`,
`${moduleName}.config.js`,
`${moduleName}.config.ts`,
`${moduleName}.config.cjs`,
`${moduleName}.config.mjs`,
]
Configurations are loaded sequentially, and the configuration file search is terminated when a configuration file exists.
This is an example, the default yaml
/yml
does not require a loader.
import load from 'auto-config-loader';
import yaml from 'yaml';
function loadYaml(filepath, content) {
return yaml.parse(content);
}
await load('namespace', {
searchPlaces: [
'.namespacerc.yaml',
'.namespacerc.yml',
],
loaders: {
'.yaml': loadYaml,
'.yml': loadYaml,
},
defaults: {
testItem2: 'some value'
}
});
As always, thanks to our amazing contributors!
Made with contributors.
This package is licensed under the MIT License.