@backstage/config
Advanced tools
Comparing version 0.0.0-nightly-20214622436 to 0.0.0-nightly-20217172188
# @backstage/config | ||
## 0.0.0-nightly-20214622436 | ||
## 0.0.0-nightly-20217172188 | ||
### Patch Changes | ||
- 90f25476a: Extended the `Config` interface to have an optional `subscribe` method that can be used be notified of updates to the configuration. | ||
## 0.1.6 | ||
### Patch Changes | ||
- e9d3983ee: Add warning when trying to access configuration values that have been filtered out by visibility. | ||
## 0.1.5 | ||
### Patch Changes | ||
- d8b81fd28: Bump `json-schema` dependency from `0.2.5` to `0.3.0`. | ||
@@ -8,0 +20,0 @@ |
@@ -54,4 +54,6 @@ 'use strict'; | ||
} | ||
return configs.reduce((previousReader, {data, context}) => { | ||
return new ConfigReader(data, context, previousReader); | ||
return configs.reduce((previousReader, {data, context, filteredKeys}) => { | ||
const reader = new ConfigReader(data, context, previousReader); | ||
reader.filteredKeys = filteredKeys; | ||
return reader; | ||
}, void 0); | ||
@@ -81,6 +83,14 @@ } | ||
getOptional(key) { | ||
var _a; | ||
var _a, _b; | ||
const value = this.readValue(key); | ||
const fallbackValue = (_a = this.fallback) == null ? void 0 : _a.getOptional(key); | ||
if (value === void 0) { | ||
if (process.env.NODE_ENV === "development") { | ||
if (fallbackValue === void 0 && key) { | ||
const fullKey = this.fullKey(key); | ||
if ((_b = this.filteredKeys) == null ? void 0 : _b.includes(fullKey)) { | ||
console.warn(`Failed to read configuration value at '${fullKey}' as it is not visible. See https://backstage.io/docs/conf/defining#visibility for instructions on how to make it visible.`); | ||
} | ||
} | ||
} | ||
return fallbackValue; | ||
@@ -103,5 +113,4 @@ } else if (fallbackValue === void 0) { | ||
const fallbackConfig = (_a = this.fallback) == null ? void 0 : _a.getOptionalConfig(key); | ||
const prefix = this.fullKey(key); | ||
if (isObject(value)) { | ||
return new ConfigReader(value, this.context, fallbackConfig, prefix); | ||
return this.copy(value, key, fallbackConfig); | ||
} | ||
@@ -121,2 +130,3 @@ if (value !== void 0) { | ||
getOptionalConfigArray(key) { | ||
var _a; | ||
const configs = this.readConfigValue(key, (values) => { | ||
@@ -134,5 +144,11 @@ if (!Array.isArray(values)) { | ||
if (!configs) { | ||
if (process.env.NODE_ENV === "development") { | ||
const fullKey = this.fullKey(key); | ||
if ((_a = this.filteredKeys) == null ? void 0 : _a.some((k) => k.startsWith(fullKey))) { | ||
console.warn(`Failed to read configuration array at '${key}' as it does not have any visible elements. See https://backstage.io/docs/conf/defining#visibility for instructions on how to make it visible.`); | ||
} | ||
} | ||
return void 0; | ||
} | ||
return configs.map((obj, index) => new ConfigReader(obj, this.context, void 0, this.fullKey(`${key}[${index}]`))); | ||
return configs.map((obj, index) => this.copy(obj, `${key}[${index}]`)); | ||
} | ||
@@ -200,7 +216,18 @@ getNumber(key) { | ||
} | ||
copy(data, key, fallback) { | ||
const reader = new ConfigReader(data, this.context, fallback, this.fullKey(key)); | ||
reader.filteredKeys = this.filteredKeys; | ||
return reader; | ||
} | ||
readConfigValue(key, validate) { | ||
var _a; | ||
var _a, _b; | ||
const value = this.readValue(key); | ||
if (value === void 0) { | ||
return (_a = this.fallback) == null ? void 0 : _a.readConfigValue(key, validate); | ||
if (process.env.NODE_ENV === "development") { | ||
const fullKey = this.fullKey(key); | ||
if ((_a = this.filteredKeys) == null ? void 0 : _a.includes(fullKey)) { | ||
console.warn(`Failed to read configuration value at '${fullKey}' as it is not visible. See https://backstage.io/docs/conf/defining#visibility for instructions on how to make it visible.`); | ||
} | ||
} | ||
return (_b = this.fallback) == null ? void 0 : _b.readConfigValue(key, validate); | ||
} | ||
@@ -207,0 +234,0 @@ const result = validate(value); |
@@ -11,4 +11,15 @@ declare type JsonPrimitive = number | string | boolean | null; | ||
data: JsonObject; | ||
filteredKeys?: string[]; | ||
}; | ||
declare type Config = { | ||
/** | ||
* Subscribes to the configuration object in order to receive a notification | ||
* whenever any value within the configuration has changed. | ||
* | ||
* This method is optional to implement, and consumers need to check if it is | ||
* implemented before invoking it. | ||
*/ | ||
subscribe?(onChange: () => void): { | ||
unsubscribe: () => void; | ||
}; | ||
has(key: string): boolean; | ||
@@ -37,2 +48,10 @@ keys(): string[]; | ||
private readonly prefix; | ||
/** | ||
* A set of key paths that where removed from the config due to not being visible. | ||
* | ||
* This was added as a mutable private member to avoid changes to the public API. | ||
* Its only purpose of this is to warn users of missing visibility when running | ||
* the frontend in development mode. | ||
*/ | ||
private filteredKeys?; | ||
static fromConfigs(configs: AppConfig[]): ConfigReader; | ||
@@ -57,2 +76,3 @@ constructor(data: JsonObject | undefined, context?: string, fallback?: ConfigReader | undefined, prefix?: string); | ||
private fullKey; | ||
private copy; | ||
private readConfigValue; | ||
@@ -59,0 +79,0 @@ private readValue; |
@@ -45,4 +45,6 @@ import cloneDeep from 'lodash/cloneDeep'; | ||
} | ||
return configs.reduce((previousReader, {data, context}) => { | ||
return new ConfigReader(data, context, previousReader); | ||
return configs.reduce((previousReader, {data, context, filteredKeys}) => { | ||
const reader = new ConfigReader(data, context, previousReader); | ||
reader.filteredKeys = filteredKeys; | ||
return reader; | ||
}, void 0); | ||
@@ -72,6 +74,14 @@ } | ||
getOptional(key) { | ||
var _a; | ||
var _a, _b; | ||
const value = this.readValue(key); | ||
const fallbackValue = (_a = this.fallback) == null ? void 0 : _a.getOptional(key); | ||
if (value === void 0) { | ||
if (process.env.NODE_ENV === "development") { | ||
if (fallbackValue === void 0 && key) { | ||
const fullKey = this.fullKey(key); | ||
if ((_b = this.filteredKeys) == null ? void 0 : _b.includes(fullKey)) { | ||
console.warn(`Failed to read configuration value at '${fullKey}' as it is not visible. See https://backstage.io/docs/conf/defining#visibility for instructions on how to make it visible.`); | ||
} | ||
} | ||
} | ||
return fallbackValue; | ||
@@ -94,5 +104,4 @@ } else if (fallbackValue === void 0) { | ||
const fallbackConfig = (_a = this.fallback) == null ? void 0 : _a.getOptionalConfig(key); | ||
const prefix = this.fullKey(key); | ||
if (isObject(value)) { | ||
return new ConfigReader(value, this.context, fallbackConfig, prefix); | ||
return this.copy(value, key, fallbackConfig); | ||
} | ||
@@ -112,2 +121,3 @@ if (value !== void 0) { | ||
getOptionalConfigArray(key) { | ||
var _a; | ||
const configs = this.readConfigValue(key, (values) => { | ||
@@ -125,5 +135,11 @@ if (!Array.isArray(values)) { | ||
if (!configs) { | ||
if (process.env.NODE_ENV === "development") { | ||
const fullKey = this.fullKey(key); | ||
if ((_a = this.filteredKeys) == null ? void 0 : _a.some((k) => k.startsWith(fullKey))) { | ||
console.warn(`Failed to read configuration array at '${key}' as it does not have any visible elements. See https://backstage.io/docs/conf/defining#visibility for instructions on how to make it visible.`); | ||
} | ||
} | ||
return void 0; | ||
} | ||
return configs.map((obj, index) => new ConfigReader(obj, this.context, void 0, this.fullKey(`${key}[${index}]`))); | ||
return configs.map((obj, index) => this.copy(obj, `${key}[${index}]`)); | ||
} | ||
@@ -191,7 +207,18 @@ getNumber(key) { | ||
} | ||
copy(data, key, fallback) { | ||
const reader = new ConfigReader(data, this.context, fallback, this.fullKey(key)); | ||
reader.filteredKeys = this.filteredKeys; | ||
return reader; | ||
} | ||
readConfigValue(key, validate) { | ||
var _a; | ||
var _a, _b; | ||
const value = this.readValue(key); | ||
if (value === void 0) { | ||
return (_a = this.fallback) == null ? void 0 : _a.readConfigValue(key, validate); | ||
if (process.env.NODE_ENV === "development") { | ||
const fullKey = this.fullKey(key); | ||
if ((_a = this.filteredKeys) == null ? void 0 : _a.includes(fullKey)) { | ||
console.warn(`Failed to read configuration value at '${fullKey}' as it is not visible. See https://backstage.io/docs/conf/defining#visibility for instructions on how to make it visible.`); | ||
} | ||
} | ||
return (_b = this.fallback) == null ? void 0 : _b.readConfigValue(key, validate); | ||
} | ||
@@ -198,0 +225,0 @@ const result = validate(value); |
{ | ||
"name": "@backstage/config", | ||
"description": "Config API used by Backstage core, backend, and CLI", | ||
"version": "0.0.0-nightly-20214622436", | ||
"version": "0.0.0-nightly-20217172188", | ||
"private": false, | ||
@@ -6,0 +6,0 @@ "publishConfig": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 1 instance in 1 package
56817
578
6