@whook/gcp-functions 8.5.1 → 10.0.0
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/README.md +51 -40
- package/dist/commands/testHTTPFunction.d.ts +1 -1
- package/dist/commands/testHTTPFunction.js +119 -150
- package/dist/commands/testHTTPFunction.js.map +1 -1
- package/dist/index.d.ts +3 -6
- package/dist/index.js +182 -269
- package/dist/index.js.map +1 -1
- package/dist/libs/utils.js +16 -35
- package/dist/libs/utils.js.map +1 -1
- package/dist/services/_autoload.d.ts +14 -2
- package/dist/services/_autoload.js +85 -105
- package/dist/services/_autoload.js.map +1 -1
- package/dist/services/log.d.ts +4 -1
- package/dist/services/log.js +2 -12
- package/dist/services/log.js.map +1 -1
- package/dist/services/log.test.js +4 -9
- package/dist/services/log.test.js.map +1 -1
- package/dist/wrappers/googleHTTPFunction.js +246 -292
- package/dist/wrappers/googleHTTPFunction.js.map +1 -1
- package/package.json +55 -98
- package/src/commands/testHTTPFunction.ts +12 -19
- package/src/index.ts +48 -62
- package/src/libs/utils.ts +4 -5
- package/src/services/_autoload.ts +127 -122
- package/src/services/log.test.ts +2 -2
- package/src/wrappers/googleHTTPFunction.ts +34 -32
- package/dist/commands/testHTTPFunction.mjs +0 -136
- package/dist/commands/testHTTPFunction.mjs.map +0 -1
- package/dist/index.mjs +0 -265
- package/dist/index.mjs.map +0 -1
- package/dist/libs/utils.mjs +0 -27
- package/dist/libs/utils.mjs.map +0 -1
- package/dist/services/_autoload.mjs +0 -107
- package/dist/services/_autoload.mjs.map +0 -1
- package/dist/services/log.mjs +0 -4
- package/dist/services/log.mjs.map +0 -1
- package/dist/services/log.test.mjs +0 -7
- package/dist/services/log.test.mjs.map +0 -1
- package/dist/wrappers/googleHTTPFunction.mjs +0 -288
- package/dist/wrappers/googleHTTPFunction.mjs.map +0 -1
package/dist/index.mjs
DELETED
|
@@ -1,265 +0,0 @@
|
|
|
1
|
-
/* eslint global-require:0 */
|
|
2
|
-
import fs from 'fs';
|
|
3
|
-
import util from 'util';
|
|
4
|
-
import path from 'path';
|
|
5
|
-
import mkdirp from 'mkdirp';
|
|
6
|
-
import cpr from 'cpr';
|
|
7
|
-
import YError from 'yerror';
|
|
8
|
-
import Knifecycle, { SPECIAL_PROPS, constant, initInitializerBuilder } from 'knifecycle';
|
|
9
|
-
import { DEFAULT_BUILD_OPTIONS, initCompiler } from '@whook/whook';
|
|
10
|
-
import initBuildAutoloader from './services/_autoload';
|
|
11
|
-
import { dereferenceOpenAPIOperations, getOpenAPIOperations } from '@whook/http-router';
|
|
12
|
-
export const DEFAULT_BUILD_PARALLELISM = 10;
|
|
13
|
-
const readFileAsync = util.promisify(fs.readFile);
|
|
14
|
-
const writeFileAsync = util.promisify(fs.writeFile);
|
|
15
|
-
const cprAsync = util.promisify(cpr);
|
|
16
|
-
const BUILD_DEFINITIONS = {
|
|
17
|
-
http: {
|
|
18
|
-
type: 'HTTP',
|
|
19
|
-
wrapper: {
|
|
20
|
-
name: 'wrapHandlerForGoogleHTTPFunction',
|
|
21
|
-
path: path.join(__dirname, 'wrappers', 'googleHTTPFunction')
|
|
22
|
-
},
|
|
23
|
-
suffix: 'Wrapped'
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
export async function prepareBuildEnvironment($ = new Knifecycle()) {
|
|
27
|
-
$.register(constant('INITIALIZER_PATH_MAP', {
|
|
28
|
-
ENV: '@whook/whook/dist/services/ProxyedENV',
|
|
29
|
-
log: __dirname + '/services/log',
|
|
30
|
-
time: 'common-services/dist/time',
|
|
31
|
-
delay: 'common-services/dist/delay'
|
|
32
|
-
}));
|
|
33
|
-
$.register(initInitializerBuilder);
|
|
34
|
-
$.register(initBuildAutoloader);
|
|
35
|
-
$.register(initCompiler);
|
|
36
|
-
$.register(constant('PORT', 1337));
|
|
37
|
-
$.register(constant('HOST', 'localhost'));
|
|
38
|
-
return $;
|
|
39
|
-
}
|
|
40
|
-
export async function runBuild(aPrepareBuildEnvironment) {
|
|
41
|
-
try {
|
|
42
|
-
const handlerName = process.argv[2];
|
|
43
|
-
const $ = await aPrepareBuildEnvironment();
|
|
44
|
-
const {
|
|
45
|
-
NODE_ENV,
|
|
46
|
-
BUILD_PARALLELISM,
|
|
47
|
-
BUILD_OPTIONS,
|
|
48
|
-
PROJECT_DIR,
|
|
49
|
-
compiler,
|
|
50
|
-
log,
|
|
51
|
-
$autoload,
|
|
52
|
-
API,
|
|
53
|
-
buildInitializer
|
|
54
|
-
} = await $.run(['NODE_ENV', '?BUILD_PARALLELISM', '?BUILD_OPTIONS', 'PROJECT_DIR', 'process', 'compiler', 'log', '$autoload', 'API', 'buildInitializer']);
|
|
55
|
-
log('info', 'Environment initialized 🚀🌕');
|
|
56
|
-
const operations = (await dereferenceOpenAPIOperations(API, getOpenAPIOperations(API))).filter(operation => {
|
|
57
|
-
if (handlerName) {
|
|
58
|
-
const sourceOperationId = operation['x-whook'] && operation['x-whook'].sourceOperationId;
|
|
59
|
-
return handlerName === operation.operationId || handlerName === sourceOperationId;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
return true;
|
|
63
|
-
});
|
|
64
|
-
log('warning', `${operations.length} operations to process.`);
|
|
65
|
-
await processOperations({
|
|
66
|
-
NODE_ENV,
|
|
67
|
-
BUILD_OPTIONS: BUILD_OPTIONS || DEFAULT_BUILD_OPTIONS,
|
|
68
|
-
BUILD_PARALLELISM: BUILD_PARALLELISM || DEFAULT_BUILD_PARALLELISM,
|
|
69
|
-
PROJECT_DIR,
|
|
70
|
-
compiler,
|
|
71
|
-
log,
|
|
72
|
-
$autoload,
|
|
73
|
-
buildInitializer
|
|
74
|
-
}, operations);
|
|
75
|
-
await $.destroy();
|
|
76
|
-
} catch (err) {
|
|
77
|
-
// eslint-disable-next-line
|
|
78
|
-
console.error('💀 - Cannot launch the build:', err.stack, JSON.stringify(err.params, null, 2));
|
|
79
|
-
process.exit(1);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
async function processOperations({
|
|
84
|
-
NODE_ENV,
|
|
85
|
-
BUILD_PARALLELISM,
|
|
86
|
-
BUILD_OPTIONS,
|
|
87
|
-
PROJECT_DIR,
|
|
88
|
-
compiler,
|
|
89
|
-
log,
|
|
90
|
-
$autoload,
|
|
91
|
-
buildInitializer
|
|
92
|
-
}, operations) {
|
|
93
|
-
const operationsLeft = operations.slice(BUILD_PARALLELISM);
|
|
94
|
-
await Promise.all(operations.slice(0, BUILD_PARALLELISM).map(operation => buildAnyLambda({
|
|
95
|
-
NODE_ENV,
|
|
96
|
-
PROJECT_DIR,
|
|
97
|
-
BUILD_OPTIONS,
|
|
98
|
-
compiler,
|
|
99
|
-
log,
|
|
100
|
-
$autoload,
|
|
101
|
-
buildInitializer
|
|
102
|
-
}, operation)));
|
|
103
|
-
|
|
104
|
-
if (operationsLeft.length) {
|
|
105
|
-
log('info', operationsLeft.length, ' operations left.');
|
|
106
|
-
return processOperations({
|
|
107
|
-
NODE_ENV,
|
|
108
|
-
BUILD_PARALLELISM,
|
|
109
|
-
BUILD_OPTIONS,
|
|
110
|
-
PROJECT_DIR,
|
|
111
|
-
compiler,
|
|
112
|
-
log,
|
|
113
|
-
$autoload,
|
|
114
|
-
buildInitializer
|
|
115
|
-
}, operationsLeft);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
log('info', 'No more operations.');
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
async function buildAnyLambda({
|
|
122
|
-
NODE_ENV,
|
|
123
|
-
PROJECT_DIR,
|
|
124
|
-
BUILD_OPTIONS,
|
|
125
|
-
compiler,
|
|
126
|
-
log,
|
|
127
|
-
$autoload,
|
|
128
|
-
buildInitializer
|
|
129
|
-
}, operation) {
|
|
130
|
-
const {
|
|
131
|
-
operationId
|
|
132
|
-
} = operation;
|
|
133
|
-
|
|
134
|
-
try {
|
|
135
|
-
const whookConfig = operation['x-whook'] || {};
|
|
136
|
-
const operationType = whookConfig.type || 'http';
|
|
137
|
-
const sourceOperationId = whookConfig.sourceOperationId;
|
|
138
|
-
const entryPoint = operationId;
|
|
139
|
-
const finalEntryPoint = (sourceOperationId ? sourceOperationId : operationId) + ((operation['x-whook'] || {}).suffix || '');
|
|
140
|
-
log('warning', `Building ${operationType} "${finalEntryPoint}"...`);
|
|
141
|
-
const buildDefinition = BUILD_DEFINITIONS[operationType]; // eslint-disable-next-line
|
|
142
|
-
|
|
143
|
-
const applyWrapper = require(buildDefinition.wrapper.path).default;
|
|
144
|
-
|
|
145
|
-
const rootNode = await $autoload(entryPoint + (buildDefinition.suffix || ''));
|
|
146
|
-
const lambdaPath = path.join(PROJECT_DIR, 'builds', NODE_ENV, finalEntryPoint);
|
|
147
|
-
const finalHandlerInitializer = applyWrapper(rootNode.initializer);
|
|
148
|
-
const initializerContent = await buildInitializer(finalHandlerInitializer[SPECIAL_PROPS.INJECT].map(name => name === 'OPERATION_API' ? `OPERATION_API>OPERATION_API_${finalEntryPoint}` : name), BUILD_OPTIONS);
|
|
149
|
-
const indexContent = await buildLambdaIndex(rootNode, {
|
|
150
|
-
name: buildDefinition.wrapper.name,
|
|
151
|
-
path: buildDefinition.wrapper.path
|
|
152
|
-
}, BUILD_OPTIONS);
|
|
153
|
-
await mkdirp(lambdaPath);
|
|
154
|
-
await Promise.all([copyStaticFiles({
|
|
155
|
-
PROJECT_DIR,
|
|
156
|
-
log
|
|
157
|
-
}, lambdaPath, whookConfig.staticFiles || []), ensureFileAsync({
|
|
158
|
-
log
|
|
159
|
-
}, path.join(lambdaPath, 'initialize.js'), initializerContent), ensureFileAsync({
|
|
160
|
-
log
|
|
161
|
-
}, path.join(lambdaPath, 'main.js'), indexContent)]);
|
|
162
|
-
await buildFinalLambda({
|
|
163
|
-
compiler,
|
|
164
|
-
log
|
|
165
|
-
}, lambdaPath, whookConfig);
|
|
166
|
-
} catch (err) {
|
|
167
|
-
log('error', `Error building "${operationId}"...`);
|
|
168
|
-
log('stack', err.stack);
|
|
169
|
-
log('debug', JSON.stringify(err.params, null, 2));
|
|
170
|
-
throw YError.wrap(err, 'E_LAMBDA_BUILD', operationId);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
async function buildLambdaIndex(rootNode, buildWrapper, options) {
|
|
175
|
-
return `${options.modules === 'commonjs' ? `const pickModule = (m) => { return m && m.default || m; }
|
|
176
|
-
const initHandler = pickModule(require('${rootNode.path}'));
|
|
177
|
-
const ${buildWrapper.name} = pickModule(require('${buildWrapper.path}'));
|
|
178
|
-
const { initialize } = require('./initialize');` : `import initHandler from '${rootNode.path}';
|
|
179
|
-
import ${buildWrapper.name} from '${buildWrapper.path}';
|
|
180
|
-
import { initialize } from './initialize';`}
|
|
181
|
-
|
|
182
|
-
const handlerInitializer = ${buildWrapper.name}(
|
|
183
|
-
initHandler
|
|
184
|
-
);
|
|
185
|
-
|
|
186
|
-
const handlerPromise = initialize()
|
|
187
|
-
.then(handlerInitializer);
|
|
188
|
-
|
|
189
|
-
${options.modules === 'commonjs' ? 'module.exports = {}; module.exports.default = ' : 'export default '}function handler (req, res) {
|
|
190
|
-
return handlerPromise
|
|
191
|
-
.then(handler => handler(req, res));
|
|
192
|
-
};
|
|
193
|
-
`;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
async function buildFinalLambda({
|
|
197
|
-
compiler,
|
|
198
|
-
log
|
|
199
|
-
}, lambdaPath, whookConfig) {
|
|
200
|
-
const entryPoint = `${lambdaPath}/main.js`;
|
|
201
|
-
const {
|
|
202
|
-
contents,
|
|
203
|
-
mappings
|
|
204
|
-
} = await compiler(entryPoint, whookConfig.compilerOptions);
|
|
205
|
-
await Promise.all([ensureFileAsync({
|
|
206
|
-
log
|
|
207
|
-
}, `${lambdaPath}/index.js`, contents, 'utf-8'), mappings ? ensureFileAsync({
|
|
208
|
-
log
|
|
209
|
-
}, `${lambdaPath}/index.js.map`, mappings, 'utf-8') : Promise.resolve()]);
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
async function copyStaticFiles({
|
|
213
|
-
PROJECT_DIR,
|
|
214
|
-
log
|
|
215
|
-
}, lambdaPath, staticFiles = []) {
|
|
216
|
-
await Promise.all(staticFiles.map(async staticFile => await copyFiles({
|
|
217
|
-
log
|
|
218
|
-
}, path.join(PROJECT_DIR, 'node_modules', staticFile), path.join(lambdaPath, 'node_modules', staticFile))));
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
async function copyFiles({
|
|
222
|
-
log
|
|
223
|
-
}, source, destination) {
|
|
224
|
-
let theError;
|
|
225
|
-
|
|
226
|
-
try {
|
|
227
|
-
await mkdirp(destination);
|
|
228
|
-
const data = await readFileAsync(source, 'utf-8');
|
|
229
|
-
await ensureFileAsync({
|
|
230
|
-
log
|
|
231
|
-
}, destination, data, 'utf-8');
|
|
232
|
-
} catch (err) {
|
|
233
|
-
theError = err;
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
if (theError) {
|
|
237
|
-
if ('EISDIR' !== theError.code) {
|
|
238
|
-
throw theError;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
await cprAsync(source, destination, {
|
|
242
|
-
overwrite: true
|
|
243
|
-
});
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
async function ensureFileAsync({
|
|
248
|
-
log
|
|
249
|
-
}, path, content, encoding = 'utf-8') {
|
|
250
|
-
try {
|
|
251
|
-
const oldContent = await readFileAsync(path, encoding);
|
|
252
|
-
|
|
253
|
-
if (oldContent === content) {
|
|
254
|
-
log('debug', `Ignore unchanged file: "${path}".`);
|
|
255
|
-
return;
|
|
256
|
-
}
|
|
257
|
-
} catch (err) {
|
|
258
|
-
log('debug', `Write new file: "${path}".`);
|
|
259
|
-
return await writeFileAsync(path, content, encoding);
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
log('debug', `Write changed file: "${path}".`);
|
|
263
|
-
return await writeFileAsync(path, content, encoding);
|
|
264
|
-
}
|
|
265
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"names":["fs","util","path","mkdirp","cpr","YError","Knifecycle","SPECIAL_PROPS","constant","initInitializerBuilder","DEFAULT_BUILD_OPTIONS","initCompiler","initBuildAutoloader","dereferenceOpenAPIOperations","getOpenAPIOperations","DEFAULT_BUILD_PARALLELISM","readFileAsync","promisify","readFile","writeFileAsync","writeFile","cprAsync","BUILD_DEFINITIONS","http","type","wrapper","name","join","__dirname","suffix","prepareBuildEnvironment","$","register","ENV","log","time","delay","runBuild","aPrepareBuildEnvironment","handlerName","process","argv","NODE_ENV","BUILD_PARALLELISM","BUILD_OPTIONS","PROJECT_DIR","compiler","$autoload","API","buildInitializer","run","operations","filter","operation","sourceOperationId","operationId","length","processOperations","destroy","err","console","error","stack","JSON","stringify","params","exit","operationsLeft","slice","Promise","all","map","buildAnyLambda","whookConfig","operationType","entryPoint","finalEntryPoint","buildDefinition","applyWrapper","require","default","rootNode","lambdaPath","finalHandlerInitializer","initializer","initializerContent","INJECT","indexContent","buildLambdaIndex","copyStaticFiles","staticFiles","ensureFileAsync","buildFinalLambda","wrap","buildWrapper","options","modules","contents","mappings","compilerOptions","resolve","staticFile","copyFiles","source","destination","theError","data","code","overwrite","content","encoding","oldContent"],"mappings":"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","sourcesContent":["/* eslint global-require:0 */\nimport fs from 'fs';\nimport util from 'util';\nimport path from 'path';\nimport mkdirp from 'mkdirp';\nimport cpr from 'cpr';\nimport YError from 'yerror';\nimport Knifecycle, {\n SPECIAL_PROPS,\n constant,\n initInitializerBuilder,\n} from 'knifecycle';\nimport { DEFAULT_BUILD_OPTIONS, initCompiler } from '@whook/whook';\nimport initBuildAutoloader from './services/_autoload';\nimport {\n dereferenceOpenAPIOperations,\n getOpenAPIOperations,\n} from '@whook/http-router';\nimport type { Autoloader, Dependencies, BuildInitializer } from 'knifecycle';\nimport type {\n WhookOperation,\n WhookCompilerOptions,\n WhookCompilerService,\n} from '@whook/whook';\nimport type { OpenAPIV3 } from 'openapi-types';\nimport type { LogService } from 'common-services';\nimport type { CprOptions } from 'cpr';\nimport type { BuildOptions } from 'knifecycle/dist/build';\n\nexport const DEFAULT_BUILD_PARALLELISM = 10;\n\nexport type WhookBuildConfig = {\n BUILD_OPTIONS?: BuildOptions;\n BUILD_PARALLELISM?: number;\n};\nexport type WhookAPIOperationGCPFunctionConfig = {\n type?: 'http';\n sourceOperationId?: string;\n staticFiles?: string[];\n compilerOptions?: WhookCompilerOptions;\n suffix?: string;\n};\n\nconst readFileAsync = util.promisify(fs.readFile) as (\n path: string,\n encoding: string,\n) => Promise<string>;\nconst writeFileAsync = util.promisify(fs.writeFile) as (\n path: string,\n content: string,\n encoding: string,\n) => Promise<void>;\nconst cprAsync = util.promisify(cpr) as (\n source: string,\n destination: string,\n options: CprOptions,\n) => Promise<string[]>;\n\nconst BUILD_DEFINITIONS: Record<\n WhookAPIOperationGCPFunctionConfig['type'],\n {\n type: string;\n wrapper: { name: string; path: string };\n suffix?: string;\n }\n> = {\n http: {\n type: 'HTTP',\n wrapper: {\n name: 'wrapHandlerForGoogleHTTPFunction',\n path: path.join(__dirname, 'wrappers', 'googleHTTPFunction'),\n },\n suffix: 'Wrapped',\n },\n};\n\nexport async function prepareBuildEnvironment<\n T extends Knifecycle<Dependencies>,\n>($: T = new Knifecycle() as T): Promise<T> {\n $.register(\n constant('INITIALIZER_PATH_MAP', {\n ENV: '@whook/whook/dist/services/ProxyedENV',\n log: __dirname + '/services/log',\n time: 'common-services/dist/time',\n delay: 'common-services/dist/delay',\n }),\n );\n $.register(initInitializerBuilder);\n $.register(initBuildAutoloader);\n $.register(initCompiler);\n $.register(constant('PORT', 1337));\n $.register(constant('HOST', 'localhost'));\n\n return $;\n}\n\nexport async function runBuild(\n aPrepareBuildEnvironment: typeof prepareBuildEnvironment,\n): Promise<void> {\n try {\n const handlerName = process.argv[2];\n const $ = await aPrepareBuildEnvironment();\n const {\n NODE_ENV,\n BUILD_PARALLELISM,\n BUILD_OPTIONS,\n PROJECT_DIR,\n compiler,\n log,\n $autoload,\n API,\n buildInitializer,\n }: WhookBuildConfig & {\n NODE_ENV: string;\n PROJECT_DIR: string;\n compiler: WhookCompilerService;\n log: LogService;\n $autoload: Autoloader;\n API: OpenAPIV3.Document;\n buildInitializer: BuildInitializer;\n } = await $.run([\n 'NODE_ENV',\n '?BUILD_PARALLELISM',\n '?BUILD_OPTIONS',\n 'PROJECT_DIR',\n 'process',\n 'compiler',\n 'log',\n '$autoload',\n 'API',\n 'buildInitializer',\n ]);\n\n log('info', 'Environment initialized 🚀🌕');\n\n const operations = (\n await dereferenceOpenAPIOperations(\n API,\n getOpenAPIOperations<WhookAPIOperationGCPFunctionConfig>(API),\n )\n ).filter((operation) => {\n if (handlerName) {\n const sourceOperationId =\n operation['x-whook'] && operation['x-whook'].sourceOperationId;\n\n return (\n handlerName === operation.operationId ||\n handlerName === sourceOperationId\n );\n }\n return true;\n });\n\n log('warning', `${operations.length} operations to process.`);\n await processOperations(\n {\n NODE_ENV,\n BUILD_OPTIONS: BUILD_OPTIONS || DEFAULT_BUILD_OPTIONS,\n BUILD_PARALLELISM: BUILD_PARALLELISM || DEFAULT_BUILD_PARALLELISM,\n PROJECT_DIR,\n compiler,\n log,\n $autoload,\n buildInitializer,\n },\n operations,\n );\n await $.destroy();\n } catch (err) {\n // eslint-disable-next-line\n console.error(\n '💀 - Cannot launch the build:',\n err.stack,\n JSON.stringify(err.params, null, 2),\n );\n process.exit(1);\n }\n}\n\nasync function processOperations(\n {\n NODE_ENV,\n BUILD_PARALLELISM,\n BUILD_OPTIONS,\n PROJECT_DIR,\n compiler,\n log,\n $autoload,\n buildInitializer,\n }: {\n NODE_ENV: string;\n BUILD_PARALLELISM: number;\n BUILD_OPTIONS: BuildOptions;\n PROJECT_DIR: string;\n compiler: WhookCompilerService;\n log: LogService;\n $autoload: Autoloader;\n buildInitializer: BuildInitializer;\n },\n operations: WhookOperation<WhookAPIOperationGCPFunctionConfig>[],\n): Promise<void> {\n const operationsLeft = operations.slice(BUILD_PARALLELISM);\n\n await Promise.all(\n operations.slice(0, BUILD_PARALLELISM).map((operation) =>\n buildAnyLambda(\n {\n NODE_ENV,\n PROJECT_DIR,\n BUILD_OPTIONS,\n compiler,\n log,\n $autoload,\n buildInitializer,\n },\n operation,\n ),\n ),\n );\n\n if (operationsLeft.length) {\n log('info', operationsLeft.length, ' operations left.');\n return processOperations(\n {\n NODE_ENV,\n BUILD_PARALLELISM,\n BUILD_OPTIONS,\n PROJECT_DIR,\n compiler,\n log,\n $autoload,\n buildInitializer,\n },\n operationsLeft,\n );\n }\n log('info', 'No more operations.');\n}\n\nasync function buildAnyLambda(\n {\n NODE_ENV,\n PROJECT_DIR,\n BUILD_OPTIONS,\n compiler,\n log,\n $autoload,\n buildInitializer,\n }: {\n NODE_ENV: string;\n PROJECT_DIR: string;\n BUILD_OPTIONS: BuildOptions;\n compiler: WhookCompilerService;\n log: LogService;\n $autoload: Autoloader;\n buildInitializer: BuildInitializer;\n },\n operation: WhookOperation<WhookAPIOperationGCPFunctionConfig>,\n): Promise<void> {\n const { operationId } = operation;\n\n try {\n const whookConfig: WhookAPIOperationGCPFunctionConfig =\n operation['x-whook'] || {};\n const operationType = whookConfig.type || 'http';\n const sourceOperationId = whookConfig.sourceOperationId;\n const entryPoint = operationId;\n const finalEntryPoint =\n (sourceOperationId ? sourceOperationId : operationId) +\n ((operation['x-whook'] || {}).suffix || '');\n log('warning', `Building ${operationType} \"${finalEntryPoint}\"...`);\n const buildDefinition = BUILD_DEFINITIONS[operationType];\n // eslint-disable-next-line\n const applyWrapper = require(buildDefinition.wrapper.path).default;\n const rootNode = await $autoload(\n entryPoint + (buildDefinition.suffix || ''),\n );\n const lambdaPath = path.join(\n PROJECT_DIR,\n 'builds',\n NODE_ENV,\n finalEntryPoint,\n );\n const finalHandlerInitializer = applyWrapper(rootNode.initializer);\n\n const initializerContent = await buildInitializer(\n finalHandlerInitializer[SPECIAL_PROPS.INJECT].map((name) =>\n name === 'OPERATION_API'\n ? `OPERATION_API>OPERATION_API_${finalEntryPoint}`\n : name,\n ),\n BUILD_OPTIONS,\n );\n const indexContent = await buildLambdaIndex(\n rootNode,\n {\n name: buildDefinition.wrapper.name,\n path: buildDefinition.wrapper.path,\n },\n BUILD_OPTIONS,\n );\n\n await mkdirp(lambdaPath);\n await Promise.all([\n copyStaticFiles(\n { PROJECT_DIR, log },\n lambdaPath,\n whookConfig.staticFiles || [],\n ),\n ensureFileAsync(\n { log },\n path.join(lambdaPath, 'initialize.js'),\n initializerContent,\n ),\n ensureFileAsync({ log }, path.join(lambdaPath, 'main.js'), indexContent),\n ]);\n await buildFinalLambda({ compiler, log }, lambdaPath, whookConfig);\n } catch (err) {\n log('error', `Error building \"${operationId}\"...`);\n log('stack', err.stack);\n log('debug', JSON.stringify(err.params, null, 2));\n throw YError.wrap(err, 'E_LAMBDA_BUILD', operationId);\n }\n}\n\nasync function buildLambdaIndex(\n rootNode: { path: string },\n buildWrapper: { name: string; path: string },\n options: BuildOptions,\n): Promise<string> {\n return `${\n options.modules === 'commonjs'\n ? `const pickModule = (m) => { return m && m.default || m; }\nconst initHandler = pickModule(require('${rootNode.path}'));\nconst ${buildWrapper.name} = pickModule(require('${buildWrapper.path}'));\nconst { initialize } = require('./initialize');`\n : `import initHandler from '${rootNode.path}';\nimport ${buildWrapper.name} from '${buildWrapper.path}';\nimport { initialize } from './initialize';`\n }\n\nconst handlerInitializer = ${buildWrapper.name}(\n initHandler\n);\n\nconst handlerPromise = initialize()\n .then(handlerInitializer);\n\n${\n options.modules === 'commonjs'\n ? 'module.exports = {}; module.exports.default = '\n : 'export default '\n}function handler (req, res) {\n return handlerPromise\n .then(handler => handler(req, res));\n};\n`;\n}\n\nasync function buildFinalLambda(\n { compiler, log }: { compiler: WhookCompilerService; log: LogService },\n lambdaPath: string,\n whookConfig: WhookAPIOperationGCPFunctionConfig,\n): Promise<void> {\n const entryPoint = `${lambdaPath}/main.js`;\n const { contents, mappings } = await compiler(\n entryPoint,\n whookConfig.compilerOptions,\n );\n\n await Promise.all([\n ensureFileAsync({ log }, `${lambdaPath}/index.js`, contents, 'utf-8'),\n mappings\n ? ensureFileAsync(\n { log },\n `${lambdaPath}/index.js.map`,\n mappings,\n 'utf-8',\n )\n : Promise.resolve(),\n ]);\n}\n\nasync function copyStaticFiles(\n { PROJECT_DIR, log }: { PROJECT_DIR: string; log: LogService },\n lambdaPath: string,\n staticFiles: string[] = [],\n): Promise<void> {\n await Promise.all(\n staticFiles.map(\n async (staticFile) =>\n await copyFiles(\n { log },\n path.join(PROJECT_DIR, 'node_modules', staticFile),\n path.join(lambdaPath, 'node_modules', staticFile),\n ),\n ),\n );\n}\n\nasync function copyFiles(\n { log }: { log: LogService },\n source: string,\n destination: string,\n): Promise<void> {\n let theError;\n try {\n await mkdirp(destination);\n const data = await readFileAsync(source, 'utf-8');\n await ensureFileAsync({ log }, destination, data, 'utf-8');\n } catch (err) {\n theError = err;\n }\n if (theError) {\n if ('EISDIR' !== theError.code) {\n throw theError;\n }\n await cprAsync(source, destination, {\n overwrite: true,\n });\n }\n}\n\nasync function ensureFileAsync(\n { log }: { log: LogService },\n path: string,\n content: string,\n encoding = 'utf-8',\n): Promise<void> {\n try {\n const oldContent = await readFileAsync(path, encoding);\n\n if (oldContent === content) {\n log('debug', `Ignore unchanged file: \"${path}\".`);\n return;\n }\n } catch (err) {\n log('debug', `Write new file: \"${path}\".`);\n return await writeFileAsync(path, content, encoding);\n }\n log('debug', `Write changed file: \"${path}\".`);\n return await writeFileAsync(path, content, encoding);\n}\n"],"file":"index.mjs"}
|
package/dist/libs/utils.mjs
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import YError from 'yerror';
|
|
2
|
-
import path from 'path';
|
|
3
|
-
export async function loadLambda({
|
|
4
|
-
PROJECT_DIR,
|
|
5
|
-
log
|
|
6
|
-
}, target, operationId, type) {
|
|
7
|
-
const modulePath = path.join(PROJECT_DIR, 'builds', target, operationId, type);
|
|
8
|
-
log('debug', `⛏️ - Loading lambda module at path "${modulePath}".`);
|
|
9
|
-
|
|
10
|
-
try {
|
|
11
|
-
// eslint-disable-next-line
|
|
12
|
-
const module = require(modulePath);
|
|
13
|
-
|
|
14
|
-
if (!module) {
|
|
15
|
-
throw new YError('E_MODULE_NOT_FOUND', module);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
if (!module.default) {
|
|
19
|
-
throw new YError('E_LAMBDA_NOT_FOUND', module, Object.keys(module));
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
return module.default;
|
|
23
|
-
} catch (err) {
|
|
24
|
-
throw YError.wrap(err, 'E_LAMBDA_LOAD');
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=utils.mjs.map
|
package/dist/libs/utils.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/libs/utils.ts"],"names":["YError","path","loadLambda","PROJECT_DIR","log","target","operationId","type","modulePath","join","module","require","default","Object","keys","err","wrap"],"mappings":"AAAA,OAAOA,MAAP,MAAmB,QAAnB;AACA,OAAOC,IAAP,MAAiB,MAAjB;AAGA,OAAO,eAAeC,UAAf,CACL;AACEC,EAAAA,WADF;AAEEC,EAAAA;AAFF,CADK,EAQLC,MARK,EASLC,WATK,EAULC,IAVK,EAWS;AACd,QAAMC,UAAU,GAAGP,IAAI,CAACQ,IAAL,CACjBN,WADiB,EAEjB,QAFiB,EAGjBE,MAHiB,EAIjBC,WAJiB,EAKjBC,IALiB,CAAnB;AAQAH,EAAAA,GAAG,CAAC,OAAD,EAAW,uCAAsCI,UAAW,IAA5D,CAAH;;AAEA,MAAI;AACF;AACA,UAAME,MAAM,GAAGC,OAAO,CAACH,UAAD,CAAtB;;AAEA,QAAI,CAACE,MAAL,EAAa;AACX,YAAM,IAAIV,MAAJ,CAAW,oBAAX,EAAiCU,MAAjC,CAAN;AACD;;AAED,QAAI,CAACA,MAAM,CAACE,OAAZ,EAAqB;AACnB,YAAM,IAAIZ,MAAJ,CAAW,oBAAX,EAAiCU,MAAjC,EAAyCG,MAAM,CAACC,IAAP,CAAYJ,MAAZ,CAAzC,CAAN;AACD;;AAED,WAAOA,MAAM,CAACE,OAAd;AACD,GAbD,CAaE,OAAOG,GAAP,EAAY;AACZ,UAAMf,MAAM,CAACgB,IAAP,CAAYD,GAAZ,EAAiB,eAAjB,CAAN;AACD;AACF","sourcesContent":["import YError from 'yerror';\nimport path from 'path';\nimport type { LogService } from 'common-services';\n\nexport async function loadLambda(\n {\n PROJECT_DIR,\n log,\n }: {\n PROJECT_DIR: string;\n log: LogService;\n },\n target: string,\n operationId: string,\n type: string,\n): Promise<any> {\n const modulePath = path.join(\n PROJECT_DIR,\n 'builds',\n target,\n operationId,\n type,\n );\n\n log('debug', `⛏️ - Loading lambda module at path \"${modulePath}\".`);\n\n try {\n // eslint-disable-next-line\n const module = require(modulePath);\n\n if (!module) {\n throw new YError('E_MODULE_NOT_FOUND', module);\n }\n\n if (!module.default) {\n throw new YError('E_LAMBDA_NOT_FOUND', module, Object.keys(module));\n }\n\n return module.default;\n } catch (err) {\n throw YError.wrap(err, 'E_LAMBDA_LOAD');\n }\n}\n"],"file":"utils.mjs"}
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
2
|
-
|
|
3
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
4
|
-
|
|
5
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
6
|
-
|
|
7
|
-
import { initAutoload, noop, cleanupOpenAPI } from '@whook/whook';
|
|
8
|
-
import { SPECIAL_PROPS, wrapInitializer, constant, alsoInject } from 'knifecycle';
|
|
9
|
-
import YError from 'yerror';
|
|
10
|
-
import { dereferenceOpenAPIOperations, getOpenAPIOperations } from '@whook/http-router';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Wrap the _autoload service in order to build AWS
|
|
14
|
-
* Lambda compatible code.
|
|
15
|
-
* @param {Object} services
|
|
16
|
-
* The services ENV depends on
|
|
17
|
-
* @param {Object} services.NODE_ENV
|
|
18
|
-
* The injected NODE_ENV value to add it to the build env
|
|
19
|
-
* @param {Object} [services.PROXYED_ENV_VARS={}]
|
|
20
|
-
* A list of environment variable names to proxy
|
|
21
|
-
* @param {Object} [services.log=noop]
|
|
22
|
-
* An optional logging service
|
|
23
|
-
* @return {Promise<Object>}
|
|
24
|
-
* A promise of an object containing the reshaped env vars.
|
|
25
|
-
*/
|
|
26
|
-
export default alsoInject(['?BUILD_CONSTANTS', '$instance', '$injector', '?log'], wrapInitializer(async ({
|
|
27
|
-
BUILD_CONSTANTS = {},
|
|
28
|
-
$injector,
|
|
29
|
-
$instance,
|
|
30
|
-
log = noop
|
|
31
|
-
}, $autoload) => {
|
|
32
|
-
let API;
|
|
33
|
-
let OPERATION_APIS;
|
|
34
|
-
|
|
35
|
-
const getAPIOperation = (() => {
|
|
36
|
-
return async serviceName => {
|
|
37
|
-
// eslint-disable-next-line
|
|
38
|
-
API = API || (await $injector(['API'])).API; // eslint-disable-next-line
|
|
39
|
-
|
|
40
|
-
OPERATION_APIS = OPERATION_APIS || getOpenAPIOperations(API);
|
|
41
|
-
const OPERATION = OPERATION_APIS.find(operation => serviceName === ((operation['x-whook'] || {}).sourceOperationId && 'OPERATION_API_' + (operation['x-whook'] || {}).sourceOperationId || 'OPERATION_API_' + operation.operationId) + ((operation['x-whook'] || {}).suffix || ''));
|
|
42
|
-
|
|
43
|
-
if (!OPERATION) {
|
|
44
|
-
log('error', '💥 - Unable to find a lambda operation definition!');
|
|
45
|
-
throw new YError('E_OPERATION_NOT_FOUND', serviceName);
|
|
46
|
-
} // eslint-disable-next-line
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
const OPERATION_API = cleanupOpenAPI(_objectSpread(_objectSpread({}, API), {}, {
|
|
50
|
-
paths: {
|
|
51
|
-
[OPERATION.path]: {
|
|
52
|
-
[OPERATION.method]: API.paths[OPERATION.path][OPERATION.method]
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}));
|
|
56
|
-
return _objectSpread(_objectSpread({}, OPERATION_API), {}, {
|
|
57
|
-
paths: {
|
|
58
|
-
[OPERATION.path]: {
|
|
59
|
-
[OPERATION.method]: (await dereferenceOpenAPIOperations(OPERATION_API, [_objectSpread(_objectSpread({
|
|
60
|
-
path: OPERATION.path,
|
|
61
|
-
method: OPERATION.method
|
|
62
|
-
}, OPERATION_API.paths[OPERATION.path][OPERATION.method]), {}, {
|
|
63
|
-
parameters: OPERATION.parameters
|
|
64
|
-
})]))[0]
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
};
|
|
69
|
-
})();
|
|
70
|
-
|
|
71
|
-
log('debug', '🤖 - Initializing the `$autoload` build wrapper.');
|
|
72
|
-
return async serviceName => {
|
|
73
|
-
try {
|
|
74
|
-
// TODO: add initializer map to knifecycle public API
|
|
75
|
-
const initializer = $instance._initializers.get(serviceName);
|
|
76
|
-
|
|
77
|
-
if (initializer && initializer[SPECIAL_PROPS.TYPE] === 'constant') {
|
|
78
|
-
log('debug', `🤖 - Reusing a constant initializer directly from the Knifecycle instance: "${serviceName}".`);
|
|
79
|
-
return {
|
|
80
|
-
initializer,
|
|
81
|
-
path: `instance://${serviceName}`
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
if (serviceName.startsWith('OPERATION_API_')) {
|
|
86
|
-
const OPERATION_API = await getAPIOperation(serviceName);
|
|
87
|
-
return {
|
|
88
|
-
initializer: constant(serviceName, OPERATION_API),
|
|
89
|
-
path: `api://${serviceName}`
|
|
90
|
-
};
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (BUILD_CONSTANTS[serviceName]) {
|
|
94
|
-
return {
|
|
95
|
-
initializer: constant(serviceName, BUILD_CONSTANTS[serviceName]),
|
|
96
|
-
path: `constant://${serviceName}`
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return $autoload(serviceName);
|
|
101
|
-
} catch (err) {
|
|
102
|
-
log('error', `Build error while loading "${serviceName}".`);
|
|
103
|
-
log('stack', err.stack);
|
|
104
|
-
}
|
|
105
|
-
};
|
|
106
|
-
}, initAutoload));
|
|
107
|
-
//# sourceMappingURL=_autoload.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/_autoload.ts"],"names":["initAutoload","noop","cleanupOpenAPI","SPECIAL_PROPS","wrapInitializer","constant","alsoInject","YError","dereferenceOpenAPIOperations","getOpenAPIOperations","BUILD_CONSTANTS","$injector","$instance","log","$autoload","API","OPERATION_APIS","getAPIOperation","serviceName","OPERATION","find","operation","sourceOperationId","operationId","suffix","OPERATION_API","paths","path","method","parameters","initializer","_initializers","get","TYPE","startsWith","err","stack"],"mappings":"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","sourcesContent":["import { initAutoload, noop, cleanupOpenAPI } from '@whook/whook';\nimport Knifecycle, {\n SPECIAL_PROPS,\n wrapInitializer,\n constant,\n alsoInject,\n} from 'knifecycle';\nimport YError from 'yerror';\nimport {\n dereferenceOpenAPIOperations,\n getOpenAPIOperations,\n} from '@whook/http-router';\nimport type {\n Injector,\n Autoloader,\n Initializer,\n Dependencies,\n Service,\n} from 'knifecycle';\nimport type { WhookBuildConstantsService } from '@whook/whook';\nimport type { WhookRawOperation } from '@whook/http-router';\nimport type { LogService } from 'common-services';\nimport type { OpenAPIV3 } from 'openapi-types';\nimport type { WhookAPIOperationGCPFunctionConfig } from '..';\n\n/**\n * Wrap the _autoload service in order to build AWS\n * Lambda compatible code.\n * @param {Object} services\n * The services ENV depends on\n * @param {Object} services.NODE_ENV\n * The injected NODE_ENV value to add it to the build env\n * @param {Object} [services.PROXYED_ENV_VARS={}]\n * A list of environment variable names to proxy\n * @param {Object} [services.log=noop]\n * An optional logging service\n * @return {Promise<Object>}\n * A promise of an object containing the reshaped env vars.\n */\nexport default alsoInject(\n ['?BUILD_CONSTANTS', '$instance', '$injector', '?log'],\n wrapInitializer(\n async (\n {\n BUILD_CONSTANTS = {},\n $injector,\n $instance,\n log = noop,\n }: {\n BUILD_CONSTANTS?: WhookBuildConstantsService;\n $injector: Injector<Service>;\n $instance: Knifecycle<Dependencies>;\n log: LogService;\n },\n $autoload: Autoloader,\n ): Promise<\n (serviceName: string) => Promise<{\n initializer: Initializer<Dependencies, Service>;\n path: string;\n }>\n > => {\n let API: OpenAPIV3.Document;\n let OPERATION_APIS: WhookRawOperation<WhookAPIOperationGCPFunctionConfig>[];\n const getAPIOperation = (() => {\n return async (serviceName) => {\n // eslint-disable-next-line\n API = API || (await $injector(['API'])).API;\n // eslint-disable-next-line\n OPERATION_APIS =\n OPERATION_APIS ||\n getOpenAPIOperations<WhookAPIOperationGCPFunctionConfig>(API);\n\n const OPERATION = OPERATION_APIS.find(\n (operation) =>\n serviceName ===\n (((operation['x-whook'] || {}).sourceOperationId &&\n 'OPERATION_API_' +\n (operation['x-whook'] || {}).sourceOperationId) ||\n 'OPERATION_API_' + operation.operationId) +\n ((operation['x-whook'] || {}).suffix || ''),\n );\n\n if (!OPERATION) {\n log('error', '💥 - Unable to find a lambda operation definition!');\n throw new YError('E_OPERATION_NOT_FOUND', serviceName);\n }\n\n // eslint-disable-next-line\n const OPERATION_API = cleanupOpenAPI({\n ...API,\n paths: {\n [OPERATION.path]: {\n [OPERATION.method]: API.paths[OPERATION.path][OPERATION.method],\n },\n },\n });\n\n return {\n ...OPERATION_API,\n paths: {\n [OPERATION.path]: {\n [OPERATION.method]: (\n await dereferenceOpenAPIOperations(OPERATION_API, [\n {\n path: OPERATION.path,\n method: OPERATION.method,\n ...OPERATION_API.paths[OPERATION.path][OPERATION.method],\n parameters: OPERATION.parameters,\n },\n ])\n )[0],\n },\n },\n };\n };\n })();\n\n log('debug', '🤖 - Initializing the `$autoload` build wrapper.');\n\n return async (serviceName) => {\n try {\n // TODO: add initializer map to knifecycle public API\n const initializer = ($instance as any)._initializers.get(serviceName);\n\n if (initializer && initializer[SPECIAL_PROPS.TYPE] === 'constant') {\n log(\n 'debug',\n `🤖 - Reusing a constant initializer directly from the Knifecycle instance: \"${serviceName}\".`,\n );\n return {\n initializer,\n path: `instance://${serviceName}`,\n };\n }\n\n if (serviceName.startsWith('OPERATION_API_')) {\n const OPERATION_API = await getAPIOperation(serviceName);\n\n return {\n initializer: constant(serviceName, OPERATION_API),\n path: `api://${serviceName}`,\n };\n }\n\n if (BUILD_CONSTANTS[serviceName]) {\n return {\n initializer: constant(serviceName, BUILD_CONSTANTS[serviceName]),\n path: `constant://${serviceName}`,\n };\n }\n\n return $autoload(serviceName);\n } catch (err) {\n log('error', `Build error while loading \"${serviceName}\".`);\n log('stack', err.stack);\n }\n };\n },\n initAutoload,\n ),\n);\n"],"file":"_autoload.mjs"}
|
package/dist/services/log.mjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/log.ts"],"names":["service","console","log","bind"],"mappings":"AAAA,SAASA,OAAT,QAAwB,YAAxB,C,CAEA;;AACA,eAAeA,OAAO,CAAC,YAAYC,OAAO,CAACC,GAAR,CAAYC,IAAZ,CAAiBF,OAAjB,CAAb,EAAwC,KAAxC,CAAtB","sourcesContent":["import { service } from 'knifecycle';\n\n// eslint-disable-next-line\nexport default service(async () => console.log.bind(console), 'log');\n"],"file":"log.mjs"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/log.test.ts"],"names":["initLogService","describe","it"],"mappings":"AAAA,OAAOA,cAAP,MAA2B,OAA3B;AAEAC,QAAQ,CAAC,gBAAD,EAAmB,MAAM;AAC/BC,EAAAA,EAAE,CAAC,aAAD,EAAgB,YAAY;AAC5B,UAAMF,cAAc,EAApB;AACD,GAFC,CAAF;AAGD,CAJO,CAAR","sourcesContent":["import initLogService from './log';\n\ndescribe('initLogService', () => {\n it('should work', async () => {\n await initLogService();\n });\n});\n"],"file":"log.test.mjs"}
|