@powerlines/plugin-env 0.16.131 → 0.16.134

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.
Files changed (34) hide show
  1. package/dist/babel/plugin.mjs.map +1 -1
  2. package/dist/components/docs.cjs +49 -39
  3. package/dist/components/docs.d.cts +1 -2
  4. package/dist/components/docs.d.cts.map +1 -1
  5. package/dist/components/docs.d.mts +1 -2
  6. package/dist/components/docs.d.mts.map +1 -1
  7. package/dist/components/docs.mjs +50 -40
  8. package/dist/components/docs.mjs.map +1 -1
  9. package/dist/components/env-builtin.cjs +513 -397
  10. package/dist/components/env-builtin.d.cts +2 -2
  11. package/dist/components/env-builtin.d.cts.map +1 -1
  12. package/dist/components/env-builtin.d.mts +2 -2
  13. package/dist/components/env-builtin.d.mts.map +1 -1
  14. package/dist/components/env-builtin.mjs +514 -398
  15. package/dist/components/env-builtin.mjs.map +1 -1
  16. package/dist/helpers/automd-generator.mjs.map +1 -1
  17. package/dist/helpers/create-reflection-resource.mjs.map +1 -1
  18. package/dist/helpers/docs-helper.mjs.map +1 -1
  19. package/dist/helpers/load.cjs +20 -15
  20. package/dist/helpers/load.d.cts +7 -6
  21. package/dist/helpers/load.d.cts.map +1 -1
  22. package/dist/helpers/load.d.mts +7 -6
  23. package/dist/helpers/load.d.mts.map +1 -1
  24. package/dist/helpers/load.mjs +20 -15
  25. package/dist/helpers/load.mjs.map +1 -1
  26. package/dist/helpers/persistence.mjs.map +1 -1
  27. package/dist/helpers/reflect.mjs.map +1 -1
  28. package/dist/helpers/source-file-env.mjs.map +1 -1
  29. package/dist/helpers/template-helpers.mjs.map +1 -1
  30. package/dist/index.cjs +6 -3
  31. package/dist/index.mjs +7 -4
  32. package/dist/index.mjs.map +1 -1
  33. package/dist/types/runtime.mjs.map +1 -1
  34. package/package.json +10 -10
@@ -1 +1 @@
1
- {"version":3,"file":"env-builtin.mjs","names":[],"sources":["../../src/components/env-builtin.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 Children,\n code,\n computed,\n For,\n Show,\n splitProps\n} from \"@alloy-js/core\";\nimport {\n InterfaceDeclaration as BaseInterfaceDeclaration,\n ClassDeclaration,\n ClassMethod,\n ElseIfClause,\n FunctionDeclaration,\n IfStatement,\n InterfaceMember,\n NewExpression,\n VarDeclaration\n} from \"@alloy-js/typescript\";\nimport {\n ReflectionClass,\n ReflectionKind,\n ReflectionProperty\n} from \"@powerlines/deepkit/vendor/type\";\nimport { Spacing } from \"@powerlines/plugin-alloy/core/components/spacing\";\nimport { usePowerlines } from \"@powerlines/plugin-alloy/core/contexts/context\";\nimport { refkey } from \"@powerlines/plugin-alloy/helpers/refkey\";\nimport { ComponentProps } from \"@powerlines/plugin-alloy/types/components\";\nimport {\n BuiltinFile,\n BuiltinFileProps\n} from \"@powerlines/plugin-alloy/typescript/components/builtin-file\";\nimport type { InterfaceDeclarationProps } from \"@powerlines/plugin-alloy/typescript/components/interface-declaration\";\nimport { InterfaceDeclaration } from \"@powerlines/plugin-alloy/typescript/components/interface-declaration\";\nimport { ObjectDeclaration } from \"@powerlines/plugin-alloy/typescript/components/object-declaration\";\nimport {\n TSDoc,\n TSDocExample,\n TSDocLink,\n TSDocParam,\n TSDocRemarks,\n TSDocReturns,\n TSDocThrows\n} from \"@powerlines/plugin-alloy/typescript/components/tsdoc\";\nimport { TSDocReflectionProperty } from \"@powerlines/plugin-alloy/typescript/components/tsdoc-reflection\";\nimport { getUnique } from \"@stryke/helpers/get-unique\";\nimport { titleCase } from \"@stryke/string-format/title-case\";\nimport defu from \"defu\";\nimport { loadEnvFromContext } from \"../helpers/load\";\nimport { EnvPluginContext } from \"../types/plugin\";\n\n/**\n * Generates the environment configuration typescript definition for the Powerlines project.\n */\nexport function EnvTypeDefinition(\n props: Omit<InterfaceDeclarationProps, \"name\">\n) {\n const [{ defaultValue, reflection }] = splitProps(props, [\n \"defaultValue\",\n \"reflection\"\n ]);\n\n const context = usePowerlines<EnvPluginContext>();\n\n return (\n <>\n <InterfaceDeclaration\n name=\"UnprefixedEnv\"\n defaultValue={defaultValue}\n reflection={reflection}\n export\n />\n <Spacing />\n <TSDoc heading=\"The environment configuration object with prefixed keys.\">\n <TSDocRemarks>\n {`The \\`Env\\` type extends the \\`UnprefixedEnv\\` interface by including additional keys that are prefixed according to the project's configuration. This allows for flexibility in accessing environment variables with different naming conventions.`}\n </TSDocRemarks>\n </TSDoc>\n <BaseInterfaceDeclaration name=\"Env\" export extends=\"UnprefixedEnv\">\n <For\n each={getUnique(context.config.env.prefix).map(prefix =>\n prefix.replace(/_$/, \"\")\n )}\n doubleHardline>\n {prefix => (\n <For\n each={\n reflection\n ?.getProperties()\n .filter(property => !property.isIgnored()) ?? []\n }\n doubleHardline>\n {property => (\n <>\n <TSDocReflectionProperty reflection={property} />\n <InterfaceMember\n name={`${prefix}_${property.getNameAsString()}`}\n type={`UnprefixedEnv[\"${property.getNameAsString()}\"]`}\n readonly={property.isReadonly()}\n />\n </>\n )}\n </For>\n )}\n </For>\n </BaseInterfaceDeclaration>\n <Spacing />\n </>\n );\n}\n\ninterface ConfigPropertyConditionalProps extends ComponentProps {\n context: EnvPluginContext;\n name: string;\n}\n\nfunction ConfigPropertyConditional(props: ConfigPropertyConditionalProps) {\n const [{ context, name }] = splitProps(props, [\"context\", \"name\"]);\n\n return code`propertyName === \"${name}\" || propertyName.replace(/^(${getUnique(\n context.config.env.prefix\n .sort((a, b) =>\n a.startsWith(b) ? -1 : b.startsWith(a) ? 1 : a.localeCompare(b)\n )\n .map(prefix => `${prefix.replace(/_$/, \"\")}_`)\n ).join(\"|\")})/g, \"\").toLowerCase().replace(/[\\\\s\\\\-_]+/g, \"\") === \"${name\n .toLowerCase()\n .replace(/[\\s\\-_]+/g, \"\")}\"`;\n}\n\ninterface ConfigPropertyProps extends ComponentProps {\n index: number;\n context: EnvPluginContext;\n property: ReflectionProperty;\n}\n\nfunction ConfigPropertyGet(props: ConfigPropertyProps) {\n const [{ context, property, index }] = splitProps(props, [\n \"context\",\n \"property\",\n \"index\"\n ]);\n\n return (\n <>\n {index === 0 ? (\n <IfStatement\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`return target[\"${property.getNameAsString()}\"];`}\n </IfStatement>\n ) : (\n <ElseIfClause\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`return target[\"${property.getNameAsString()}\"];`}\n </ElseIfClause>\n )}\n </>\n );\n}\n\nfunction ConfigPropertySet(props: ConfigPropertyProps) {\n const [{ context, property, index }] = splitProps(props, [\n \"context\",\n \"property\",\n \"index\"\n ]);\n\n return (\n <>\n {index === 0 ? (\n <IfStatement\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`\n target[\"${property.getNameAsString()}\"] = newValue;\n return true;\n`}\n </IfStatement>\n ) : (\n <ElseIfClause\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`\n target[\"${property.getNameAsString()}\"] = newValue;\n return true;\n`}\n </ElseIfClause>\n )}\n </>\n );\n}\n\nexport interface EnvBuiltinProps extends Omit<BuiltinFileProps, \"id\"> {\n defaultConfig?: Children;\n reflection: ReflectionClass<any>;\n}\n\nconst createEnvRefkey = refkey(\"createEnv\");\nconst envRefkey = refkey(\"env\");\nconst envSerializerRefkey = refkey(\"EnvSerializer\");\n\n/**\n * Generates the environment configuration module for the Powerlines project.\n */\nexport function EnvBuiltin(props: EnvBuiltinProps) {\n const [{ defaultConfig, reflection, children }, rest] = splitProps(props, [\n \"defaultConfig\",\n \"reflection\",\n \"children\"\n ]);\n\n const context = usePowerlines<EnvPluginContext>();\n const defaultValue = computed(\n () => context && loadEnvFromContext(context, process.env)\n );\n\n const envInstance = computed(() => {\n const result = new ReflectionClass(\n {\n kind: ReflectionKind.objectLiteral,\n description: `The initial environment configuration state for the ${titleCase(\n context?.config?.name\n )} project.`,\n types: []\n },\n reflection\n );\n\n result\n .getProperties()\n .filter(\n property => property.isRuntime() || property.getTags().runtime === true\n )\n .forEach(property => {\n result.removeProperty(property.getNameAsString());\n });\n\n return result;\n });\n\n const reflectionGetProperties = computed(\n () =>\n reflection\n ?.getProperties()\n .filter(property => !property.isIgnored())\n .sort((a, b) =>\n a.getNameAsString().localeCompare(b.getNameAsString())\n ) ?? []\n );\n const reflectionSetProperties = computed(\n () =>\n reflection\n ?.getProperties()\n .filter(property => !property.isIgnored() && !property.isReadonly())\n .sort((a, b) =>\n a.getNameAsString().localeCompare(b.getNameAsString())\n ) ?? []\n );\n\n return (\n <BuiltinFile\n id=\"env\"\n description=\"The environment configuration module provides an interface to define environment configuration parameters.\"\n {...rest}\n imports={defu(\n {\n \"@powerlines/deepkit/vendor/type\": [\n \"serializeFunction\",\n \"deserializeFunction\",\n \"ReflectionKind\",\n \"Serializer\",\n \"NamingStrategy\",\n \"TemplateState\",\n \"Type\",\n \"TypeProperty\",\n \"TypePropertySignature\"\n ]\n },\n rest.imports ?? {}\n )}>\n <Show when={Boolean(reflection)}>\n <EnvTypeDefinition\n defaultValue={defaultValue}\n reflection={reflection}\n />\n <hbr />\n <hbr />\n </Show>\n\n <ObjectDeclaration\n name=\"initialEnv\"\n type=\"Partial<Env>\"\n defaultValue={defaultValue}\n reflection={envInstance}\n export\n const\n doc=\"The initial environment configuration object values for the runtime.\"\n />\n <Spacing />\n\n <TSDoc heading=\"The environment configuration serializer for the Powerlines application.\">\n <TSDocLink>\n {`https://deepkit.io/docs/serialization/serializers`}\n </TSDocLink>\n <TSDocLink>\n {`https://github.com/marcj/untitled-code/blob/master/packages/type/src/serializer.ts#L1918`}\n </TSDocLink>\n <TSDocRemarks>\n {`This serializer is used to serialize and deserialize the Powerlines environment configuration.`}\n </TSDocRemarks>\n </TSDoc>\n <ClassDeclaration\n refkey={envSerializerRefkey}\n name=\"EnvSerializer\"\n extends=\"Serializer\"\n export>\n <ClassMethod\n name=\"constructor\"\n public\n doc=\"Initializes a new instance of the `EnvSerializer` class.\">\n {code`super(\"env\");\n\n this.deserializeRegistry.register(\n ReflectionKind.boolean,\n (type: Type, state: TemplateState) => {\n state.addSetter(\n \\`typeof \\${state.accessor.toString()} !== \"boolean\" ? \\${state.accessor.toString()} === 1 || \\${state.accessor.toString()} === \"1\" || \\${state.accessor.toString()}.toLowerCase() === \"t\" || \\${state.accessor.toString()}.toLowerCase() === \"true\" || \\${state.accessor.toString()}.toLowerCase() === \"y\" || \\${state.accessor.toString()}.toLowerCase() === \"yes\" : \\${state.accessor.toString()}\\`\n );\n }\n ); `}\n </ClassMethod>\n </ClassDeclaration>\n <Spacing />\n\n <VarDeclaration\n name=\"envNamingStrategy\"\n const\n doc=\"The environment naming strategy for the runtime.\"\n initializer={code`new class extends NamingStrategy {\n constructor() {\n super(\"env\");\n }\n\n getPropertyName(type: TypeProperty | TypePropertySignature, forSerializer: string): string | undefined {\n const name = super.getPropertyName(type, forSerializer);\n if (!name) {\n return name;\n }\n\n return name.replace(/^(${getUnique(\n context.config.env.prefix\n )\n .map(prefix => prefix.replace(/_$/, \"\"))\n .join(\"|\")})_/, \"\");\n }\n }; `}\n />\n <Spacing />\n\n <TSDoc heading=\"A {@link EnvSerializer | environment configuration serializer} instance for the Powerlines application.\">\n <TSDocLink>\n {`https://deepkit.io/docs/serialization/serializers`}\n </TSDocLink>\n <TSDocLink>\n {`https://github.com/marcj/untitled-code/blob/master/packages/type/src/serializer.ts#L1918`}\n </TSDocLink>\n <TSDocRemarks>\n {`This serializer is used to serialize and deserialize the Powerlines environment configuration.`}\n </TSDocRemarks>\n </TSDoc>\n <VarDeclaration\n name=\"envSerializer\"\n const\n initializer={<NewExpression args={[]} target=\"EnvSerializer\" />}\n />\n <Spacing />\n\n <VarDeclaration\n name=\"_serializeEnv\"\n const\n initializer={\"serializeFunction<Env>(envSerializer, envNamingStrategy)\"}\n />\n <Spacing />\n <TSDoc heading=\"Serialize a environment configuration object to JSON data objects (not a JSON string).\">\n <TSDocRemarks>\n {`The resulting JSON object can be stringified using \\`JSON.stringify()\\`.`}\n </TSDocRemarks>\n <TSDocExample>{`const json = serializeEnv(env);`}</TSDocExample>\n <Spacing />\n <TSDocParam name=\"input\">\n {`The environment configuration object to serialize.`}\n </TSDocParam>\n <TSDocReturns>\n {`The serialized environment configuration as JSON data objects.`}\n </TSDocReturns>\n <TSDocThrows>\n {`ValidationError when serialization or validation fails.`}\n </TSDocThrows>\n </TSDoc>\n <FunctionDeclaration\n name=\"serializeEnv\"\n export\n parameters={[\n {\n name: \"input\",\n type: \"Env\"\n }\n ]}>\n {code` return _serializeEnv(input, { loosely: true }); `}\n </FunctionDeclaration>\n <Spacing />\n\n <VarDeclaration\n name=\"_deserializeEnv\"\n const\n initializer=\"deserializeFunction<Env>(envSerializer, envNamingStrategy)\"\n />\n <Spacing />\n <TSDoc heading=\"Deserialize a environment configuration object from JSON data objects to JavaScript objects, without running any validators.\">\n <TSDocRemarks>\n {`Types that are already correct will be used as-is.`}\n </TSDocRemarks>\n <TSDocExample>{`const env = deserializeEnv(json);`}</TSDocExample>\n <TSDocThrows>\n {`ValidationError when deserialization fails.`}\n </TSDocThrows>\n </TSDoc>\n <FunctionDeclaration\n name=\"deserializeEnv\"\n export\n parameters={[\n {\n name: \"input\",\n type: \"Env\"\n }\n ]}>\n {code` return _deserializeEnv(input, { loosely: true }); `}\n </FunctionDeclaration>\n <Spacing />\n\n <TSDoc heading=\"Initializes the Powerlines environment configuration module.\">\n <TSDocRemarks>\n {`This function initializes the Powerlines environment configuration object.`}\n </TSDocRemarks>\n <TSDocParam name=\"environmentConfig\">\n {`The dynamic/runtime configuration - this could include the current environment variables or any other environment-specific settings provided by the runtime.`}\n </TSDocParam>\n <TSDocReturns>\n {`The initialized Powerlines configuration object.`}\n </TSDocReturns>\n </TSDoc>\n <Show when={Boolean(context?.entryPath)}>\n <FunctionDeclaration\n refkey={createEnvRefkey}\n async={false}\n export\n name=\"createEnv\"\n parameters={[\n {\n name: \"environmentConfig\",\n type: `Partial<Env>`,\n optional: false,\n default: \"{}\"\n }\n ]}\n returnType=\"Env\">\n {code`\n return new Proxy<Env>(\n deserializeEnv({\n ...initialEnv,\n ...environmentConfig\n } as Env),\n {\n get: (target: UnprefixedEnv, propertyName: string) => { `}\n <hbr />\n\n <For each={reflectionGetProperties}>\n {(property: ReflectionProperty, index: number) => (\n <ConfigPropertyGet\n index={index}\n context={context}\n property={property}\n />\n )}\n </For>\n {code`\n return undefined;\n }, `}\n\n <Spacing />\n {code` set: (target: UnprefixedEnv, propertyName: string, newValue: any) => { `}\n <hbr />\n <For each={reflectionSetProperties} ender={code` else `}>\n {(property: ReflectionProperty, index: number) => (\n <ConfigPropertySet\n index={index}\n context={context}\n property={property}\n />\n )}\n </For>\n\n <hbr />\n {code`return false;\n }\n }\n );\n`}\n </FunctionDeclaration>\n </Show>\n <Spacing />\n <hbr />\n\n <TSDoc heading=\"The environment configuration object.\">\n <TSDocRemarks>\n {`This object provides access to the environment configuration parameters in the application runtime.`}\n </TSDocRemarks>\n </TSDoc>\n <VarDeclaration\n refkey={envRefkey}\n name=\"env\"\n type=\"Env\"\n export\n const\n initializer={\n <>{code`createEnv(${defaultConfig || \"{}\"} as Partial<Env>);`}</>\n }\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isCI\"\n doc=\"Detect if the application is running in a continuous integration (CI) environment.\"\n initializer={code`Boolean(\n env.CI ||\n env.RUN_ID ||\n env.AGOLA_GIT_REF ||\n env.AC_APPCIRCLE ||\n env.APPVEYOR ||\n env.CODEBUILD ||\n env.TF_BUILD ||\n env.bamboo_planKey ||\n env.BITBUCKET_COMMIT ||\n env.BITRISE_IO ||\n env.BUDDY_WORKSPACE_ID ||\n env.BUILDKITE ||\n env.CIRCLECI ||\n env.CIRRUS_CI ||\n env.CF_BUILD_ID ||\n env.CM_BUILD_ID ||\n env.CI_NAME ||\n env.DRONE ||\n env.DSARI ||\n env.EARTHLY_CI ||\n env.EAS_BUILD ||\n env.GERRIT_PROJECT ||\n env.GITEA_ACTIONS ||\n env.GITHUB_ACTIONS ||\n env.GITLAB_CI ||\n env.GOCD ||\n env.BUILDER_OUTPUT ||\n env.HARNESS_BUILD_ID ||\n env.JENKINS_URL ||\n env.LAYERCI ||\n env.MAGNUM ||\n env.NETLIFY ||\n env.NEVERCODE ||\n env.PROW_JOB_ID ||\n env.RELEASE_BUILD_ID ||\n env.RENDER ||\n env.SAILCI ||\n env.HUDSON ||\n env.SCREWDRIVER ||\n env.SEMAPHORE ||\n env.SOURCEHUT ||\n env.STRIDER ||\n env.TASK_ID ||\n env.RUN_ID ||\n env.TEAMCITY_VERSION ||\n env.TRAVIS ||\n env.VELA ||\n env.NOW_BUILDER ||\n env.APPCENTER_BUILD_ID ||\n env.CI_XCODE_PROJECT ||\n env.XCS || false\n ); `}\n />\n <Spacing />\n\n <TSDoc heading=\"Detect the \\`mode\\` of the current runtime environment.\">\n <TSDocRemarks>\n {code`The \\`mode\\` is determined by the \\`MODE\\` environment variable, or falls back to the \\`NEXT_PUBLIC_VERCEL_ENV\\`, \\`NODE_ENV\\`, or defaults to \\`production\\`. While the value can potentially be any string, it is generally recommended to only allow a value in the following list:\n - \\`production\\`\n - \\`test\\`\n - \\`development\\`\n `}\n </TSDocRemarks>\n </TSDoc>\n <VarDeclaration\n export\n const\n name=\"mode\"\n initializer={code`String(env.MODE) || \"production\"; `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isProduction\"\n doc='Detect if the application is running in `\"production\"` mode'\n initializer={code`[\"prd\", \"prod\", \"production\"].includes(mode.toLowerCase()); `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isTest\"\n doc='Detect if the application is running in `\"test\"` mode'\n initializer={code`[\"tst\", \"test\", \"testing\", \"stg\", \"stage\", \"staging\"].includes(mode.toLowerCase()) || env.TEST; `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isDevelopment\"\n doc='Detect if the application is running in `\"development\"` mode'\n initializer={code`[\"dev\", \"development\"].includes(mode.toLowerCase()); `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isDebug\"\n doc=\"Detect if the application is currently being debugged\"\n initializer={code`Boolean(isDevelopment && env.DEBUG); `}\n />\n <Spacing />\n <Show when={Boolean(children)}>{children}</Show>\n </BuiltinFile>\n );\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"env-builtin.mjs","names":[],"sources":["../../src/components/env-builtin.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 Children,\n code,\n computed,\n For,\n Show,\n splitProps\n} from \"@alloy-js/core\";\nimport {\n InterfaceDeclaration as BaseInterfaceDeclaration,\n ClassDeclaration,\n ClassMethod,\n ElseIfClause,\n FunctionDeclaration,\n IfStatement,\n InterfaceMember,\n NewExpression,\n VarDeclaration\n} from \"@alloy-js/typescript\";\nimport {\n ReflectionClass,\n ReflectionKind,\n ReflectionProperty\n} from \"@powerlines/deepkit/vendor/type\";\nimport { Spacing } from \"@powerlines/plugin-alloy/core/components/spacing\";\nimport { usePowerlines } from \"@powerlines/plugin-alloy/core/contexts/context\";\nimport { refkey } from \"@powerlines/plugin-alloy/helpers/refkey\";\nimport { ComponentProps } from \"@powerlines/plugin-alloy/types/components\";\nimport {\n BuiltinFile,\n BuiltinFileProps\n} from \"@powerlines/plugin-alloy/typescript/components/builtin-file\";\nimport type { InterfaceDeclarationProps } from \"@powerlines/plugin-alloy/typescript/components/interface-declaration\";\nimport { InterfaceDeclaration } from \"@powerlines/plugin-alloy/typescript/components/interface-declaration\";\nimport { ObjectDeclaration } from \"@powerlines/plugin-alloy/typescript/components/object-declaration\";\nimport {\n TSDoc,\n TSDocExample,\n TSDocLink,\n TSDocParam,\n TSDocRemarks,\n TSDocReturns,\n TSDocThrows\n} from \"@powerlines/plugin-alloy/typescript/components/tsdoc\";\nimport { TSDocReflectionProperty } from \"@powerlines/plugin-alloy/typescript/components/tsdoc-reflection\";\nimport { getUnique } from \"@stryke/helpers/get-unique\";\nimport { titleCase } from \"@stryke/string-format/title-case\";\nimport defu from \"defu\";\nimport { loadEnvFromContext } from \"../helpers/load\";\nimport { EnvPluginContext } from \"../types/plugin\";\n\n/**\n * Generates the environment configuration typescript definition for the Powerlines project.\n */\nexport function EnvTypeDefinition(\n props: Omit<InterfaceDeclarationProps, \"name\">\n) {\n const [{ defaultValue, reflection }] = splitProps(props, [\n \"defaultValue\",\n \"reflection\"\n ]);\n\n const context = usePowerlines<EnvPluginContext>();\n\n return (\n <>\n <InterfaceDeclaration\n name=\"UnprefixedEnv\"\n defaultValue={defaultValue}\n reflection={reflection}\n export\n />\n <Spacing />\n <TSDoc heading=\"The environment configuration object with prefixed keys.\">\n <TSDocRemarks>\n {`The \\`Env\\` type extends the \\`UnprefixedEnv\\` interface by including additional keys that are prefixed according to the project's configuration. This allows for flexibility in accessing environment variables with different naming conventions.`}\n </TSDocRemarks>\n </TSDoc>\n <BaseInterfaceDeclaration name=\"Env\" export extends=\"UnprefixedEnv\">\n <For\n each={getUnique(context.config.env.prefix).map(prefix =>\n prefix.replace(/_$/, \"\")\n )}\n doubleHardline>\n {prefix => (\n <For\n each={\n reflection\n ?.getProperties()\n .filter(property => !property.isIgnored()) ?? []\n }\n doubleHardline>\n {property => (\n <>\n <TSDocReflectionProperty reflection={property} />\n <InterfaceMember\n name={`${prefix}_${property.getNameAsString()}`}\n type={`UnprefixedEnv[\"${property.getNameAsString()}\"]`}\n readonly={property.isReadonly()}\n />\n </>\n )}\n </For>\n )}\n </For>\n </BaseInterfaceDeclaration>\n <Spacing />\n </>\n );\n}\n\ninterface ConfigPropertyConditionalProps extends ComponentProps {\n context: EnvPluginContext;\n name: string;\n}\n\nfunction ConfigPropertyConditional(props: ConfigPropertyConditionalProps) {\n const [{ context, name }] = splitProps(props, [\"context\", \"name\"]);\n\n return code`propertyName === \"${name}\" || propertyName.replace(/^(${getUnique(\n context.config.env.prefix\n .sort((a, b) =>\n a.startsWith(b) ? -1 : b.startsWith(a) ? 1 : a.localeCompare(b)\n )\n .map(prefix => `${prefix.replace(/_$/, \"\")}_`)\n ).join(\"|\")})/g, \"\").toLowerCase().replace(/[\\\\s\\\\-_]+/g, \"\") === \"${name\n .toLowerCase()\n .replace(/[\\s\\-_]+/g, \"\")}\"`;\n}\n\ninterface ConfigPropertyProps extends ComponentProps {\n index: number;\n context: EnvPluginContext;\n property: ReflectionProperty;\n}\n\nfunction ConfigPropertyGet(props: ConfigPropertyProps) {\n const [{ context, property, index }] = splitProps(props, [\n \"context\",\n \"property\",\n \"index\"\n ]);\n\n return (\n <>\n {index === 0 ? (\n <IfStatement\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`return target[\"${property.getNameAsString()}\"];`}\n </IfStatement>\n ) : (\n <ElseIfClause\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`return target[\"${property.getNameAsString()}\"];`}\n </ElseIfClause>\n )}\n </>\n );\n}\n\nfunction ConfigPropertySet(props: ConfigPropertyProps) {\n const [{ context, property, index }] = splitProps(props, [\n \"context\",\n \"property\",\n \"index\"\n ]);\n\n return (\n <>\n {index === 0 ? (\n <IfStatement\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`\n target[\"${property.getNameAsString()}\"] = newValue;\n return true;\n`}\n </IfStatement>\n ) : (\n <ElseIfClause\n condition={\n <>\n <ConfigPropertyConditional\n name={property.getNameAsString()}\n context={context}\n />\n <Show\n when={property.getAlias() && property.getAlias().length > 0}>\n {code` || `}\n <For each={property.getAlias()} joiner={code` || `}>\n {alias => (\n <ConfigPropertyConditional name={alias} context={context} />\n )}\n </For>\n </Show>\n </>\n }>\n {code`\n target[\"${property.getNameAsString()}\"] = newValue;\n return true;\n`}\n </ElseIfClause>\n )}\n </>\n );\n}\n\nexport interface EnvBuiltinProps extends Omit<BuiltinFileProps, \"id\"> {\n defaultConfig?: Children;\n reflection: ReflectionClass<any>;\n}\n\nconst createEnvRefkey = refkey(\"createEnv\");\nconst envRefkey = refkey(\"env\");\nconst envSerializerRefkey = refkey(\"EnvSerializer\");\n\n/**\n * Generates the environment configuration module for the Powerlines project.\n */\nexport function EnvBuiltin(props: EnvBuiltinProps) {\n const [{ defaultConfig, reflection, children }, rest] = splitProps(props, [\n \"defaultConfig\",\n \"reflection\",\n \"children\"\n ]);\n\n const context = usePowerlines<EnvPluginContext>();\n const defaultValue = computed(\n () => context && loadEnvFromContext(context, process.env)\n );\n\n const envInstance = computed(() => {\n const result = new ReflectionClass(\n {\n kind: ReflectionKind.objectLiteral,\n description: `The initial environment configuration state for the ${titleCase(\n context?.config?.name\n )} project.`,\n types: []\n },\n reflection\n );\n\n result\n .getProperties()\n .filter(\n property => property.isRuntime() || property.getTags().runtime === true\n )\n .forEach(property => {\n result.removeProperty(property.getNameAsString());\n });\n\n return result;\n });\n\n const reflectionGetProperties = computed(\n () =>\n reflection\n ?.getProperties()\n .filter(property => !property.isIgnored())\n .sort((a, b) =>\n a.getNameAsString().localeCompare(b.getNameAsString())\n ) ?? []\n );\n const reflectionSetProperties = computed(\n () =>\n reflection\n ?.getProperties()\n .filter(property => !property.isIgnored() && !property.isReadonly())\n .sort((a, b) =>\n a.getNameAsString().localeCompare(b.getNameAsString())\n ) ?? []\n );\n\n return (\n <BuiltinFile\n id=\"env\"\n description=\"The environment configuration module provides an interface to define environment configuration parameters.\"\n {...rest}\n imports={defu(\n {\n \"@powerlines/deepkit/vendor/type\": [\n \"serializeFunction\",\n \"deserializeFunction\",\n \"ReflectionKind\",\n \"Serializer\",\n \"NamingStrategy\",\n \"TemplateState\",\n \"Type\",\n \"TypeProperty\",\n \"TypePropertySignature\"\n ]\n },\n rest.imports ?? {}\n )}>\n <Show when={Boolean(reflection)}>\n <EnvTypeDefinition\n defaultValue={defaultValue}\n reflection={reflection}\n />\n <hbr />\n <hbr />\n </Show>\n\n <ObjectDeclaration\n name=\"initialEnv\"\n type=\"Partial<Env>\"\n defaultValue={defaultValue}\n reflection={envInstance}\n export\n const\n doc=\"The initial environment configuration object values for the runtime.\"\n />\n <Spacing />\n\n <TSDoc heading=\"The environment configuration serializer for the Powerlines application.\">\n <TSDocLink>\n {`https://deepkit.io/docs/serialization/serializers`}\n </TSDocLink>\n <TSDocLink>\n {`https://github.com/marcj/untitled-code/blob/master/packages/type/src/serializer.ts#L1918`}\n </TSDocLink>\n <TSDocRemarks>\n {`This serializer is used to serialize and deserialize the Powerlines environment configuration.`}\n </TSDocRemarks>\n </TSDoc>\n <ClassDeclaration\n refkey={envSerializerRefkey}\n name=\"EnvSerializer\"\n extends=\"Serializer\"\n export>\n <ClassMethod\n name=\"constructor\"\n public\n doc=\"Initializes a new instance of the `EnvSerializer` class.\">\n {code`super(\"env\");\n\n this.deserializeRegistry.register(\n ReflectionKind.boolean,\n (type: Type, state: TemplateState) => {\n state.addSetter(\n \\`typeof \\${state.accessor.toString()} !== \"boolean\" ? \\${state.accessor.toString()} === 1 || \\${state.accessor.toString()} === \"1\" || \\${state.accessor.toString()}.toLowerCase() === \"t\" || \\${state.accessor.toString()}.toLowerCase() === \"true\" || \\${state.accessor.toString()}.toLowerCase() === \"y\" || \\${state.accessor.toString()}.toLowerCase() === \"yes\" : \\${state.accessor.toString()}\\`\n );\n }\n ); `}\n </ClassMethod>\n </ClassDeclaration>\n <Spacing />\n\n <VarDeclaration\n name=\"envNamingStrategy\"\n const\n doc=\"The environment naming strategy for the runtime.\"\n initializer={code`new class extends NamingStrategy {\n constructor() {\n super(\"env\");\n }\n\n getPropertyName(type: TypeProperty | TypePropertySignature, forSerializer: string): string | undefined {\n const name = super.getPropertyName(type, forSerializer);\n if (!name) {\n return name;\n }\n\n return name.replace(/^(${getUnique(\n context.config.env.prefix\n )\n .map(prefix => prefix.replace(/_$/, \"\"))\n .join(\"|\")})_/, \"\");\n }\n }; `}\n />\n <Spacing />\n\n <TSDoc heading=\"A {@link EnvSerializer | environment configuration serializer} instance for the Powerlines application.\">\n <TSDocLink>\n {`https://deepkit.io/docs/serialization/serializers`}\n </TSDocLink>\n <TSDocLink>\n {`https://github.com/marcj/untitled-code/blob/master/packages/type/src/serializer.ts#L1918`}\n </TSDocLink>\n <TSDocRemarks>\n {`This serializer is used to serialize and deserialize the Powerlines environment configuration.`}\n </TSDocRemarks>\n </TSDoc>\n <VarDeclaration\n name=\"envSerializer\"\n const\n initializer={<NewExpression args={[]} target=\"EnvSerializer\" />}\n />\n <Spacing />\n\n <VarDeclaration\n name=\"_serializeEnv\"\n const\n initializer={\"serializeFunction<Env>(envSerializer, envNamingStrategy)\"}\n />\n <Spacing />\n <TSDoc heading=\"Serialize a environment configuration object to JSON data objects (not a JSON string).\">\n <TSDocRemarks>\n {`The resulting JSON object can be stringified using \\`JSON.stringify()\\`.`}\n </TSDocRemarks>\n <TSDocExample>{`const json = serializeEnv(env);`}</TSDocExample>\n <Spacing />\n <TSDocParam name=\"input\">\n {`The environment configuration object to serialize.`}\n </TSDocParam>\n <TSDocReturns>\n {`The serialized environment configuration as JSON data objects.`}\n </TSDocReturns>\n <TSDocThrows>\n {`ValidationError when serialization or validation fails.`}\n </TSDocThrows>\n </TSDoc>\n <FunctionDeclaration\n name=\"serializeEnv\"\n export\n parameters={[\n {\n name: \"input\",\n type: \"Env\"\n }\n ]}>\n {code` return _serializeEnv(input, { loosely: true }); `}\n </FunctionDeclaration>\n <Spacing />\n\n <VarDeclaration\n name=\"_deserializeEnv\"\n const\n initializer=\"deserializeFunction<Env>(envSerializer, envNamingStrategy)\"\n />\n <Spacing />\n <TSDoc heading=\"Deserialize a environment configuration object from JSON data objects to JavaScript objects, without running any validators.\">\n <TSDocRemarks>\n {`Types that are already correct will be used as-is.`}\n </TSDocRemarks>\n <TSDocExample>{`const env = deserializeEnv(json);`}</TSDocExample>\n <TSDocThrows>\n {`ValidationError when deserialization fails.`}\n </TSDocThrows>\n </TSDoc>\n <FunctionDeclaration\n name=\"deserializeEnv\"\n export\n parameters={[\n {\n name: \"input\",\n type: \"Env\"\n }\n ]}>\n {code` return _deserializeEnv(input, { loosely: true }); `}\n </FunctionDeclaration>\n <Spacing />\n\n <TSDoc heading=\"Initializes the Powerlines environment configuration module.\">\n <TSDocRemarks>\n {`This function initializes the Powerlines environment configuration object.`}\n </TSDocRemarks>\n <TSDocParam name=\"environmentConfig\">\n {`The dynamic/runtime configuration - this could include the current environment variables or any other environment-specific settings provided by the runtime.`}\n </TSDocParam>\n <TSDocReturns>\n {`The initialized Powerlines configuration object.`}\n </TSDocReturns>\n </TSDoc>\n <Show when={Boolean(context?.entryPath)}>\n <FunctionDeclaration\n refkey={createEnvRefkey}\n async={false}\n export\n name=\"createEnv\"\n parameters={[\n {\n name: \"environmentConfig\",\n type: `Partial<Env>`,\n optional: false,\n default: \"{}\"\n }\n ]}\n returnType=\"Env\">\n {code`\n return new Proxy<Env>(\n deserializeEnv({\n ...initialEnv,\n ...environmentConfig\n } as Env),\n {\n get: (target: UnprefixedEnv, propertyName: string) => { `}\n <hbr />\n\n <For each={reflectionGetProperties}>\n {(property: ReflectionProperty, index: number) => (\n <ConfigPropertyGet\n index={index}\n context={context}\n property={property}\n />\n )}\n </For>\n {code`\n return undefined;\n }, `}\n\n <Spacing />\n {code` set: (target: UnprefixedEnv, propertyName: string, newValue: any) => { `}\n <hbr />\n <For each={reflectionSetProperties} ender={code` else `}>\n {(property: ReflectionProperty, index: number) => (\n <ConfigPropertySet\n index={index}\n context={context}\n property={property}\n />\n )}\n </For>\n\n <hbr />\n {code`return false;\n }\n }\n );\n`}\n </FunctionDeclaration>\n </Show>\n <Spacing />\n <hbr />\n\n <TSDoc heading=\"The environment configuration object.\">\n <TSDocRemarks>\n {`This object provides access to the environment configuration parameters in the application runtime.`}\n </TSDocRemarks>\n </TSDoc>\n <VarDeclaration\n refkey={envRefkey}\n name=\"env\"\n type=\"Env\"\n export\n const\n initializer={\n <>{code`createEnv(${defaultConfig || \"{}\"} as Partial<Env>);`}</>\n }\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isCI\"\n doc=\"Detect if the application is running in a continuous integration (CI) environment.\"\n initializer={code`Boolean(\n env.CI ||\n env.RUN_ID ||\n env.AGOLA_GIT_REF ||\n env.AC_APPCIRCLE ||\n env.APPVEYOR ||\n env.CODEBUILD ||\n env.TF_BUILD ||\n env.bamboo_planKey ||\n env.BITBUCKET_COMMIT ||\n env.BITRISE_IO ||\n env.BUDDY_WORKSPACE_ID ||\n env.BUILDKITE ||\n env.CIRCLECI ||\n env.CIRRUS_CI ||\n env.CF_BUILD_ID ||\n env.CM_BUILD_ID ||\n env.CI_NAME ||\n env.DRONE ||\n env.DSARI ||\n env.EARTHLY_CI ||\n env.EAS_BUILD ||\n env.GERRIT_PROJECT ||\n env.GITEA_ACTIONS ||\n env.GITHUB_ACTIONS ||\n env.GITLAB_CI ||\n env.GOCD ||\n env.BUILDER_OUTPUT ||\n env.HARNESS_BUILD_ID ||\n env.JENKINS_URL ||\n env.LAYERCI ||\n env.MAGNUM ||\n env.NETLIFY ||\n env.NEVERCODE ||\n env.PROW_JOB_ID ||\n env.RELEASE_BUILD_ID ||\n env.RENDER ||\n env.SAILCI ||\n env.HUDSON ||\n env.SCREWDRIVER ||\n env.SEMAPHORE ||\n env.SOURCEHUT ||\n env.STRIDER ||\n env.TASK_ID ||\n env.RUN_ID ||\n env.TEAMCITY_VERSION ||\n env.TRAVIS ||\n env.VELA ||\n env.NOW_BUILDER ||\n env.APPCENTER_BUILD_ID ||\n env.CI_XCODE_PROJECT ||\n env.XCS || false\n ); `}\n />\n <Spacing />\n\n <TSDoc heading=\"Detect the \\`mode\\` of the current runtime environment.\">\n <TSDocRemarks>\n {code`The \\`mode\\` is determined by the \\`MODE\\` environment variable, or falls back to the \\`NEXT_PUBLIC_VERCEL_ENV\\`, \\`NODE_ENV\\`, or defaults to \\`production\\`. While the value can potentially be any string, it is generally recommended to only allow a value in the following list:\n - \\`production\\`\n - \\`test\\`\n - \\`development\\`\n `}\n </TSDocRemarks>\n </TSDoc>\n <VarDeclaration\n export\n const\n name=\"mode\"\n initializer={code`String(env.MODE) || \"production\"; `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isProduction\"\n doc='Detect if the application is running in `\"production\"` mode'\n initializer={code`[\"prd\", \"prod\", \"production\"].includes(mode.toLowerCase()); `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isTest\"\n doc='Detect if the application is running in `\"test\"` mode'\n initializer={code`[\"tst\", \"test\", \"testing\", \"stg\", \"stage\", \"staging\"].includes(mode.toLowerCase()) || env.TEST; `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isDevelopment\"\n doc='Detect if the application is running in `\"development\"` mode'\n initializer={code`[\"dev\", \"development\"].includes(mode.toLowerCase()); `}\n />\n <Spacing />\n\n <VarDeclaration\n export\n const\n name=\"isDebug\"\n doc=\"Detect if the application is currently being debugged\"\n initializer={code`Boolean(isDevelopment && env.DEBUG); `}\n />\n <Spacing />\n <Show when={Boolean(children)}>{children}</Show>\n </BuiltinFile>\n );\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"automd-generator.mjs","names":[],"sources":["../../src/helpers/automd-generator.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 { joinPaths } from \"@stryke/path/join-paths\";\nimport { defineGenerator } from \"automd\";\nimport { UnresolvedContext } from \"powerlines\";\n\n/**\n * AutoMD generator to generate environment variable documentation\n *\n * @param context - The generator context.\n * @returns The generated documentation content.\n */\nexport const env = (context: UnresolvedContext) =>\n defineGenerator({\n name: \"env\",\n async generate() {\n const envDocFile = joinPaths(\n context.config.root,\n \"docs\",\n \"generated\",\n \"env.md\"\n );\n\n if (!context.fs.existsSync(envDocFile)) {\n return {\n contents: \"\"\n };\n }\n\n const contents = await context.fs.read(envDocFile);\n\n return {\n contents: contents || \"\"\n };\n }\n });\n"],"mappings":";;;;AAAA,SAAS,aAAa,IAAI,MAAM;;AAE5B,QAAO;;;;;;;;AA2BX,MAAE,MAAgB,cAAA,YAAA,gBAAA;CACd,MAAM;CACN,UAAM,aAAW,eAAA,WAAA;EACf,MAAM,aAAa,UAAS,QAAA,OAAA,MAAA,QAAA,aAAA,SAAA;AAC1B,MAAA,CAAA,QAAQ,GAAO,WAAI,WAAA,CAClB,QAAK,EACL,UAAU,IACN;AAGL,SAAG,EACH,+CAAO,IACN;IACF,CAAC,YAAC,QAAA,CAAA;CACR,CAAC,EAAE;CAAC;CAAC;CAAA;CAAA,CAAA"}
1
+ {"version":3,"file":"automd-generator.mjs","names":[],"sources":["../../src/helpers/automd-generator.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 { joinPaths } from \"@stryke/path/join-paths\";\nimport { defineGenerator } from \"automd\";\nimport { UnresolvedContext } from \"powerlines\";\n\n/**\n * AutoMD generator to generate environment variable documentation\n *\n * @param context - The generator context.\n * @returns The generated documentation content.\n */\nexport const env = (context: UnresolvedContext) =>\n defineGenerator({\n name: \"env\",\n async generate() {\n const envDocFile = joinPaths(\n context.config.root,\n \"docs\",\n \"generated\",\n \"env.md\"\n );\n\n if (!context.fs.existsSync(envDocFile)) {\n return {\n contents: \"\"\n };\n }\n\n const contents = await context.fs.read(envDocFile);\n\n return {\n contents: contents || \"\"\n };\n }\n });\n"],"mappings":";;;;AAAA,SAAS,aAAa,IAAI,MAAM;;AAE9B,QAAO;;;;;;;;AA2BT,MAAE,MAAgB,cAAA,YAAA,gBAAA;CAChB,MAAM;CACN,UAAQ,aAAW,eAAA,WAAA;EACjB,MAAE,aAAiB,UAAE,QAAS,OAAA,MAAA,QAAA,aAAA,SAAA;AAC9B,MAAI,CAAA,QAAQ,GAAA,WAAW,WAAA,CACrB,QAAO,EACL,UAAU,IACX;AAGH,SAAO,EACL,UAAS,qCAAA,IACV;IACA,CAAC,YAAG,QAAA,CAAA;CACR,CAAC,EAAE;CAAC;CAAC;CAAA;CAAA,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"create-reflection-resource.mjs","names":[],"sources":["../../src/helpers/create-reflection-resource.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 { EnvPluginContext } from \"../types/plugin\";\n\n/**\n * Creates a reflection resource for the environment configuration.\n *\n * @param _context - The environment plugin context.\n * @returns A resource that provides the reflection of the environment configuration.\n */\nexport function createReflection(_context: EnvPluginContext) {\n // const defaultValue = computed(\n // () => context && loadEnvFromContext(context, process.env)\n // );\n\n return {};\n\n // return computed(() => {\n // result.getProperties().forEach(prop => {\n // const aliases = prop.getAlias();\n // aliases.filter(Boolean).forEach(alias => {\n // result.addProperty({\n // name: alias,\n // optional: prop.isOptional() ? true : undefined,\n // readonly: prop.isReadonly() ? true : undefined,\n // description: prop.getDescription(),\n // visibility: prop.getVisibility(),\n // type: prop.getType(),\n // default: prop.getDefaultValue(),\n // tags: {\n // hidden: prop.isHidden(),\n // ignore: prop.isIgnored(),\n // internal: prop.isInternal(),\n // alias: prop\n // .getAlias()\n // .filter(a => a !== alias)\n // .concat(prop.name),\n // title: prop.getTitle() || titleCase(prop.name),\n // readonly: prop.isReadonly(),\n // permission: prop.getPermission(),\n // domain: prop.getDomain()\n // }\n // });\n // });\n // });\n\n // result.getProperties().forEach(prop => {\n // prop.setDefaultValue(\n // (defaultValue.value as Record<string, any>)?.[prop.getNameAsString()] ??\n // prop\n // .getAlias()\n // .reduce(\n // (ret, alias) =>\n // ret ?? (defaultValue.value as Record<string, any>)?.[alias],\n // undefined\n // ) ??\n // prop.getDefaultValue()\n // );\n // });\n // });\n}\n"],"mappings":";;;;;;;;;;AAYC,QAAU,EAAE;;AA4Cb,iBAAe,SAAQ;OAAK;CAAU;CAAA;CAAA;CAAA;CAAA"}
1
+ {"version":3,"file":"create-reflection-resource.mjs","names":[],"sources":["../../src/helpers/create-reflection-resource.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 { EnvPluginContext } from \"../types/plugin\";\n\n/**\n * Creates a reflection resource for the environment configuration.\n *\n * @param _context - The environment plugin context.\n * @returns A resource that provides the reflection of the environment configuration.\n */\nexport function createReflection(_context: EnvPluginContext) {\n // const defaultValue = computed(\n // () => context && loadEnvFromContext(context, process.env)\n // );\n\n return {};\n\n // return computed(() => {\n // result.getProperties().forEach(prop => {\n // const aliases = prop.getAlias();\n // aliases.filter(Boolean).forEach(alias => {\n // result.addProperty({\n // name: alias,\n // optional: prop.isOptional() ? true : undefined,\n // readonly: prop.isReadonly() ? true : undefined,\n // description: prop.getDescription(),\n // visibility: prop.getVisibility(),\n // type: prop.getType(),\n // default: prop.getDefaultValue(),\n // tags: {\n // hidden: prop.isHidden(),\n // ignore: prop.isIgnored(),\n // internal: prop.isInternal(),\n // alias: prop\n // .getAlias()\n // .filter(a => a !== alias)\n // .concat(prop.name),\n // title: prop.getTitle() || titleCase(prop.name),\n // readonly: prop.isReadonly(),\n // permission: prop.getPermission(),\n // domain: prop.getDomain()\n // }\n // });\n // });\n // });\n\n // result.getProperties().forEach(prop => {\n // prop.setDefaultValue(\n // (defaultValue.value as Record<string, any>)?.[prop.getNameAsString()] ??\n // prop\n // .getAlias()\n // .reduce(\n // (ret, alias) =>\n // ret ?? (defaultValue.value as Record<string, any>)?.[alias],\n // undefined\n // ) ??\n // prop.getDefaultValue()\n // );\n // });\n // });\n}\n"],"mappings":";;;;;;;;;;AAYC,QAAQ,EAAE;;AA4CX,iBAAe,SAAQ;OAAK;CAAU;CAAA;CAAA;CAAA;CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"docs-helper.mjs","names":[],"sources":["../../src/helpers/docs-helper.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 { joinPaths } from \"@stryke/path/join\";\nimport { EnvPluginContext } from \"../types/plugin\";\n\n/**\n * Gets the output path for the generated environment documentation.\n *\n * @param context - The environment plugin context.\n * @returns The output path for the generated environment documentation.\n */\nexport function getDocsOutputPath(context: EnvPluginContext): string {\n return joinPaths(context.config.root, \"docs\", \"generated\");\n}\n"],"mappings":";;;;;;;;;;AA0BA,SAAE,kBAAA,SAAA;AACF,QAAO,UAAS,QAAA,OAAkB,MAAQ,QAAC,YAAmB;;AAE9D,kBAAA,SAAA;OAAA;CAAA;CAAA;CAAA;CAAA;CAAA"}
1
+ {"version":3,"file":"docs-helper.mjs","names":[],"sources":["../../src/helpers/docs-helper.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 { joinPaths } from \"@stryke/path/join\";\nimport { EnvPluginContext } from \"../types/plugin\";\n\n/**\n * Gets the output path for the generated environment documentation.\n *\n * @param context - The environment plugin context.\n * @returns The output path for the generated environment documentation.\n */\nexport function getDocsOutputPath(context: EnvPluginContext): string {\n return joinPaths(context.config.root, \"docs\", \"generated\");\n}\n"],"mappings":";;;;;;;;;;AA0BA,SAAE,kBAAA,SAAA;AACF,QAAO,UAAS,QAAA,OAAkB,MAAA,QAAS,YAAiB;;AAE5D,kBAAA,SAAA;OAAA;CAAA;CAAA;CAAA;CAAA;CAAA"}
@@ -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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"}