@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.
- package/dist/helpers/generate-service-env.d.ts +16 -0
- package/dist/helpers/index.d.ts +1 -0
- package/dist/index.cjs +34 -0
- package/dist/index.js +34 -0
- package/package.json +1 -1
|
@@ -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;
|
package/dist/helpers/index.d.ts
CHANGED
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,
|