config

Una herramienta de Sumor Cloud.
Más Documentación El cargador de configuración admite archivos yaml y json. Puede cargar todos los archivos en un directorio. Y convertir automáticamente el archivo al formato especificado.

CI Test Cobertura Auditoría

Instalación

npm i @sumor/config --save

Requisitos

Versión de Node.JS

Requiere Node.JS versión 16.x o superior

Requiere módulo ES de Node.JS

Como este paquete está escrito en módulo ES, por favor cambia el siguiente código en tu archivo package.json:

{
  "type": "module"
}

Uso

Métodos de entrada

load

import { load } from '@sumor/config'

meta

Cargar todos los archivos en el directorio

import { meta } from '@sumor/config'

const config = await meta(process.cwd(), ['js', 'sql'])

/*
Estructura de directorio de demostración
- root
  - car.json
  - car.sql
  - ship.js
  - plane.yml
  - truck.config.js
*/

// cargará todos los archivos de configuración de la siguiente manera
/*
{
  car: {
    name: 'car',
    sql: "..."
  },
  ship: {
    name: 'ship'
    js: '<root>/ship.js'
  },
  plane: {
    name: 'plane'
  },
  truck: {
    name: 'truck'
  }
*/

Métodos heredados

find

import { find } from '@sumor/config'

findReference

import { findReference } from '@sumor/config'

Cargar archivo de configuración

import { load } from '@sumor/config'

const config1 = await load(process.cwd(), 'demo')
// cargará demo.yml o demo.json en el directorio raíz

const config2 = await load(process.cwd(), 'demo', 'yaml')
// cargará demo.yml o demo.json en el directorio raíz, y lo convertirá a un archivo en formato yaml

Encontrar archivos de configuración

import { find } from '@sumor/config'

const config = await find(process.cwd(), 'entidad')
// cargará todos los *.entity.yml o *.entity.json en el directorio raíz
/*
 * ejemplo:
 *   car.entity.yml, bike.entity.json
 *   {
 *       "car": {...}
 *       "bike": {...}
 *   }
 * */

Encontrar archivos de configuración desde otros archivos

como archivos .vue, .js, que tienen un archivo de configuración con el mismo nombre

import { findReference } from '@sumor/config'

const config = await findReference(process.cwd(), ['vue', 'js'])
// cargará todos los *.entity.yml o *.entity.json que tengan el mismo nombre que *.vue o *.js en el directorio raíz
/*
 * ejemplo:
 *   car.entity.yml, bike.entity.json
 *   car.vue, bike.js
 *   {
 *       "car": {...}
 *       "bike": {...}
 *   }
 * */