@powerlines/plugin-env 0.16.184 → 0.16.187
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +24 -24
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +25 -25
- package/dist/index.mjs.map +1 -1
- package/package.json +9 -9
package/dist/index.cjs
CHANGED
|
@@ -12,7 +12,6 @@ const require_babel_plugin = require('./babel/plugin.cjs');
|
|
|
12
12
|
let _powerlines_deepkit_vendor_type = require("@powerlines/deepkit/vendor/type");
|
|
13
13
|
let defu = require("defu");
|
|
14
14
|
defu = require_runtime.__toESM(defu);
|
|
15
|
-
let powerlines_constants = require("powerlines/constants");
|
|
16
15
|
let powerlines_plugin_utils = require("powerlines/plugin-utils");
|
|
17
16
|
let _alloy_js_core_jsx_runtime = require("@alloy-js/core/jsx-runtime");
|
|
18
17
|
let _stryke_path_join = require("@stryke/path/join");
|
|
@@ -40,7 +39,12 @@ function __assignType(fn, args) {
|
|
|
40
39
|
*/
|
|
41
40
|
const plugin = __assignType((options = {}) => {
|
|
42
41
|
return [
|
|
43
|
-
(0, _powerlines_plugin_deepkit.default)(
|
|
42
|
+
(0, _powerlines_plugin_deepkit.default)({
|
|
43
|
+
...options.deepkit,
|
|
44
|
+
reflection: "default",
|
|
45
|
+
level: "all",
|
|
46
|
+
filter: {}
|
|
47
|
+
}),
|
|
44
48
|
(0, _powerlines_plugin_babel.default)(options.babel),
|
|
45
49
|
{
|
|
46
50
|
name: "env",
|
|
@@ -60,26 +64,11 @@ const plugin = __assignType((options = {}) => {
|
|
|
60
64
|
},
|
|
61
65
|
tsc: {}
|
|
62
66
|
};
|
|
63
|
-
if ((0, _stryke_type_checks_is_set_string.isSetString)(config.env.types)
|
|
64
|
-
config.env.types = (0, _stryke_convert_parse_type_definition.parseTypeDefinition)(config.env.types);
|
|
65
|
-
const file = await this.fs.resolve(config.env.types.file);
|
|
66
|
-
if (file) config.env.types.file = file;
|
|
67
|
-
} else {
|
|
67
|
+
if (!(0, _stryke_type_checks_is_set_string.isSetString)(config.env.types) && !(0, _stryke_type_checks_is_set_string.isSetString)(config.env.types?.file)) {
|
|
68
68
|
this.warn("The `env.types` configuration parameter was not provided. Please ensure this is expected.");
|
|
69
|
-
|
|
70
|
-
const file = await this.fs.resolve(envDefaultTypeDefinition.file);
|
|
71
|
-
if (file) config.env.types = (0, _stryke_convert_parse_type_definition.parseTypeDefinition)(`${file}#${envDefaultTypeDefinition.name}`);
|
|
72
|
-
}
|
|
73
|
-
if ((0, _stryke_type_checks_is_set_string.isSetString)(config.env.secrets) || config.env.secrets && (0, _stryke_type_checks_is_set_string.isSetString)(config.env.secrets.file)) {
|
|
74
|
-
config.env.secrets = (0, _stryke_convert_parse_type_definition.parseTypeDefinition)(config.env.secrets);
|
|
75
|
-
const file = await this.fs.resolve(config.env.secrets.file);
|
|
76
|
-
if (file) config.env.secrets.file = file;
|
|
77
|
-
} else {
|
|
78
|
-
const secretsDefaultTypeDefinition = await require_helpers_persistence.getSecretsDefaultTypeDefinition(this);
|
|
79
|
-
const file = await this.fs.resolve(secretsDefaultTypeDefinition.file);
|
|
80
|
-
if (file) config.env.secrets = (0, _stryke_convert_parse_type_definition.parseTypeDefinition)(`${file}#${secretsDefaultTypeDefinition.name}`);
|
|
69
|
+
config.env.types = await require_helpers_persistence.getEnvDefaultTypeDefinition(this);
|
|
81
70
|
}
|
|
82
|
-
if (
|
|
71
|
+
if (!(0, _stryke_type_checks_is_set_string.isSetString)(config.env.secrets) && !(0, _stryke_type_checks_is_set_string.isSetString)(config.env.secrets?.file)) config.env.secrets = await require_helpers_persistence.getSecretsDefaultTypeDefinition(this);
|
|
83
72
|
config.env.prefix = (0, _stryke_convert_to_array.toArray)(config.env.prefix ?? []).reduce(__assignType((ret, prefix) => {
|
|
84
73
|
const formattedPrefix = (0, _stryke_string_format_constant_case.constantCase)(prefix);
|
|
85
74
|
if (!ret.includes(formattedPrefix)) ret.push(formattedPrefix);
|
|
@@ -99,10 +88,7 @@ const plugin = __assignType((options = {}) => {
|
|
|
99
88
|
"",
|
|
100
89
|
"P\"2!\"2\"\"/#"
|
|
101
90
|
]), []));
|
|
102
|
-
this.
|
|
103
|
-
meta: { category: "env" },
|
|
104
|
-
message: `Environment configuration definition file: ${config.env.types.file}${config.env.types.name ? `#${config.env.types.name}` : ""}${config.env.secrets ? `\nSecrets configuration definition file: ${config.env.secrets?.file}${config.env.secrets?.name ? `#${config.env.secrets?.name}` : ""}` : ""}\nEnvironment variable Prefixes: ${config.env.prefix.join(", ")}\nShould inject values: ${config.env.inject ? "Yes" : "No"}\nShould validate configuration: ${config.env.validate ? "Yes" : "No"}`
|
|
105
|
-
});
|
|
91
|
+
config.tsc.filter = { id: [(0, powerlines_plugin_utils.createVirtualPrefixRegex)((0, _stryke_path_join.joinPaths)(this.builtinsPath, "env.ts")), (0, powerlines_plugin_utils.createVirtualPrefixRegex)(`${this.config.framework}:env`)] };
|
|
106
92
|
return config;
|
|
107
93
|
},
|
|
108
94
|
async configResolved() {
|
|
@@ -116,6 +102,20 @@ const plugin = __assignType((options = {}) => {
|
|
|
116
102
|
parsed: {},
|
|
117
103
|
injected: {}
|
|
118
104
|
});
|
|
105
|
+
if ((0, _stryke_type_checks_is_set_string.isSetString)(this.config.env.types) || this.config.env.types && (0, _stryke_type_checks_is_set_string.isSetString)(this.config.env.types.file)) {
|
|
106
|
+
this.config.env.types = (0, _stryke_convert_parse_type_definition.parseTypeDefinition)(this.config.env.types);
|
|
107
|
+
const file = await this.fs.resolve(this.config.env.types.file);
|
|
108
|
+
if (file) this.config.env.types.file = file;
|
|
109
|
+
}
|
|
110
|
+
if ((0, _stryke_type_checks_is_set_string.isSetString)(this.config.env.secrets) || this.config.env.secrets && (0, _stryke_type_checks_is_set_string.isSetString)(this.config.env.secrets.file)) {
|
|
111
|
+
this.config.env.secrets = (0, _stryke_convert_parse_type_definition.parseTypeDefinition)(this.config.env.secrets);
|
|
112
|
+
const file = await this.fs.resolve(this.config.env.secrets.file);
|
|
113
|
+
if (file) this.config.env.secrets.file = file;
|
|
114
|
+
}
|
|
115
|
+
this.info({
|
|
116
|
+
meta: { category: "env" },
|
|
117
|
+
message: `Environment configuration definition file: ${this.config.env.types.file}${this.config.env.types.name ? `#${this.config.env.types.name}` : ""}${this.config.env.secrets ? `\nSecrets configuration definition file: ${this.config.env.secrets?.file}${this.config.env.secrets?.name ? `#${this.config.env.secrets?.name}` : ""}` : ""}\nEnvironment variable Prefixes: ${this.config.env.prefix.join(", ")}\nShould inject values: ${this.config.env.inject ? "Yes" : "No"}\nShould validate configuration: ${this.config.env.validate ? "Yes" : "No"}`
|
|
118
|
+
});
|
|
119
119
|
if (this.config.command !== "prepare" && !this.config.skipCache && this.persistedMeta?.checksum === this.meta.checksum && (0, _stryke_fs_exists.existsSync)(require_helpers_persistence.getEnvTypeReflectionsPath(this, "env"))) {
|
|
120
120
|
this.debug(`Skipping reflection initialization as the meta checksum has not changed.`);
|
|
121
121
|
this.env.types.env = await require_helpers_persistence.readEnvTypeReflection(this, "env");
|
package/dist/index.d.cts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/index.tsx"],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/index.tsx"],"mappings":";;;;;;YAmEY,MAAA;IACR,GAAA,GAAM,gBAAA;EAAA;AAAA;;;;cAOG,MAAA,oBAA2B,gBAAA,GAAmB,gBAAA,EACzD,OAAA,GAAS,gBAAA,KAydJ,MAAA,CAAO,QAAA"}
|
package/dist/index.d.mts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.mts","names":[],"sources":["../src/index.tsx"],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"index.d.mts","names":[],"sources":["../src/index.tsx"],"mappings":";;;;;;YAmEY,MAAA;IACR,GAAA,GAAM,gBAAA;EAAA;AAAA;;;;cAOG,MAAA,oBAA2B,gBAAA,GAAmB,gBAAA,EACzD,OAAA,GAAS,gBAAA,KAydJ,MAAA,CAAO,QAAA"}
|
package/dist/index.mjs
CHANGED
|
@@ -9,8 +9,7 @@ import { EnvBuiltin } from "./components/env-builtin.mjs";
|
|
|
9
9
|
import { envBabelPlugin } from "./babel/plugin.mjs";
|
|
10
10
|
import { ReflectionClass, ReflectionKind } from "@powerlines/deepkit/vendor/type";
|
|
11
11
|
import defu from "defu";
|
|
12
|
-
import {
|
|
13
|
-
import { getDocsOutputPath } from "powerlines/plugin-utils";
|
|
12
|
+
import { createVirtualPrefixRegex, getDocsOutputPath } from "powerlines/plugin-utils";
|
|
14
13
|
import { createComponent } from "@alloy-js/core/jsx-runtime";
|
|
15
14
|
import { joinPaths } from "@stryke/path/join";
|
|
16
15
|
import { getUnique } from "@stryke/helpers/get-unique";
|
|
@@ -34,7 +33,12 @@ function __assignType(fn, args) {
|
|
|
34
33
|
*/
|
|
35
34
|
const plugin = __assignType((options = {}) => {
|
|
36
35
|
return [
|
|
37
|
-
deepkit(
|
|
36
|
+
deepkit({
|
|
37
|
+
...options.deepkit,
|
|
38
|
+
reflection: "default",
|
|
39
|
+
level: "all",
|
|
40
|
+
filter: {}
|
|
41
|
+
}),
|
|
38
42
|
babel(options.babel),
|
|
39
43
|
{
|
|
40
44
|
name: "env",
|
|
@@ -54,26 +58,11 @@ const plugin = __assignType((options = {}) => {
|
|
|
54
58
|
},
|
|
55
59
|
tsc: {}
|
|
56
60
|
};
|
|
57
|
-
if (isSetString(config.env.types)
|
|
58
|
-
config.env.types = parseTypeDefinition(config.env.types);
|
|
59
|
-
const file = await this.fs.resolve(config.env.types.file);
|
|
60
|
-
if (file) config.env.types.file = file;
|
|
61
|
-
} else {
|
|
61
|
+
if (!isSetString(config.env.types) && !isSetString(config.env.types?.file)) {
|
|
62
62
|
this.warn("The `env.types` configuration parameter was not provided. Please ensure this is expected.");
|
|
63
|
-
|
|
64
|
-
const file = await this.fs.resolve(envDefaultTypeDefinition.file);
|
|
65
|
-
if (file) config.env.types = parseTypeDefinition(`${file}#${envDefaultTypeDefinition.name}`);
|
|
66
|
-
}
|
|
67
|
-
if (isSetString(config.env.secrets) || config.env.secrets && isSetString(config.env.secrets.file)) {
|
|
68
|
-
config.env.secrets = parseTypeDefinition(config.env.secrets);
|
|
69
|
-
const file = await this.fs.resolve(config.env.secrets.file);
|
|
70
|
-
if (file) config.env.secrets.file = file;
|
|
71
|
-
} else {
|
|
72
|
-
const secretsDefaultTypeDefinition = await getSecretsDefaultTypeDefinition(this);
|
|
73
|
-
const file = await this.fs.resolve(secretsDefaultTypeDefinition.file);
|
|
74
|
-
if (file) config.env.secrets = parseTypeDefinition(`${file}#${secretsDefaultTypeDefinition.name}`);
|
|
63
|
+
config.env.types = await getEnvDefaultTypeDefinition(this);
|
|
75
64
|
}
|
|
76
|
-
if (config.env.
|
|
65
|
+
if (!isSetString(config.env.secrets) && !isSetString(config.env.secrets?.file)) config.env.secrets = await getSecretsDefaultTypeDefinition(this);
|
|
77
66
|
config.env.prefix = toArray(config.env.prefix ?? []).reduce(__assignType((ret, prefix) => {
|
|
78
67
|
const formattedPrefix = constantCase(prefix);
|
|
79
68
|
if (!ret.includes(formattedPrefix)) ret.push(formattedPrefix);
|
|
@@ -93,10 +82,7 @@ const plugin = __assignType((options = {}) => {
|
|
|
93
82
|
"",
|
|
94
83
|
"P\"2!\"2\"\"/#"
|
|
95
84
|
]), []));
|
|
96
|
-
this.
|
|
97
|
-
meta: { category: "env" },
|
|
98
|
-
message: `Environment configuration definition file: ${config.env.types.file}${config.env.types.name ? `#${config.env.types.name}` : ""}${config.env.secrets ? `\nSecrets configuration definition file: ${config.env.secrets?.file}${config.env.secrets?.name ? `#${config.env.secrets?.name}` : ""}` : ""}\nEnvironment variable Prefixes: ${config.env.prefix.join(", ")}\nShould inject values: ${config.env.inject ? "Yes" : "No"}\nShould validate configuration: ${config.env.validate ? "Yes" : "No"}`
|
|
99
|
-
});
|
|
85
|
+
config.tsc.filter = { id: [createVirtualPrefixRegex(joinPaths(this.builtinsPath, "env.ts")), createVirtualPrefixRegex(`${this.config.framework}:env`)] };
|
|
100
86
|
return config;
|
|
101
87
|
},
|
|
102
88
|
async configResolved() {
|
|
@@ -110,6 +96,20 @@ const plugin = __assignType((options = {}) => {
|
|
|
110
96
|
parsed: {},
|
|
111
97
|
injected: {}
|
|
112
98
|
});
|
|
99
|
+
if (isSetString(this.config.env.types) || this.config.env.types && isSetString(this.config.env.types.file)) {
|
|
100
|
+
this.config.env.types = parseTypeDefinition(this.config.env.types);
|
|
101
|
+
const file = await this.fs.resolve(this.config.env.types.file);
|
|
102
|
+
if (file) this.config.env.types.file = file;
|
|
103
|
+
}
|
|
104
|
+
if (isSetString(this.config.env.secrets) || this.config.env.secrets && isSetString(this.config.env.secrets.file)) {
|
|
105
|
+
this.config.env.secrets = parseTypeDefinition(this.config.env.secrets);
|
|
106
|
+
const file = await this.fs.resolve(this.config.env.secrets.file);
|
|
107
|
+
if (file) this.config.env.secrets.file = file;
|
|
108
|
+
}
|
|
109
|
+
this.info({
|
|
110
|
+
meta: { category: "env" },
|
|
111
|
+
message: `Environment configuration definition file: ${this.config.env.types.file}${this.config.env.types.name ? `#${this.config.env.types.name}` : ""}${this.config.env.secrets ? `\nSecrets configuration definition file: ${this.config.env.secrets?.file}${this.config.env.secrets?.name ? `#${this.config.env.secrets?.name}` : ""}` : ""}\nEnvironment variable Prefixes: ${this.config.env.prefix.join(", ")}\nShould inject values: ${this.config.env.inject ? "Yes" : "No"}\nShould validate configuration: ${this.config.env.validate ? "Yes" : "No"}`
|
|
112
|
+
});
|
|
113
113
|
if (this.config.command !== "prepare" && !this.config.skipCache && this.persistedMeta?.checksum === this.meta.checksum && existsSync(getEnvTypeReflectionsPath(this, "env"))) {
|
|
114
114
|
this.debug(`Skipping reflection initialization as the meta checksum has not changed.`);
|
|
115
115
|
this.env.types.env = await readEnvTypeReflection(this, "env");
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","names":[],"sources":["../src/index.tsx"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport {\n ReflectionClass,\n ReflectionKind\n} from \"@powerlines/deepkit/vendor/type\";\nimport { render } from \"@powerlines/plugin-alloy/render\";\nimport automd from \"@powerlines/plugin-automd\";\nimport babel from \"@powerlines/plugin-babel\";\nimport deepkit from \"@powerlines/plugin-deepkit\";\nimport { TypeScriptCompilerPluginUserConfig } from \"@powerlines/plugin-tsc\";\nimport { parseTypeDefinition } from \"@stryke/convert/parse-type-definition\";\nimport { toArray } from \"@stryke/convert/to-array\";\nimport { existsSync } from \"@stryke/fs/exists\";\nimport { getUnique } from \"@stryke/helpers/get-unique\";\nimport { joinPaths } from \"@stryke/path/join\";\nimport { constantCase } from \"@stryke/string-format/constant-case\";\nimport { isSetString } from \"@stryke/type-checks/is-set-string\";\nimport {\n TypeDefinition,\n TypeDefinitionParameter\n} from \"@stryke/types/configuration\";\nimport defu from \"defu\";\nimport { Plugin } from \"powerlines\";\nimport { VIRTUAL_MODULE_PREFIX } from \"powerlines/constants\";\nimport { getDocsOutputPath } from \"powerlines/plugin-utils\";\nimport type { UserConfig as ViteUserConfig } from \"vite\";\nimport { envBabelPlugin } from \"./babel/plugin\";\nimport { EnvDocsFile } from \"./components/docs\";\nimport { EnvBuiltin } from \"./components/env-builtin\";\nimport { env } from \"./helpers/automd-generator\";\nimport { loadEnv } from \"./helpers/load\";\nimport {\n getEnvDefaultTypeDefinition,\n getEnvReflectionsPath,\n getEnvTypeReflectionsPath,\n getSecretsDefaultTypeDefinition,\n readEnvReflection,\n readEnvTypeReflection,\n readSecretsReflection,\n writeEnvReflection,\n writeEnvTypeReflection\n} from \"./helpers/persistence\";\nimport { reflectEnv, reflectSecrets } from \"./helpers/reflect\";\nimport { EnvPluginContext, EnvPluginOptions } from \"./types/plugin\";\n\nexport * from \"./types\";\n\ndeclare module \"powerlines\" {\n interface Config {\n env?: EnvPluginOptions;\n }\n}\n\n/**\n * A Powerlines plugin to inject environment variables into the source code.\n */\nexport const plugin = <TContext extends EnvPluginContext = EnvPluginContext>(\n options: EnvPluginOptions = {}\n) => {\n return [\n deepkit(options.deepkit),\n babel(options.babel),\n {\n name: \"env\",\n async config() {\n this.debug(\n \"Providing default configuration for the Powerlines `env` build plugin.\"\n );\n\n const config = {\n env: defu(options, {\n types: {} as TypeDefinitionParameter,\n validate: false,\n inject: false,\n prefix: []\n }),\n babel: {\n plugins: [envBabelPlugin]\n },\n deepkit: {\n reflection: \"default\",\n level: \"all\"\n },\n tsc: {} as TypeScriptCompilerPluginUserConfig[\"tsc\"]\n };\n\n if (\n isSetString(config.env.types) ||\n (config.env.types && isSetString(config.env.types.file))\n ) {\n config.env.types = parseTypeDefinition(\n config.env.types\n ) as TypeDefinition;\n\n const file = await this.fs.resolve(config.env.types.file);\n if (file) {\n config.env.types.file = file;\n }\n } else {\n this.warn(\n \"The `env.types` configuration parameter was not provided. Please ensure this is expected.\"\n );\n\n const envDefaultTypeDefinition =\n await getEnvDefaultTypeDefinition(this);\n\n const file = await this.fs.resolve(envDefaultTypeDefinition.file);\n if (file) {\n config.env.types = parseTypeDefinition(\n `${file}#${envDefaultTypeDefinition.name}`\n ) as TypeDefinition;\n }\n }\n\n if (\n isSetString(config.env.secrets) ||\n (config.env.secrets && isSetString(config.env.secrets.file))\n ) {\n config.env.secrets = parseTypeDefinition(config.env.secrets);\n\n const file = await this.fs.resolve(config.env.secrets!.file);\n if (file) {\n config.env.secrets!.file = file;\n }\n } else {\n const secretsDefaultTypeDefinition =\n await getSecretsDefaultTypeDefinition(this);\n\n const file = await this.fs.resolve(secretsDefaultTypeDefinition.file);\n if (file) {\n config.env.secrets = parseTypeDefinition(\n `${file}#${secretsDefaultTypeDefinition.name}`\n );\n }\n }\n\n if (config.env.types || config.env.secrets) {\n config.tsc.filter = {\n id: [\n new RegExp(\n `^(${VIRTUAL_MODULE_PREFIX})?${joinPaths(\n this.builtinsPath,\n \"env.ts\"\n )\n .replace(/\\\\/g, \"\\\\\\\\\")\n .replace(/\\//g, \"\\\\/\")\n .replace(/\\./g, \"\\\\.\")\n .replace(/\\$/g, \"\\\\$\")}$`\n )\n ]\n };\n }\n\n config.env.prefix = toArray(\n (config.env.prefix ?? []) as string[]\n ).reduce(\n (ret: string[], prefix: string) => {\n const formattedPrefix = constantCase(prefix);\n if (!ret.includes(formattedPrefix)) {\n ret.push(formattedPrefix);\n }\n\n return ret;\n },\n [\n \"POWERLINES_\",\n this.config.framework &&\n this.config.framework !== \"powerlines\" &&\n `${constantCase(this.config.framework)}_`\n ].filter(Boolean) as string[]\n );\n\n config.env.prefix = getUnique(\n toArray(config.env.prefix).reduce((ret, prefix) => {\n if (!ret.includes(prefix.replace(/_$/g, \"\"))) {\n ret.push(prefix.replace(/_$/g, \"\"));\n }\n return ret;\n }, [] as string[])\n );\n\n this.info({\n meta: {\n category: \"env\"\n },\n message: `Environment configuration definition file: ${\n config.env.types.file\n }${config.env.types.name ? `#${config.env.types.name}` : \"\"}${\n config.env.secrets\n ? `\\nSecrets configuration definition file: ${config.env.secrets?.file}${\n config.env.secrets?.name ? `#${config.env.secrets?.name}` : \"\"\n }`\n : \"\"\n }\\nEnvironment variable Prefixes: ${config.env.prefix.join(\", \")}\\nShould inject values: ${\n config.env.inject ? \"Yes\" : \"No\"\n }\\nShould validate configuration: ${\n config.env.validate ? \"Yes\" : \"No\"\n }`\n });\n\n return config;\n },\n async configResolved() {\n this.debug(\n `Environment plugin configuration has been resolved for the Powerlines project.`\n );\n\n this.env = defu(\n {\n parsed: await loadEnv(this, this.config.env)\n },\n this.env ?? {},\n {\n types: {\n env: {}\n },\n used: {\n env: {},\n secrets: {}\n },\n parsed: {},\n injected: {}\n }\n );\n\n if (\n this.config.command !== \"prepare\" &&\n !this.config.skipCache &&\n this.persistedMeta?.checksum === this.meta.checksum &&\n existsSync(getEnvTypeReflectionsPath(this, \"env\"))\n ) {\n this.debug(\n `Skipping reflection initialization as the meta checksum has not changed.`\n );\n\n this.env.types.env = await readEnvTypeReflection(this, \"env\");\n\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following environment configuration parameter definitions: \\n${this.env.types.env\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()}${\n prop.getAlias().length > 0\n ? ` (aliases: ${prop.getAlias().join(\", \")})`\n : \"\"\n }`\n )\n .join(\"\\n\")}`\n });\n\n if (existsSync(getEnvReflectionsPath(this, \"env\"))) {\n this.env.used.env = await readEnvReflection(this);\n\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following environment configuration parameters used in project: \\n${this.env.used.env\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()}${\n prop.getAlias().length > 0\n ? ` (aliases: ${prop.getAlias().join(\", \")})`\n : \"\"\n }`\n )\n .join(\"\\n\")}`\n });\n }\n\n if (existsSync(getEnvTypeReflectionsPath(this, \"secrets\"))) {\n this.env.types.secrets = await readEnvTypeReflection(\n this,\n \"secrets\"\n );\n\n if (this.env.types.secrets.getProperties().length > 0) {\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following secret configuration parameter definitions: \\n${this.env.types.secrets\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n }\n }\n\n if (existsSync(getEnvReflectionsPath(this, \"secrets\"))) {\n this.env.used.secrets = await readSecretsReflection(this);\n\n if (this.env.used.secrets.getProperties().length > 0) {\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following secret configuration parameters used in project: \\n${this.env.used.secrets\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n }\n }\n } else {\n this.debug(\n `Starting environment configuration reflection initialization.`\n );\n\n this.env.types.env = await reflectEnv(\n this,\n this.config.env.types?.file,\n this.config.env.types?.name\n );\n if (!this.env.types.env) {\n throw new Error(\n \"Failed to find the environment configuration type reflection in the context.\"\n );\n }\n\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following environment configuration parameter definitions: \\n${this.env.types.env\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n\n await writeEnvTypeReflection(this, this.env.types.env, \"env\");\n\n this.env.types.secrets = await reflectSecrets(\n this,\n this.config.env.secrets?.file,\n this.config.env.secrets?.name\n );\n if (!this.env.types.secrets) {\n throw new Error(\n \"Failed to find the secrets configuration type reflection in the context.\"\n );\n }\n\n if (this.env.types.secrets.getProperties().length > 0) {\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following secret configuration parameter definitions: \\n${this.env.types.secrets\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n }\n\n await writeEnvTypeReflection(this, this.env.types.secrets, \"secrets\");\n\n this.info({\n meta: {\n category: \"env\"\n },\n message: `Resolved ${\n this.env.types.env.getProperties().length ?? 0\n } environment configuration parameters and ${\n this.env.types.secrets?.getProperties().length ?? 0\n } secret configuration parameters`\n });\n\n const envWithAlias = this.env.types.env\n .getProperties()\n .filter(prop => prop.getAlias().length > 0);\n\n Object.entries(await loadEnv(this, this.config.env)).forEach(\n ([key, value]) => {\n const unprefixedKey = this.config.env.prefix.reduce(\n (ret, prefix) => {\n if (key.replace(/_$/g, \"\").startsWith(prefix)) {\n return key.replace(/_$/g, \"\").slice(prefix.length);\n }\n return ret;\n },\n key\n );\n\n const aliasKey = envWithAlias.find(prop =>\n prop?.getAlias().reverse().includes(unprefixedKey)\n );\n if (this.env.types.env?.hasProperty(unprefixedKey) || aliasKey) {\n this.env.types.env\n .getProperty(unprefixedKey)\n .setDefaultValue(value);\n }\n }\n );\n\n this.env.used.env = new ReflectionClass(\n {\n kind: ReflectionKind.objectLiteral,\n typeName: \"Env\",\n description: `An object containing the environment configuration parameters used by the ${\n this.config.name\n ? `${this.config.name} application`\n : \"application\"\n }.`,\n types: []\n },\n this.env.types.env\n );\n\n await writeEnvReflection(this, this.env.used.env, \"env\");\n\n if (this.env.types.secrets) {\n await writeEnvTypeReflection(\n this,\n this.env.types.secrets,\n \"secrets\"\n );\n\n this.env.used.secrets = new ReflectionClass(\n {\n kind: ReflectionKind.objectLiteral,\n typeName: \"Secrets\",\n description: `An object containing the secret configuration parameters used by the ${\n this.config.name\n ? `${this.config.name} application`\n : \"application\"\n }.`,\n types: []\n },\n this.env.types.secrets\n );\n await writeEnvReflection(this, this.env.used.secrets, \"secrets\");\n }\n }\n },\n async prepare() {\n this.debug(\n `Preparing the Environment runtime artifacts for the Powerlines project.`\n );\n\n const result = await readEnvTypeReflection(this, \"env\");\n\n return render(\n this,\n <EnvBuiltin\n defaultConfig={this.config.env.defaultConfig}\n reflection={result}\n />\n );\n },\n transform: {\n order: \"post\",\n async handler() {\n if (this.env.used.env.getProperties().length > 0) {\n this.trace(\n `Persisting used environment configuration reflections to ${getEnvReflectionsPath(\n this,\n \"env\"\n )}.`\n );\n await writeEnvReflection(this, this.env.used.env, \"env\");\n }\n\n if (this.env.used.secrets.getProperties().length > 0) {\n this.trace(\n `Persisting used secret configuration reflections to ${getEnvReflectionsPath(\n this,\n \"secrets\"\n )}.`\n );\n await writeEnvReflection(this, this.env.used.secrets, \"secrets\");\n }\n }\n },\n async docs() {\n this.debug(\n `Documenting environment variables configuration values in \"${joinPaths(\n getDocsOutputPath(this.config.root),\n \"env.md\"\n )}\"`\n );\n\n const result = await readEnvTypeReflection(this, \"env\");\n\n return render(\n this,\n <EnvDocsFile levelOffset={0} reflection={result} />\n );\n },\n async buildEnd() {\n const reflectionPath = getEnvReflectionsPath(this, \"env\");\n\n this.debug(`Writing env reflection types to ${reflectionPath}.`);\n\n await writeEnvReflection(this, this.env.used.env, \"env\");\n }\n },\n {\n name: \"env:automd-generator\",\n config() {\n return {\n automd: defu(options.automd ?? {}, {\n generators: {\n env: env(this)\n }\n })\n };\n }\n },\n {\n name: \"env:vite\",\n vite: {\n configResolved(this: TContext) {\n return {\n envPrefix: this.config?.env?.prefix\n } as ViteUserConfig;\n }\n }\n },\n automd(options.automd)\n ] as Plugin<TContext>[];\n};\n\nexport default plugin;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","names":[],"sources":["../src/index.tsx"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport {\n ReflectionClass,\n ReflectionKind\n} from \"@powerlines/deepkit/vendor/type\";\nimport { render } from \"@powerlines/plugin-alloy/render\";\nimport automd from \"@powerlines/plugin-automd\";\nimport babel from \"@powerlines/plugin-babel\";\nimport deepkit from \"@powerlines/plugin-deepkit\";\nimport { TypeScriptCompilerPluginUserConfig } from \"@powerlines/plugin-tsc\";\nimport { parseTypeDefinition } from \"@stryke/convert/parse-type-definition\";\nimport { toArray } from \"@stryke/convert/to-array\";\nimport { existsSync } from \"@stryke/fs/exists\";\nimport { getUnique } from \"@stryke/helpers/get-unique\";\nimport { joinPaths } from \"@stryke/path/join\";\nimport { constantCase } from \"@stryke/string-format/constant-case\";\nimport { isSetString } from \"@stryke/type-checks/is-set-string\";\nimport {\n TypeDefinition,\n TypeDefinitionParameter\n} from \"@stryke/types/configuration\";\nimport defu from \"defu\";\nimport { Plugin } from \"powerlines\";\nimport {\n createVirtualPrefixRegex,\n getDocsOutputPath\n} from \"powerlines/plugin-utils\";\nimport type { UserConfig as ViteUserConfig } from \"vite\";\nimport { envBabelPlugin } from \"./babel/plugin\";\nimport { EnvDocsFile } from \"./components/docs\";\nimport { EnvBuiltin } from \"./components/env-builtin\";\nimport { env } from \"./helpers/automd-generator\";\nimport { loadEnv } from \"./helpers/load\";\nimport {\n getEnvDefaultTypeDefinition,\n getEnvReflectionsPath,\n getEnvTypeReflectionsPath,\n getSecretsDefaultTypeDefinition,\n readEnvReflection,\n readEnvTypeReflection,\n readSecretsReflection,\n writeEnvReflection,\n writeEnvTypeReflection\n} from \"./helpers/persistence\";\nimport { reflectEnv, reflectSecrets } from \"./helpers/reflect\";\nimport { EnvPluginContext, EnvPluginOptions } from \"./types/plugin\";\n\nexport * from \"./types\";\n\ndeclare module \"powerlines\" {\n interface Config {\n env?: EnvPluginOptions;\n }\n}\n\n/**\n * A Powerlines plugin to inject environment variables into the source code.\n */\nexport const plugin = <TContext extends EnvPluginContext = EnvPluginContext>(\n options: EnvPluginOptions = {}\n) => {\n return [\n deepkit({\n ...options.deepkit,\n reflection: \"default\",\n level: \"all\",\n filter: {}\n }),\n babel(options.babel),\n {\n name: \"env\",\n async config() {\n this.debug(\n \"Providing default configuration for the Powerlines `env` build plugin.\"\n );\n\n const config = {\n env: defu(options, {\n types: {} as TypeDefinitionParameter,\n validate: false,\n inject: false,\n prefix: []\n }),\n babel: {\n plugins: [envBabelPlugin]\n },\n deepkit: {\n reflection: \"default\",\n level: \"all\"\n },\n tsc: {} as TypeScriptCompilerPluginUserConfig[\"tsc\"]\n };\n\n if (\n !isSetString(config.env.types) &&\n !isSetString(config.env.types?.file)\n ) {\n this.warn(\n \"The `env.types` configuration parameter was not provided. Please ensure this is expected.\"\n );\n\n config.env.types = await getEnvDefaultTypeDefinition(this);\n }\n\n if (\n !isSetString(config.env.secrets) &&\n !isSetString(config.env.secrets?.file)\n ) {\n config.env.secrets = await getSecretsDefaultTypeDefinition(this);\n }\n\n config.env.prefix = toArray(\n (config.env.prefix ?? []) as string[]\n ).reduce(\n (ret: string[], prefix: string) => {\n const formattedPrefix = constantCase(prefix);\n if (!ret.includes(formattedPrefix)) {\n ret.push(formattedPrefix);\n }\n\n return ret;\n },\n [\n \"POWERLINES_\",\n this.config.framework &&\n this.config.framework !== \"powerlines\" &&\n `${constantCase(this.config.framework)}_`\n ].filter(Boolean) as string[]\n );\n\n config.env.prefix = getUnique(\n toArray(config.env.prefix).reduce((ret, prefix) => {\n if (!ret.includes(prefix.replace(/_$/g, \"\"))) {\n ret.push(prefix.replace(/_$/g, \"\"));\n }\n return ret;\n }, [] as string[])\n );\n\n config.tsc.filter = {\n id: [\n createVirtualPrefixRegex(joinPaths(this.builtinsPath, \"env.ts\")),\n createVirtualPrefixRegex(`${this.config.framework}:env`)\n ]\n };\n\n return config;\n },\n async configResolved() {\n this.debug(\n `Environment plugin configuration has been resolved for the Powerlines project.`\n );\n\n this.env = defu(\n {\n parsed: await loadEnv(this, this.config.env)\n },\n this.env ?? {},\n {\n types: {\n env: {}\n },\n used: {\n env: {},\n secrets: {}\n },\n parsed: {},\n injected: {}\n }\n );\n\n if (\n isSetString(this.config.env.types) ||\n (this.config.env.types && isSetString(this.config.env.types.file))\n ) {\n this.config.env.types = parseTypeDefinition(\n this.config.env.types\n ) as TypeDefinition;\n\n const file = await this.fs.resolve(this.config.env.types.file);\n if (file) {\n this.config.env.types.file = file;\n }\n }\n\n if (\n isSetString(this.config.env.secrets) ||\n (this.config.env.secrets && isSetString(this.config.env.secrets.file))\n ) {\n this.config.env.secrets = parseTypeDefinition(\n this.config.env.secrets\n )!;\n\n const file = await this.fs.resolve(this.config.env.secrets.file);\n if (file) {\n this.config.env.secrets.file = file;\n }\n }\n\n this.info({\n meta: {\n category: \"env\"\n },\n message: `Environment configuration definition file: ${\n this.config.env.types.file\n }${this.config.env.types.name ? `#${this.config.env.types.name}` : \"\"}${\n this.config.env.secrets\n ? `\\nSecrets configuration definition file: ${this.config.env.secrets?.file}${\n this.config.env.secrets?.name\n ? `#${this.config.env.secrets?.name}`\n : \"\"\n }`\n : \"\"\n }\\nEnvironment variable Prefixes: ${this.config.env.prefix.join(\", \")}\\nShould inject values: ${\n this.config.env.inject ? \"Yes\" : \"No\"\n }\\nShould validate configuration: ${\n this.config.env.validate ? \"Yes\" : \"No\"\n }`\n });\n\n if (\n this.config.command !== \"prepare\" &&\n !this.config.skipCache &&\n this.persistedMeta?.checksum === this.meta.checksum &&\n existsSync(getEnvTypeReflectionsPath(this, \"env\"))\n ) {\n this.debug(\n `Skipping reflection initialization as the meta checksum has not changed.`\n );\n\n this.env.types.env = await readEnvTypeReflection(this, \"env\");\n\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following environment configuration parameter definitions: \\n${this.env.types.env\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()}${\n prop.getAlias().length > 0\n ? ` (aliases: ${prop.getAlias().join(\", \")})`\n : \"\"\n }`\n )\n .join(\"\\n\")}`\n });\n\n if (existsSync(getEnvReflectionsPath(this, \"env\"))) {\n this.env.used.env = await readEnvReflection(this);\n\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following environment configuration parameters used in project: \\n${this.env.used.env\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()}${\n prop.getAlias().length > 0\n ? ` (aliases: ${prop.getAlias().join(\", \")})`\n : \"\"\n }`\n )\n .join(\"\\n\")}`\n });\n }\n\n if (existsSync(getEnvTypeReflectionsPath(this, \"secrets\"))) {\n this.env.types.secrets = await readEnvTypeReflection(\n this,\n \"secrets\"\n );\n\n if (this.env.types.secrets.getProperties().length > 0) {\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following secret configuration parameter definitions: \\n${this.env.types.secrets\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n }\n }\n\n if (existsSync(getEnvReflectionsPath(this, \"secrets\"))) {\n this.env.used.secrets = await readSecretsReflection(this);\n\n if (this.env.used.secrets.getProperties().length > 0) {\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following secret configuration parameters used in project: \\n${this.env.used.secrets\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n }\n }\n } else {\n this.debug(\n `Starting environment configuration reflection initialization.`\n );\n\n this.env.types.env = await reflectEnv(\n this,\n this.config.env.types?.file,\n this.config.env.types?.name\n );\n if (!this.env.types.env) {\n throw new Error(\n \"Failed to find the environment configuration type reflection in the context.\"\n );\n }\n\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following environment configuration parameter definitions: \\n${this.env.types.env\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n\n await writeEnvTypeReflection(this, this.env.types.env, \"env\");\n\n this.env.types.secrets = await reflectSecrets(\n this,\n this.config.env.secrets?.file,\n this.config.env.secrets?.name\n );\n if (!this.env.types.secrets) {\n throw new Error(\n \"Failed to find the secrets configuration type reflection in the context.\"\n );\n }\n\n if (this.env.types.secrets.getProperties().length > 0) {\n this.debug({\n meta: {\n category: \"env\"\n },\n message: `Found the following secret configuration parameter definitions: \\n${this.env.types.secrets\n .getProperties()\n .map(\n prop =>\n `- ${prop.getNameAsString()} (aliases: ${prop.getAlias().join(\", \")})`\n )\n .join(\"\\n\")}`\n });\n }\n\n await writeEnvTypeReflection(this, this.env.types.secrets, \"secrets\");\n\n this.info({\n meta: {\n category: \"env\"\n },\n message: `Resolved ${\n this.env.types.env.getProperties().length ?? 0\n } environment configuration parameters and ${\n this.env.types.secrets?.getProperties().length ?? 0\n } secret configuration parameters`\n });\n\n const envWithAlias = this.env.types.env\n .getProperties()\n .filter(prop => prop.getAlias().length > 0);\n\n Object.entries(await loadEnv(this, this.config.env)).forEach(\n ([key, value]) => {\n const unprefixedKey = this.config.env.prefix.reduce(\n (ret, prefix) => {\n if (key.replace(/_$/g, \"\").startsWith(prefix)) {\n return key.replace(/_$/g, \"\").slice(prefix.length);\n }\n return ret;\n },\n key\n );\n\n const aliasKey = envWithAlias.find(prop =>\n prop?.getAlias().reverse().includes(unprefixedKey)\n );\n if (this.env.types.env?.hasProperty(unprefixedKey) || aliasKey) {\n this.env.types.env\n .getProperty(unprefixedKey)\n .setDefaultValue(value);\n }\n }\n );\n\n this.env.used.env = new ReflectionClass(\n {\n kind: ReflectionKind.objectLiteral,\n typeName: \"Env\",\n description: `An object containing the environment configuration parameters used by the ${\n this.config.name\n ? `${this.config.name} application`\n : \"application\"\n }.`,\n types: []\n },\n this.env.types.env\n );\n\n await writeEnvReflection(this, this.env.used.env, \"env\");\n\n if (this.env.types.secrets) {\n await writeEnvTypeReflection(\n this,\n this.env.types.secrets,\n \"secrets\"\n );\n\n this.env.used.secrets = new ReflectionClass(\n {\n kind: ReflectionKind.objectLiteral,\n typeName: \"Secrets\",\n description: `An object containing the secret configuration parameters used by the ${\n this.config.name\n ? `${this.config.name} application`\n : \"application\"\n }.`,\n types: []\n },\n this.env.types.secrets\n );\n await writeEnvReflection(this, this.env.used.secrets, \"secrets\");\n }\n }\n },\n async prepare() {\n this.debug(\n `Preparing the Environment runtime artifacts for the Powerlines project.`\n );\n\n const result = await readEnvTypeReflection(this, \"env\");\n\n return render(\n this,\n <EnvBuiltin\n defaultConfig={this.config.env.defaultConfig}\n reflection={result}\n />\n );\n },\n transform: {\n order: \"post\",\n async handler() {\n if (this.env.used.env.getProperties().length > 0) {\n this.trace(\n `Persisting used environment configuration reflections to ${getEnvReflectionsPath(\n this,\n \"env\"\n )}.`\n );\n await writeEnvReflection(this, this.env.used.env, \"env\");\n }\n\n if (this.env.used.secrets.getProperties().length > 0) {\n this.trace(\n `Persisting used secret configuration reflections to ${getEnvReflectionsPath(\n this,\n \"secrets\"\n )}.`\n );\n await writeEnvReflection(this, this.env.used.secrets, \"secrets\");\n }\n }\n },\n async docs() {\n this.debug(\n `Documenting environment variables configuration values in \"${joinPaths(\n getDocsOutputPath(this.config.root),\n \"env.md\"\n )}\"`\n );\n\n const result = await readEnvTypeReflection(this, \"env\");\n\n return render(\n this,\n <EnvDocsFile levelOffset={0} reflection={result} />\n );\n },\n async buildEnd() {\n const reflectionPath = getEnvReflectionsPath(this, \"env\");\n\n this.debug(`Writing env reflection types to ${reflectionPath}.`);\n\n await writeEnvReflection(this, this.env.used.env, \"env\");\n }\n },\n {\n name: \"env:automd-generator\",\n config() {\n return {\n automd: defu(options.automd ?? {}, {\n generators: {\n env: env(this)\n }\n })\n };\n }\n },\n {\n name: \"env:vite\",\n vite: {\n configResolved(this: TContext) {\n return {\n envPrefix: this.config?.env?.prefix\n } as ViteUserConfig;\n }\n }\n },\n automd(options.automd)\n ] as Plugin<TContext>[];\n};\n\nexport default plugin;\n"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@powerlines/plugin-env",
|
|
3
|
-
"version": "0.16.
|
|
3
|
+
"version": "0.16.187",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "A package containing a Powerlines plugin for injecting static .env configuration values to the code so that they're accessible at runtime.",
|
|
6
6
|
"keywords": ["dotenv", "powerlines", "storm-software", "powerlines-plugin"],
|
|
@@ -292,12 +292,12 @@
|
|
|
292
292
|
"@alloy-js/typescript": "0.23.0-dev.4",
|
|
293
293
|
"@babel/core": "8.0.0-rc.4",
|
|
294
294
|
"@babel/types": "8.0.0-rc.4",
|
|
295
|
-
"@powerlines/plugin-alloy": "^0.26.
|
|
296
|
-
"@powerlines/plugin-automd": "^0.1.
|
|
297
|
-
"@powerlines/plugin-babel": "^0.12.
|
|
298
|
-
"@powerlines/plugin-plugin": "^0.12.
|
|
299
|
-
"@powerlines/deepkit": "^0.8.
|
|
300
|
-
"@powerlines/plugin-deepkit": "^0.11.
|
|
295
|
+
"@powerlines/plugin-alloy": "^0.26.80",
|
|
296
|
+
"@powerlines/plugin-automd": "^0.1.461",
|
|
297
|
+
"@powerlines/plugin-babel": "^0.12.454",
|
|
298
|
+
"@powerlines/plugin-plugin": "^0.12.412",
|
|
299
|
+
"@powerlines/deepkit": "^0.8.62",
|
|
300
|
+
"@powerlines/plugin-deepkit": "^0.11.343",
|
|
301
301
|
"@storm-software/config-tools": "^1.190.1",
|
|
302
302
|
"@stryke/capnp": "^0.12.96",
|
|
303
303
|
"@stryke/convert": "^0.7.3",
|
|
@@ -311,10 +311,10 @@
|
|
|
311
311
|
"@stryke/types": "^0.12.0",
|
|
312
312
|
"automd": "^0.4.3",
|
|
313
313
|
"defu": "^6.1.7",
|
|
314
|
-
"powerlines": "^0.
|
|
314
|
+
"powerlines": "^0.47.0",
|
|
315
315
|
"c12": "^3.3.4"
|
|
316
316
|
},
|
|
317
317
|
"devDependencies": { "@types/node": "^25.6.0", "vite": "^8.0.10" },
|
|
318
318
|
"publishConfig": { "access": "public" },
|
|
319
|
-
"gitHead": "
|
|
319
|
+
"gitHead": "3ffdf81ad60da786acd42f9b750df6c7837f8003"
|
|
320
320
|
}
|