@powerlines/plugin-env 0.16.131 → 0.16.133

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.
@@ -3,6 +3,7 @@ const require_runtime = require('../_virtual/_rolldown/runtime.cjs');
3
3
  const require_types_plugin = require('../types/plugin.cjs');
4
4
  const require_helpers_source_file_env = require('./source-file-env.cjs');
5
5
  let _stryke_path_join_paths = require("@stryke/path/join-paths");
6
+ let _storm_software_config_tools_get_config = require("@storm-software/config-tools/get-config");
6
7
  let _stryke_env_load_env = require("@stryke/env/load-env");
7
8
  let _stryke_string_format_kebab_case = require("@stryke/string-format/kebab-case");
8
9
  let _stryke_type_checks_is_set_object = require("@stryke/type-checks/is-set-object");
@@ -36,15 +37,15 @@ loadEnvFiles.__type = [
36
37
  "loadEnvFiles",
37
38
  "Pn!2\"&2#&2$\"`/%"
38
39
  ];
39
- async function loadEnvDirectory(options, directory, mode, cacheDir, packageJson, workspaceConfig) {
40
+ async function loadEnvDirectory(context, options, directory, mode, cacheDir, packageJson, workspaceConfig) {
40
41
  const [envResult, c12Result] = await Promise.all([(loadEnvFiles.Ω = [["!"]], loadEnvFiles(options, mode, directory)), (0, c12.loadConfig)({
41
42
  cwd: directory,
42
43
  name: "storm",
43
44
  envName: mode,
44
45
  defaults: {
45
- NAME: packageJson.name?.replace(`@${workspaceConfig.namespace}/`, ""),
46
+ NAME: workspaceConfig?.namespace && packageJson.name ? packageJson.name?.replace(`@${workspaceConfig.namespace}/`, "") : context.config.name,
46
47
  MODE: mode,
47
- ORG: workspaceConfig.organization
48
+ ORG: context.config.organization || workspaceConfig?.organization
48
49
  },
49
50
  globalRc: true,
50
51
  packageJson: true,
@@ -57,6 +58,8 @@ async function loadEnvDirectory(options, directory, mode, cacheDir, packageJson,
57
58
  return (0, defu.default)(envResult, c12Result.config, workspaceConfig);
58
59
  }
59
60
  loadEnvDirectory.__type = [
61
+ () => require_types_plugin.__ΩEnvPluginContext,
62
+ "context",
60
63
  () => require_types_plugin.__ΩEnvPluginOptions,
61
64
  "options",
62
65
  "directory",
@@ -65,7 +68,7 @@ loadEnvDirectory.__type = [
65
68
  "packageJson",
66
69
  "workspaceConfig",
67
70
  "loadEnvDirectory",
68
- "Pn!2\"&2#&2$&2%!2&!2'\"`/("
71
+ "Pn!2\"n#2$&2%&2&&2'!2(!2)8\"`/*"
69
72
  ];
70
73
  /**
71
74
  * Retrieves various dotenv configuration parameters from the context.
@@ -74,20 +77,20 @@ loadEnvDirectory.__type = [
74
77
  * @param parsed - The parsed dotenv configuration.
75
78
  * @returns An object containing the dotenv configuration.
76
79
  */
77
- function loadEnvFromContext(context, parsed) {
80
+ function loadEnvFromContext(context, parsed, workspaceConfig) {
78
81
  return (0, defu.default)({
79
- APP_NAME: (0, _stryke_string_format_kebab_case.kebabCase)(context.config.name || context.packageJson.name?.replace(`/${context.workspaceConfig.namespace}`, "")),
82
+ APP_NAME: (0, _stryke_string_format_kebab_case.kebabCase)(context.config.name),
80
83
  APP_VERSION: context.packageJson.version,
81
84
  BUILD_ID: context.meta.buildId,
82
85
  BUILD_TIMESTAMP: new Date(context.meta.timestamp).toISOString(),
83
86
  BUILD_CHECKSUM: context.meta.checksum,
84
87
  RELEASE_ID: context.meta.releaseId,
85
88
  RELEASE_TAG: `${(0, _stryke_string_format_kebab_case.kebabCase)(context.config.name)}@${context.packageJson.version}`,
86
- DEFAULT_LOCALE: context.workspaceConfig.locale,
87
- DEFAULT_TIMEZONE: context.workspaceConfig.timezone,
89
+ DEFAULT_LOCALE: workspaceConfig?.locale,
90
+ DEFAULT_TIMEZONE: workspaceConfig?.timezone,
88
91
  LOG_LEVEL: context.config.logLevel === "trace" ? "debug" : context.config.logLevel,
89
- ERROR_URL: context.workspaceConfig.error?.url,
90
- ORGANIZATION: context.config.organization || ((0, _stryke_type_checks_is_set_object.isSetObject)(context.workspaceConfig.organization) ? context.workspaceConfig.organization.name : context.workspaceConfig.organization),
92
+ ERROR_URL: workspaceConfig?.error?.url,
93
+ ORGANIZATION: context.config.organization || ((0, _stryke_type_checks_is_set_object.isSetObject)(workspaceConfig?.organization) ? workspaceConfig.organization.name : workspaceConfig?.organization),
91
94
  PLATFORM: context.config.platform,
92
95
  MODE: context.config.mode,
93
96
  TEST: context.config.mode === "test",
@@ -108,17 +111,19 @@ loadEnvFromContext.__type = [
108
111
  () => require_types_plugin.__ΩEnvPluginContext,
109
112
  "context",
110
113
  "parsed",
114
+ "workspaceConfig",
111
115
  "loadEnvFromContext",
112
116
  "Retrieves various dotenv configuration parameters from the context.",
113
- "Pn!2\"!2#\"/$?%"
117
+ "Pn!2\"!2#!2$8\"/%?&"
114
118
  ];
115
119
  async function loadEnv(context, options) {
120
+ const workspaceConfig = await (0, _storm_software_config_tools_get_config.tryGetWorkspaceConfig)();
116
121
  const [project, workspace, config] = await Promise.all([
117
- (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(options, context.config.root, context.config.mode, context.cachePath, context.packageJson, context.workspaceConfig)),
118
- (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(options, context.config.cwd, context.config.mode, context.cachePath, context.packageJson, context.workspaceConfig)),
119
- (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(options, context.envPaths.config, context.config.mode, context.cachePath, context.packageJson, context.workspaceConfig))
122
+ (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(context, options, context.config.root, context.config.mode, context.cachePath, context.packageJson, workspaceConfig)),
123
+ (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(context, options, context.config.cwd, context.config.mode, context.cachePath, context.packageJson, workspaceConfig)),
124
+ (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(context, options, context.envPaths.config, context.config.mode, context.cachePath, context.packageJson, workspaceConfig))
120
125
  ]);
121
- return (0, defu.default)(loadEnvFromContext(context, process.env), project, workspace, config);
126
+ return (0, defu.default)(loadEnvFromContext(context, process.env, workspaceConfig), project, workspace, config);
122
127
  }
123
128
  loadEnv.__type = [
124
129
  () => require_types_plugin.__ΩEnvPluginContext,
@@ -1,4 +1,5 @@
1
1
  import { EnvPluginContext, EnvPluginOptions } from "../types/plugin.cjs";
2
+ import { WorkspaceConfig } from "powerlines";
2
3
  import { DotenvParseOutput } from "@stryke/env/types";
3
4
 
4
5
  //#region src/helpers/load.d.ts
@@ -9,19 +10,19 @@ import { DotenvParseOutput } from "@stryke/env/types";
9
10
  * @param parsed - The parsed dotenv configuration.
10
11
  * @returns An object containing the dotenv configuration.
11
12
  */
12
- declare function loadEnvFromContext(context: EnvPluginContext, parsed: DotenvParseOutput): {
13
- APP_NAME: string | undefined;
13
+ declare function loadEnvFromContext(context: EnvPluginContext, parsed: DotenvParseOutput, workspaceConfig?: WorkspaceConfig): {
14
+ APP_NAME: string;
14
15
  APP_VERSION: string | undefined;
15
16
  BUILD_ID: string;
16
17
  BUILD_TIMESTAMP: string;
17
18
  BUILD_CHECKSUM: string;
18
19
  RELEASE_ID: string;
19
20
  RELEASE_TAG: string;
20
- DEFAULT_LOCALE: any;
21
- DEFAULT_TIMEZONE: any;
21
+ DEFAULT_LOCALE: string | undefined;
22
+ DEFAULT_TIMEZONE: string | undefined;
22
23
  LOG_LEVEL: "error" | "warn" | "info" | "debug" | null;
23
- ERROR_URL: any;
24
- ORGANIZATION: any;
24
+ ERROR_URL: string | undefined;
25
+ ORGANIZATION: string | undefined;
25
26
  PLATFORM: "node" | "browser" | "neutral";
26
27
  MODE: "test" | "development" | "production";
27
28
  TEST: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"load.d.cts","names":[],"sources":["../../src/helpers/load.ts"],"mappings":";;;;;;AAgGA;;;;;iBAAgB,kBAAA,CACd,OAAA,EAAS,gBAAA,EACT,MAAA,EAAQ,iBAAA;;;;;;;;;;;;;;;;;;;;iBAkDY,OAAA,cACP,iBAAA,GAAoB,iBAAA,CAAA,CACjC,OAAA,EAAS,gBAAA,EAAkB,OAAA,EAAS,gBAAA,GAAmB,OAAA,CAAQ,IAAA"}
1
+ {"version":3,"file":"load.d.cts","names":[],"sources":["../../src/helpers/load.ts"],"mappings":";;;;;;;AAqGA;;;;;iBAAgB,kBAAA,CACd,OAAA,EAAS,gBAAA,EACT,MAAA,EAAQ,iBAAA,EACR,eAAA,GAAkB,eAAA;;;;;;;;;;;;;;;;;;;;iBA4CE,OAAA,cACP,iBAAA,GAAoB,iBAAA,CAAA,CACjC,OAAA,EAAS,gBAAA,EAAkB,OAAA,EAAS,gBAAA,GAAmB,OAAA,CAAQ,IAAA"}
@@ -1,5 +1,6 @@
1
1
  import { EnvPluginContext, EnvPluginOptions } from "../types/plugin.mjs";
2
2
  import { DotenvParseOutput } from "@stryke/env/types";
3
+ import { WorkspaceConfig } from "powerlines";
3
4
 
4
5
  //#region src/helpers/load.d.ts
5
6
  /**
@@ -9,19 +10,19 @@ import { DotenvParseOutput } from "@stryke/env/types";
9
10
  * @param parsed - The parsed dotenv configuration.
10
11
  * @returns An object containing the dotenv configuration.
11
12
  */
12
- declare function loadEnvFromContext(context: EnvPluginContext, parsed: DotenvParseOutput): {
13
- APP_NAME: string | undefined;
13
+ declare function loadEnvFromContext(context: EnvPluginContext, parsed: DotenvParseOutput, workspaceConfig?: WorkspaceConfig): {
14
+ APP_NAME: string;
14
15
  APP_VERSION: string | undefined;
15
16
  BUILD_ID: string;
16
17
  BUILD_TIMESTAMP: string;
17
18
  BUILD_CHECKSUM: string;
18
19
  RELEASE_ID: string;
19
20
  RELEASE_TAG: string;
20
- DEFAULT_LOCALE: any;
21
- DEFAULT_TIMEZONE: any;
21
+ DEFAULT_LOCALE: string | undefined;
22
+ DEFAULT_TIMEZONE: string | undefined;
22
23
  LOG_LEVEL: "error" | "warn" | "info" | "debug" | null;
23
- ERROR_URL: any;
24
- ORGANIZATION: any;
24
+ ERROR_URL: string | undefined;
25
+ ORGANIZATION: string | undefined;
25
26
  PLATFORM: "node" | "browser" | "neutral";
26
27
  MODE: "test" | "development" | "production";
27
28
  TEST: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"load.d.mts","names":[],"sources":["../../src/helpers/load.ts"],"mappings":";;;;;;AAgGA;;;;;iBAAgB,kBAAA,CACd,OAAA,EAAS,gBAAA,EACT,MAAA,EAAQ,iBAAA;;;;;;;;;;;;;;;;;;;;iBAkDY,OAAA,cACP,iBAAA,GAAoB,iBAAA,CAAA,CACjC,OAAA,EAAS,gBAAA,EAAkB,OAAA,EAAS,gBAAA,GAAmB,OAAA,CAAQ,IAAA"}
1
+ {"version":3,"file":"load.d.mts","names":[],"sources":["../../src/helpers/load.ts"],"mappings":";;;;;;;AAqGA;;;;;iBAAgB,kBAAA,CACd,OAAA,EAAS,gBAAA,EACT,MAAA,EAAQ,iBAAA,EACR,eAAA,GAAkB,eAAA;;;;;;;;;;;;;;;;;;;;iBA4CE,OAAA,cACP,iBAAA,GAAoB,iBAAA,CAAA,CACjC,OAAA,EAAS,gBAAA,EAAkB,OAAA,EAAS,gBAAA,GAAmB,OAAA,CAAQ,IAAA"}
@@ -1,6 +1,7 @@
1
1
  import { __ΩEnvPluginContext, __ΩEnvPluginOptions } from "../types/plugin.mjs";
2
2
  import { removeEnvPrefix } from "./source-file-env.mjs";
3
3
  import { joinPaths } from "@stryke/path/join-paths";
4
+ import { tryGetWorkspaceConfig } from "@storm-software/config-tools/get-config";
4
5
  import { loadEnv as loadEnv$1, loadEnvFile } from "@stryke/env/load-env";
5
6
  import { kebabCase } from "@stryke/string-format/kebab-case";
6
7
  import { isSetObject } from "@stryke/type-checks/is-set-object";
@@ -33,15 +34,15 @@ loadEnvFiles.__type = [
33
34
  "loadEnvFiles",
34
35
  "Pn!2\"&2#&2$\"`/%"
35
36
  ];
36
- async function loadEnvDirectory(options, directory, mode, cacheDir, packageJson, workspaceConfig) {
37
+ async function loadEnvDirectory(context, options, directory, mode, cacheDir, packageJson, workspaceConfig) {
37
38
  const [envResult, c12Result] = await Promise.all([(loadEnvFiles.Ω = [["!"]], loadEnvFiles(options, mode, directory)), loadConfig({
38
39
  cwd: directory,
39
40
  name: "storm",
40
41
  envName: mode,
41
42
  defaults: {
42
- NAME: packageJson.name?.replace(`@${workspaceConfig.namespace}/`, ""),
43
+ NAME: workspaceConfig?.namespace && packageJson.name ? packageJson.name?.replace(`@${workspaceConfig.namespace}/`, "") : context.config.name,
43
44
  MODE: mode,
44
- ORG: workspaceConfig.organization
45
+ ORG: context.config.organization || workspaceConfig?.organization
45
46
  },
46
47
  globalRc: true,
47
48
  packageJson: true,
@@ -54,6 +55,8 @@ async function loadEnvDirectory(options, directory, mode, cacheDir, packageJson,
54
55
  return defu(envResult, c12Result.config, workspaceConfig);
55
56
  }
56
57
  loadEnvDirectory.__type = [
58
+ () => __ΩEnvPluginContext,
59
+ "context",
57
60
  () => __ΩEnvPluginOptions,
58
61
  "options",
59
62
  "directory",
@@ -62,7 +65,7 @@ loadEnvDirectory.__type = [
62
65
  "packageJson",
63
66
  "workspaceConfig",
64
67
  "loadEnvDirectory",
65
- "Pn!2\"&2#&2$&2%!2&!2'\"`/("
68
+ "Pn!2\"n#2$&2%&2&&2'!2(!2)8\"`/*"
66
69
  ];
67
70
  /**
68
71
  * Retrieves various dotenv configuration parameters from the context.
@@ -71,20 +74,20 @@ loadEnvDirectory.__type = [
71
74
  * @param parsed - The parsed dotenv configuration.
72
75
  * @returns An object containing the dotenv configuration.
73
76
  */
74
- function loadEnvFromContext(context, parsed) {
77
+ function loadEnvFromContext(context, parsed, workspaceConfig) {
75
78
  return defu({
76
- APP_NAME: kebabCase(context.config.name || context.packageJson.name?.replace(`/${context.workspaceConfig.namespace}`, "")),
79
+ APP_NAME: kebabCase(context.config.name),
77
80
  APP_VERSION: context.packageJson.version,
78
81
  BUILD_ID: context.meta.buildId,
79
82
  BUILD_TIMESTAMP: new Date(context.meta.timestamp).toISOString(),
80
83
  BUILD_CHECKSUM: context.meta.checksum,
81
84
  RELEASE_ID: context.meta.releaseId,
82
85
  RELEASE_TAG: `${kebabCase(context.config.name)}@${context.packageJson.version}`,
83
- DEFAULT_LOCALE: context.workspaceConfig.locale,
84
- DEFAULT_TIMEZONE: context.workspaceConfig.timezone,
86
+ DEFAULT_LOCALE: workspaceConfig?.locale,
87
+ DEFAULT_TIMEZONE: workspaceConfig?.timezone,
85
88
  LOG_LEVEL: context.config.logLevel === "trace" ? "debug" : context.config.logLevel,
86
- ERROR_URL: context.workspaceConfig.error?.url,
87
- ORGANIZATION: context.config.organization || (isSetObject(context.workspaceConfig.organization) ? context.workspaceConfig.organization.name : context.workspaceConfig.organization),
89
+ ERROR_URL: workspaceConfig?.error?.url,
90
+ ORGANIZATION: context.config.organization || (isSetObject(workspaceConfig?.organization) ? workspaceConfig.organization.name : workspaceConfig?.organization),
88
91
  PLATFORM: context.config.platform,
89
92
  MODE: context.config.mode,
90
93
  TEST: context.config.mode === "test",
@@ -105,17 +108,19 @@ loadEnvFromContext.__type = [
105
108
  () => __ΩEnvPluginContext,
106
109
  "context",
107
110
  "parsed",
111
+ "workspaceConfig",
108
112
  "loadEnvFromContext",
109
113
  "Retrieves various dotenv configuration parameters from the context.",
110
- "Pn!2\"!2#\"/$?%"
114
+ "Pn!2\"!2#!2$8\"/%?&"
111
115
  ];
112
116
  async function loadEnv(context, options) {
117
+ const workspaceConfig = await tryGetWorkspaceConfig();
113
118
  const [project, workspace, config] = await Promise.all([
114
- (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(options, context.config.root, context.config.mode, context.cachePath, context.packageJson, context.workspaceConfig)),
115
- (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(options, context.config.cwd, context.config.mode, context.cachePath, context.packageJson, context.workspaceConfig)),
116
- (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(options, context.envPaths.config, context.config.mode, context.cachePath, context.packageJson, context.workspaceConfig))
119
+ (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(context, options, context.config.root, context.config.mode, context.cachePath, context.packageJson, workspaceConfig)),
120
+ (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(context, options, context.config.cwd, context.config.mode, context.cachePath, context.packageJson, workspaceConfig)),
121
+ (loadEnvDirectory.Ω = [["!"]], loadEnvDirectory(context, options, context.envPaths.config, context.config.mode, context.cachePath, context.packageJson, workspaceConfig))
117
122
  ]);
118
- return defu(loadEnvFromContext(context, process.env), project, workspace, config);
123
+ return defu(loadEnvFromContext(context, process.env, workspaceConfig), project, workspace, config);
119
124
  }
120
125
  loadEnv.__type = [
121
126
  () => __ΩEnvPluginContext,
@@ -1 +1 @@
1
- {"version":3,"file":"load.mjs","names":[],"sources":["../../src/helpers/load.ts"],"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 loadEnv as loadEnvBase,\n loadEnvFile as loadEnvFileBase\n} from \"@stryke/env/load-env\";\nimport type { DotenvParseOutput } from \"@stryke/env/types\";\nimport { joinPaths } from \"@stryke/path/join-paths\";\nimport { kebabCase } from \"@stryke/string-format/kebab-case\";\nimport { isSetObject } from \"@stryke/type-checks/is-set-object\";\nimport type { PackageJson } from \"@stryke/types/package-json\";\nimport { loadConfig } from \"c12\";\nimport defu from \"defu\";\nimport { WorkspaceConfig } from \"powerlines\";\nimport { DEFAULT_ENVIRONMENT } from \"powerlines/constants\";\nimport { EnvPluginContext, EnvPluginOptions } from \"../types/plugin\";\nimport { removeEnvPrefix } from \"./source-file-env\";\n\nasync function loadEnvFiles<TEnv extends DotenvParseOutput = DotenvParseOutput>(\n options: EnvPluginOptions,\n mode: string,\n cwd: string\n): Promise<TEnv> {\n let env = await loadEnvBase(cwd, mode);\n if (options.additionalFiles && options.additionalFiles?.length > 0) {\n const additionalEnvFiles = await Promise.all(\n options.additionalFiles.map(async additionalEnvFile =>\n loadEnvFileBase(additionalEnvFile, cwd)\n )\n );\n\n for (const additionalEnvFile of additionalEnvFiles) {\n env = defu(additionalEnvFile, env);\n }\n }\n\n return removeEnvPrefix(env) as TEnv;\n}\n\nasync function loadEnvDirectory<\n TEnv extends DotenvParseOutput = DotenvParseOutput\n>(\n options: EnvPluginOptions,\n directory: string,\n mode: string,\n cacheDir: string,\n packageJson: PackageJson,\n workspaceConfig: WorkspaceConfig\n): Promise<TEnv> {\n const [envResult, c12Result] = await Promise.all([\n loadEnvFiles<TEnv>(options, mode, directory),\n loadConfig({\n cwd: directory,\n name: \"storm\",\n envName: mode,\n defaults: {\n NAME: packageJson.name?.replace(`@${workspaceConfig.namespace}/`, \"\"),\n MODE: mode,\n ORG: workspaceConfig.organization\n },\n globalRc: true,\n packageJson: true,\n dotenv: true,\n jitiOptions: {\n fsCache: joinPaths(cacheDir, \"jiti\"),\n moduleCache: true\n }\n })\n ]);\n\n return defu(envResult as any, c12Result.config, workspaceConfig) as TEnv;\n}\n\n/**\n * Retrieves various dotenv configuration parameters from the context.\n *\n * @param context - The context to retrieve the dotenv configuration from.\n * @param parsed - The parsed dotenv configuration.\n * @returns An object containing the dotenv configuration.\n */\nexport function loadEnvFromContext(\n context: EnvPluginContext,\n parsed: DotenvParseOutput\n) {\n return defu(\n {\n APP_NAME: kebabCase(\n context.config.name ||\n context.packageJson.name?.replace(\n `/${context.workspaceConfig.namespace}`,\n \"\"\n )\n ),\n APP_VERSION: context.packageJson.version,\n BUILD_ID: context.meta.buildId,\n BUILD_TIMESTAMP: new Date(context.meta.timestamp).toISOString(),\n BUILD_CHECKSUM: context.meta.checksum,\n RELEASE_ID: context.meta.releaseId,\n RELEASE_TAG: `${kebabCase(context.config.name)}@${context.packageJson.version}`,\n DEFAULT_LOCALE: context.workspaceConfig.locale,\n DEFAULT_TIMEZONE: context.workspaceConfig.timezone,\n LOG_LEVEL:\n context.config.logLevel === \"trace\" ? \"debug\" : context.config.logLevel,\n ERROR_URL: context.workspaceConfig.error?.url,\n ORGANIZATION:\n context.config.organization ||\n (isSetObject(context.workspaceConfig.organization)\n ? context.workspaceConfig.organization.name\n : context.workspaceConfig.organization),\n PLATFORM: context.config.platform,\n MODE: context.config.mode,\n TEST: context.config.mode === \"test\",\n DEBUG: context.config.mode === \"development\",\n STACKTRACE: context.config.mode !== \"production\",\n ENVIRONMENT:\n !context.environment.name ||\n context.environment.name === DEFAULT_ENVIRONMENT\n ? context.config.mode\n : context.environment.name\n },\n isSetObject(context?.env?.types?.env)\n ? context.env.types.env?.getProperties().reduce(\n (ret, prop) => {\n ret[prop.name] = parsed[prop.name] ?? prop.getDefaultValue();\n return ret;\n },\n {} as Record<string, any>\n )\n : {}\n );\n}\n\nexport async function loadEnv<\n TEnv extends DotenvParseOutput = DotenvParseOutput\n>(context: EnvPluginContext, options: EnvPluginOptions): Promise<TEnv> {\n const [project, workspace, config] = await Promise.all([\n loadEnvDirectory<TEnv>(\n options,\n context.config.root,\n context.config.mode,\n context.cachePath,\n context.packageJson,\n context.workspaceConfig\n ),\n loadEnvDirectory<TEnv>(\n options,\n context.config.cwd,\n context.config.mode,\n context.cachePath,\n context.packageJson,\n context.workspaceConfig\n ),\n loadEnvDirectory<TEnv>(\n options,\n context.envPaths.config,\n context.config.mode,\n context.cachePath,\n context.packageJson,\n context.workspaceConfig\n )\n ]);\n\n return defu(\n loadEnvFromContext(context, process.env),\n project,\n workspace,\n config\n ) as TEnv;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"load.mjs","names":[],"sources":["../../src/helpers/load.ts"],"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 { tryGetWorkspaceConfig } from \"@storm-software/config-tools/get-config\";\nimport {\n loadEnv as loadEnvBase,\n loadEnvFile as loadEnvFileBase\n} from \"@stryke/env/load-env\";\nimport type { DotenvParseOutput } from \"@stryke/env/types\";\nimport { joinPaths } from \"@stryke/path/join-paths\";\nimport { kebabCase } from \"@stryke/string-format/kebab-case\";\nimport { isSetObject } from \"@stryke/type-checks/is-set-object\";\nimport type { PackageJson } from \"@stryke/types/package-json\";\nimport { loadConfig } from \"c12\";\nimport defu from \"defu\";\nimport { WorkspaceConfig } from \"powerlines\";\nimport { DEFAULT_ENVIRONMENT } from \"powerlines/constants\";\nimport { EnvPluginContext, EnvPluginOptions } from \"../types/plugin\";\nimport { removeEnvPrefix } from \"./source-file-env\";\n\nasync function loadEnvFiles<TEnv extends DotenvParseOutput = DotenvParseOutput>(\n options: EnvPluginOptions,\n mode: string,\n cwd: string\n): Promise<TEnv> {\n let env = await loadEnvBase(cwd, mode);\n if (options.additionalFiles && options.additionalFiles?.length > 0) {\n const additionalEnvFiles = await Promise.all(\n options.additionalFiles.map(async additionalEnvFile =>\n loadEnvFileBase(additionalEnvFile, cwd)\n )\n );\n\n for (const additionalEnvFile of additionalEnvFiles) {\n env = defu(additionalEnvFile, env);\n }\n }\n\n return removeEnvPrefix(env) as TEnv;\n}\n\nasync function loadEnvDirectory<\n TEnv extends DotenvParseOutput = DotenvParseOutput\n>(\n context: EnvPluginContext,\n options: EnvPluginOptions,\n directory: string,\n mode: string,\n cacheDir: string,\n packageJson: PackageJson,\n workspaceConfig?: WorkspaceConfig\n): Promise<TEnv> {\n const [envResult, c12Result] = await Promise.all([\n loadEnvFiles<TEnv>(options, mode, directory),\n loadConfig({\n cwd: directory,\n name: \"storm\",\n envName: mode,\n defaults: {\n NAME:\n workspaceConfig?.namespace && packageJson.name\n ? packageJson.name?.replace(`@${workspaceConfig.namespace}/`, \"\")\n : context.config.name,\n MODE: mode,\n ORG: context.config.organization || workspaceConfig?.organization\n },\n globalRc: true,\n packageJson: true,\n dotenv: true,\n jitiOptions: {\n fsCache: joinPaths(cacheDir, \"jiti\"),\n moduleCache: true\n }\n })\n ]);\n\n return defu(envResult as any, c12Result.config, workspaceConfig) as TEnv;\n}\n\n/**\n * Retrieves various dotenv configuration parameters from the context.\n *\n * @param context - The context to retrieve the dotenv configuration from.\n * @param parsed - The parsed dotenv configuration.\n * @returns An object containing the dotenv configuration.\n */\nexport function loadEnvFromContext(\n context: EnvPluginContext,\n parsed: DotenvParseOutput,\n workspaceConfig?: WorkspaceConfig\n) {\n return defu(\n {\n APP_NAME: kebabCase(context.config.name),\n APP_VERSION: context.packageJson.version,\n BUILD_ID: context.meta.buildId,\n BUILD_TIMESTAMP: new Date(context.meta.timestamp).toISOString(),\n BUILD_CHECKSUM: context.meta.checksum,\n RELEASE_ID: context.meta.releaseId,\n RELEASE_TAG: `${kebabCase(context.config.name)}@${context.packageJson.version}`,\n DEFAULT_LOCALE: workspaceConfig?.locale,\n DEFAULT_TIMEZONE: workspaceConfig?.timezone,\n LOG_LEVEL:\n context.config.logLevel === \"trace\" ? \"debug\" : context.config.logLevel,\n ERROR_URL: workspaceConfig?.error?.url,\n ORGANIZATION:\n context.config.organization ||\n (isSetObject(workspaceConfig?.organization)\n ? workspaceConfig.organization.name\n : workspaceConfig?.organization),\n PLATFORM: context.config.platform,\n MODE: context.config.mode,\n TEST: context.config.mode === \"test\",\n DEBUG: context.config.mode === \"development\",\n STACKTRACE: context.config.mode !== \"production\",\n ENVIRONMENT:\n !context.environment.name ||\n context.environment.name === DEFAULT_ENVIRONMENT\n ? context.config.mode\n : context.environment.name\n },\n isSetObject(context?.env?.types?.env)\n ? context.env.types.env?.getProperties().reduce(\n (ret, prop) => {\n ret[prop.name] = parsed[prop.name] ?? prop.getDefaultValue();\n return ret;\n },\n {} as Record<string, any>\n )\n : {}\n );\n}\n\nexport async function loadEnv<\n TEnv extends DotenvParseOutput = DotenvParseOutput\n>(context: EnvPluginContext, options: EnvPluginOptions): Promise<TEnv> {\n const workspaceConfig = await tryGetWorkspaceConfig();\n\n const [project, workspace, config] = await Promise.all([\n loadEnvDirectory<TEnv>(\n context,\n options,\n context.config.root,\n context.config.mode,\n context.cachePath,\n context.packageJson,\n workspaceConfig\n ),\n loadEnvDirectory<TEnv>(\n context,\n options,\n context.config.cwd,\n context.config.mode,\n context.cachePath,\n context.packageJson,\n workspaceConfig\n ),\n loadEnvDirectory<TEnv>(\n context,\n options,\n context.envPaths.config,\n context.config.mode,\n context.cachePath,\n context.packageJson,\n workspaceConfig\n )\n ]);\n\n return defu(\n loadEnvFromContext(context, process.env, workspaceConfig),\n project,\n workspace,\n config\n ) as TEnv;\n}\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.131",
3
+ "version": "0.16.133",
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"],
@@ -306,12 +306,12 @@
306
306
  "@alloy-js/typescript": "0.23.0-dev.4",
307
307
  "@babel/core": "8.0.0-rc.3",
308
308
  "@babel/types": "8.0.0-rc.3",
309
- "@powerlines/plugin-alloy": "^0.26.24",
310
- "@powerlines/plugin-automd": "^0.1.406",
311
- "@powerlines/plugin-babel": "^0.12.401",
312
- "@powerlines/plugin-plugin": "^0.12.357",
313
- "@powerlines/deepkit": "^0.8.9",
314
- "@powerlines/plugin-deepkit": "^0.11.287",
309
+ "@powerlines/plugin-alloy": "^0.26.26",
310
+ "@powerlines/plugin-automd": "^0.1.408",
311
+ "@powerlines/plugin-babel": "^0.12.402",
312
+ "@powerlines/plugin-plugin": "^0.12.359",
313
+ "@powerlines/deepkit": "^0.8.10",
314
+ "@powerlines/plugin-deepkit": "^0.11.289",
315
315
  "@storm-software/config-tools": "^1.189.77",
316
316
  "@stryke/capnp": "^0.12.92",
317
317
  "@stryke/convert": "^0.6.58",
@@ -325,10 +325,10 @@
325
325
  "@stryke/types": "^0.11.3",
326
326
  "automd": "^0.4.3",
327
327
  "defu": "^6.1.7",
328
- "powerlines": "^0.43.5",
328
+ "powerlines": "^0.43.7",
329
329
  "c12": "^3.3.4"
330
330
  },
331
331
  "devDependencies": { "@types/node": "^25.6.0", "vite": "^8.0.9" },
332
332
  "publishConfig": { "access": "public" },
333
- "gitHead": "20f2c6b5e4a07b06620c8c98d83bb3b31503c426"
333
+ "gitHead": "b7dcad6bc06c093b3a839ab89438129c56f72813"
334
334
  }