@crossdelta/infrastructure 0.2.2 → 0.2.3

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.
@@ -0,0 +1,16 @@
1
+ /**
2
+ * Generate service-specific env.ts content.
3
+ *
4
+ * @param serviceName - The name of the service (e.g., 'orders', 'api-gateway')
5
+ * @returns The content for the service's src/env.ts file
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * import { generateServiceEnvFile } from '@crossdelta/infrastructure'
10
+ * import { writeFileSync } from 'node:fs'
11
+ *
12
+ * const content = generateServiceEnvFile('orders')
13
+ * writeFileSync('services/orders/src/env.ts', content)
14
+ * ```
15
+ */
16
+ export declare function generateServiceEnvFile(serviceName: string): string;
@@ -1,6 +1,7 @@
1
1
  export * from './config';
2
2
  export * from './discover-services';
3
3
  export * from './docker-hub-image';
4
+ export * from './generate-service-env';
4
5
  export * from './image';
5
6
  export * from './service-builder';
6
7
  export * from './service-runtime';
package/dist/index.cjs CHANGED
@@ -32,6 +32,7 @@ __export(exports_lib, {
32
32
  getServiceUrl: () => getServiceUrl,
33
33
  getServicePort: () => getServicePort2,
34
34
  getImage: () => getImage,
35
+ generateServiceEnvFile: () => generateServiceEnvFile,
35
36
  ensureDot: () => ensureDot,
36
37
  dockerHubImage: () => dockerHubImage,
37
38
  discoverServices: () => discoverServices,
@@ -128,6 +129,39 @@ var dockerHubImage = (repository, tag, registry = "library") => ({
128
129
  repository,
129
130
  tag
130
131
  });
132
+ // lib/helpers/generate-service-env.ts
133
+ function generateServiceEnvFile(serviceName) {
134
+ const envKey = serviceName.toUpperCase().replace(/-/g, "_");
135
+ return `/**
136
+ * Service environment configuration.
137
+ * Auto-generated by: bun run generate-env
138
+ * DO NOT EDIT MANUALLY - changes will be overwritten!
139
+ */
140
+
141
+ import {
142
+ getServicePort as _getServicePort,
143
+ getServiceUrl as _getServiceUrl,
144
+ } from '@crossdelta/infrastructure/env'
145
+
146
+ /** This service's name */
147
+ export const SERVICE_NAME = '${serviceName}' as const
148
+ export type ServiceName = typeof SERVICE_NAME
149
+
150
+ /**
151
+ * Get the port for this service from environment variables.
152
+ * Reads from ${envKey}_PORT
153
+ */
154
+ export const getServicePort = (defaultPort = 8080): number =>
155
+ _getServicePort(SERVICE_NAME, defaultPort)
156
+
157
+ /**
158
+ * Get the URL for this service from environment variables.
159
+ * Reads from ${envKey}_URL
160
+ */
161
+ export const getServiceUrl = (): string | undefined =>
162
+ _getServiceUrl(SERVICE_NAME)
163
+ `;
164
+ }
131
165
  // lib/helpers/image.ts
132
166
  var scopeImageTagsRaw = process.env.SCOPE_IMAGE_TAGS ?? "";
133
167
  var scopeImageTags = (() => {
package/dist/index.js CHANGED
@@ -80,6 +80,39 @@ var dockerHubImage = (repository, tag, registry = "library") => ({
80
80
  repository,
81
81
  tag
82
82
  });
83
+ // lib/helpers/generate-service-env.ts
84
+ function generateServiceEnvFile(serviceName) {
85
+ const envKey = serviceName.toUpperCase().replace(/-/g, "_");
86
+ return `/**
87
+ * Service environment configuration.
88
+ * Auto-generated by: bun run generate-env
89
+ * DO NOT EDIT MANUALLY - changes will be overwritten!
90
+ */
91
+
92
+ import {
93
+ getServicePort as _getServicePort,
94
+ getServiceUrl as _getServiceUrl,
95
+ } from '@crossdelta/infrastructure/env'
96
+
97
+ /** This service's name */
98
+ export const SERVICE_NAME = '${serviceName}' as const
99
+ export type ServiceName = typeof SERVICE_NAME
100
+
101
+ /**
102
+ * Get the port for this service from environment variables.
103
+ * Reads from ${envKey}_PORT
104
+ */
105
+ export const getServicePort = (defaultPort = 8080): number =>
106
+ _getServicePort(SERVICE_NAME, defaultPort)
107
+
108
+ /**
109
+ * Get the URL for this service from environment variables.
110
+ * Reads from ${envKey}_URL
111
+ */
112
+ export const getServiceUrl = (): string | undefined =>
113
+ _getServiceUrl(SERVICE_NAME)
114
+ `;
115
+ }
83
116
  // lib/helpers/image.ts
84
117
  var scopeImageTagsRaw = process.env.SCOPE_IMAGE_TAGS ?? "";
85
118
  var scopeImageTags = (() => {
@@ -215,6 +248,7 @@ export {
215
248
  getServiceUrl,
216
249
  getServicePort2 as getServicePort,
217
250
  getImage,
251
+ generateServiceEnvFile,
218
252
  ensureDot,
219
253
  dockerHubImage,
220
254
  discoverServices,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@crossdelta/infrastructure",
3
- "version": "0.2.2",
3
+ "version": "0.2.3",
4
4
  "type": "module",
5
5
  "license": "MIT",
6
6
  "publishConfig": {