vovk-cli 0.0.1-draft.32 → 0.0.1-draft.322
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/LICENSE +1 -1
- package/README.md +29 -1
- package/client-templates/cjs/index.cjs.ejs +19 -0
- package/client-templates/cjs/index.d.cts.ejs +25 -0
- package/client-templates/mixins/mixins.d.ts.ejs +64 -0
- package/client-templates/mixins/mixins.json.ejs +1 -0
- package/client-templates/mjs/index.d.mts.ejs +25 -0
- package/client-templates/mjs/index.mjs.ejs +23 -0
- package/client-templates/packageJson/package.json.ejs +1 -0
- package/client-templates/readme/README.md.ejs +38 -0
- package/client-templates/schemaCjs/schema.cjs.ejs +26 -0
- package/client-templates/schemaCjs/schema.d.cts.ejs +10 -0
- package/client-templates/schemaJson/schema.json.ejs +1 -0
- package/client-templates/schemaTs/schema.ts.ejs +35 -0
- package/client-templates/ts/index.ts.ejs +33 -0
- package/dist/bundle/index.d.mts +8 -0
- package/dist/bundle/index.mjs +88 -0
- package/dist/dev/diffSegmentSchema.d.mts +36 -0
- package/dist/dev/{diffSchema.mjs → diffSegmentSchema.mjs} +3 -11
- package/dist/dev/ensureSchemaFiles.d.mts +3 -0
- package/dist/dev/ensureSchemaFiles.mjs +15 -31
- package/dist/dev/index.d.mts +5 -1
- package/dist/dev/index.mjs +181 -78
- package/dist/dev/logDiffResult.d.mts +1 -1
- package/dist/dev/logDiffResult.mjs +6 -43
- package/dist/dev/writeMetaJson.d.mts +2 -0
- package/dist/dev/writeMetaJson.mjs +17 -0
- package/dist/dev/writeOneSegmentSchemaFile.d.mts +12 -0
- package/dist/dev/{writeOneSchemaFile.mjs → writeOneSegmentSchemaFile.mjs} +10 -6
- package/dist/generate/ensureClient.d.mts +3 -0
- package/dist/generate/ensureClient.mjs +32 -0
- package/dist/generate/generate.d.mts +16 -0
- package/dist/generate/generate.mjs +293 -0
- package/dist/generate/getClientTemplateFiles.d.mts +20 -0
- package/dist/generate/getClientTemplateFiles.mjs +94 -0
- package/dist/generate/getProjectFullSchema.d.mts +7 -0
- package/dist/generate/getProjectFullSchema.mjs +65 -0
- package/dist/generate/getTemplateClientImports.d.mts +18 -0
- package/dist/generate/getTemplateClientImports.mjs +38 -0
- package/dist/generate/index.d.mts +33 -0
- package/dist/generate/index.mjs +189 -0
- package/dist/generate/mergePackages.d.mts +7 -0
- package/dist/generate/mergePackages.mjs +55 -0
- package/dist/generate/writeOneClientFile.d.mts +36 -0
- package/dist/generate/writeOneClientFile.mjs +123 -0
- package/dist/getProjectInfo/getConfig/getConfigAbsolutePaths.d.mts +5 -0
- package/dist/getProjectInfo/{getConfigAbsolutePaths.mjs → getConfig/getConfigAbsolutePaths.mjs} +4 -1
- package/dist/getProjectInfo/{getRelativeSrcRoot.d.mts → getConfig/getRelativeSrcRoot.d.mts} +1 -1
- package/dist/getProjectInfo/{getRelativeSrcRoot.mjs → getConfig/getRelativeSrcRoot.mjs} +2 -2
- package/dist/getProjectInfo/getConfig/getTemplateDefs.d.mts +22 -0
- package/dist/getProjectInfo/getConfig/getTemplateDefs.mjs +145 -0
- package/dist/getProjectInfo/{getUserConfig.d.mts → getConfig/getUserConfig.d.mts} +3 -2
- package/dist/getProjectInfo/{getUserConfig.mjs → getConfig/getUserConfig.mjs} +6 -4
- package/dist/getProjectInfo/{importUncachedModule.mjs → getConfig/importUncachedModule.mjs} +1 -4
- package/dist/getProjectInfo/getConfig/index.d.mts +120 -0
- package/dist/getProjectInfo/getConfig/index.mjs +97 -0
- package/dist/getProjectInfo/index.d.mts +12 -9
- package/dist/getProjectInfo/index.mjs +21 -22
- package/dist/index.d.mts +2 -2
- package/dist/index.mjs +101 -36
- package/dist/init/createConfig.d.mts +2 -2
- package/dist/init/createConfig.mjs +14 -12
- package/dist/init/getTemplateFilesFromPackage.mjs +10 -5
- package/dist/init/index.d.mts +2 -2
- package/dist/init/index.mjs +81 -60
- package/dist/init/installDependencies.mjs +4 -2
- package/dist/init/logUpdateDependenciesError.d.mts +3 -1
- package/dist/init/logUpdateDependenciesError.mjs +7 -1
- package/dist/init/updateDependenciesWithoutInstalling.mjs +39 -9
- package/dist/init/updateNPMScripts.d.mts +3 -1
- package/dist/init/updateNPMScripts.mjs +9 -7
- package/dist/init/updateTypeScriptConfig.d.mts +4 -1
- package/dist/init/updateTypeScriptConfig.mjs +11 -7
- package/dist/initProgram.d.mts +1 -1
- package/dist/initProgram.mjs +16 -16
- package/dist/locateSegments.d.mts +8 -1
- package/dist/locateSegments.mjs +14 -4
- package/dist/new/addClassToSegmentCode.d.mts +1 -2
- package/dist/new/addClassToSegmentCode.mjs +3 -3
- package/dist/new/index.d.mts +1 -1
- package/dist/new/index.mjs +3 -2
- package/dist/new/newModule.d.mts +2 -1
- package/dist/new/newModule.mjs +18 -16
- package/dist/new/newSegment.d.mts +2 -1
- package/dist/new/newSegment.mjs +19 -10
- package/dist/new/render.d.mts +7 -3
- package/dist/new/render.mjs +29 -8
- package/dist/types.d.mts +51 -40
- package/dist/utils/compileJSONSchemaToTypeScriptType.d.mts +5 -0
- package/dist/utils/compileJSONSchemaToTypeScriptType.mjs +9 -0
- package/dist/utils/compileTs.d.mts +12 -0
- package/dist/utils/compileTs.mjs +261 -0
- package/dist/utils/debounceWithArgs.d.mts +2 -2
- package/dist/utils/debounceWithArgs.mjs +24 -6
- package/dist/utils/formatLoggedSegmentName.d.mts +3 -1
- package/dist/utils/formatLoggedSegmentName.mjs +3 -2
- package/dist/utils/getPackageJson.d.mts +3 -0
- package/dist/utils/getPackageJson.mjs +22 -0
- package/dist/utils/getPublicModuleNameFromPath.d.mts +4 -0
- package/dist/utils/getPublicModuleNameFromPath.mjs +9 -0
- package/dist/utils/normalizeOpenAPIMixins.d.mts +7 -0
- package/dist/utils/normalizeOpenAPIMixins.mjs +67 -0
- package/dist/utils/pickSegmentFullSchema.d.mts +3 -0
- package/dist/utils/pickSegmentFullSchema.mjs +15 -0
- package/dist/utils/removeUnlistedDirectories.d.mts +10 -0
- package/dist/utils/removeUnlistedDirectories.mjs +61 -0
- package/dist/utils/resolveAbsoluteModulePath.d.mts +2 -0
- package/dist/utils/resolveAbsoluteModulePath.mjs +32 -0
- package/module-templates/controller.ts.ejs +56 -0
- package/module-templates/service.ts.ejs +28 -0
- package/package.json +36 -22
- package/dist/dev/diffSchema.d.mts +0 -43
- package/dist/dev/ensureClient.d.mts +0 -5
- package/dist/dev/ensureClient.mjs +0 -31
- package/dist/dev/isMetadataEmpty.d.mts +0 -2
- package/dist/dev/isMetadataEmpty.mjs +0 -4
- package/dist/dev/writeOneSchemaFile.d.mts +0 -11
- package/dist/generateClient.d.mts +0 -7
- package/dist/generateClient.mjs +0 -97
- package/dist/getProjectInfo/getConfig.d.mts +0 -11
- package/dist/getProjectInfo/getConfig.mjs +0 -29
- package/dist/getProjectInfo/getConfigAbsolutePaths.d.mts +0 -4
- package/dist/postinstall.d.mts +0 -1
- package/dist/postinstall.mjs +0 -24
- package/templates/controller.ejs +0 -51
- package/templates/service.ejs +0 -27
- package/templates/worker.ejs +0 -24
- /package/dist/getProjectInfo/{importUncachedModule.d.mts → getConfig/importUncachedModule.d.mts} +0 -0
- /package/dist/getProjectInfo/{importUncachedModuleWorker.d.mts → getConfig/importUncachedModuleWorker.d.mts} +0 -0
- /package/dist/getProjectInfo/{importUncachedModuleWorker.mjs → getConfig/importUncachedModuleWorker.mjs} +0 -0
package/dist/generateClient.mjs
DELETED
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import fs from 'node:fs/promises';
|
|
3
|
-
import formatLoggedSegmentName from './utils/formatLoggedSegmentName.mjs';
|
|
4
|
-
import prettify from './utils/prettify.mjs';
|
|
5
|
-
export default async function generateClient(projectInfo, segments, segmentsSchema) {
|
|
6
|
-
const { config, cwd, log, validateOnClientImportPath, apiEntryPoint, fetcherClientImportPath, schemaOutImportPath } = projectInfo;
|
|
7
|
-
const now = Date.now();
|
|
8
|
-
const clientoOutDirAbsolutePath = path.join(cwd, config.clientOutDir);
|
|
9
|
-
let dts = `// auto-generated
|
|
10
|
-
/* eslint-disable */
|
|
11
|
-
import type { clientizeController } from 'vovk/client';
|
|
12
|
-
import type { promisifyWorker } from 'vovk/worker';
|
|
13
|
-
import type { VovkClientFetcher } from 'vovk/client';
|
|
14
|
-
import type fetcher from '${fetcherClientImportPath}';
|
|
15
|
-
|
|
16
|
-
`;
|
|
17
|
-
let js = `// auto-generated
|
|
18
|
-
/* eslint-disable */
|
|
19
|
-
const { clientizeController } = require('vovk/client');
|
|
20
|
-
const { promisifyWorker } = require('vovk/worker');
|
|
21
|
-
const { default: fetcher } = require('${fetcherClientImportPath}');
|
|
22
|
-
const schema = require('${schemaOutImportPath}');
|
|
23
|
-
`;
|
|
24
|
-
let ts = `// auto-generated
|
|
25
|
-
/* eslint-disable */
|
|
26
|
-
import { clientizeController } from 'vovk/client';
|
|
27
|
-
import { promisifyWorker } from 'vovk/worker';
|
|
28
|
-
import type { VovkClientFetcher } from 'vovk/client';
|
|
29
|
-
import fetcher from '${fetcherClientImportPath}';
|
|
30
|
-
import schema from '${schemaOutImportPath}';
|
|
31
|
-
|
|
32
|
-
`;
|
|
33
|
-
for (let i = 0; i < segments.length; i++) {
|
|
34
|
-
const { routeFilePath, segmentName } = segments[i];
|
|
35
|
-
const schema = segmentsSchema[segmentName];
|
|
36
|
-
if (!schema) {
|
|
37
|
-
throw new Error(`Unable to generate client. No schema found for ${formatLoggedSegmentName(segmentName)}`);
|
|
38
|
-
}
|
|
39
|
-
if (!schema.emitSchema)
|
|
40
|
-
continue;
|
|
41
|
-
const importRouteFilePath = path.relative(config.clientOutDir, routeFilePath);
|
|
42
|
-
dts += `import type { Controllers as Controllers${i}, Workers as Workers${i} } from "${importRouteFilePath}";\n`;
|
|
43
|
-
ts += `import type { Controllers as Controllers${i}, Workers as Workers${i} } from "${importRouteFilePath}";\n`;
|
|
44
|
-
}
|
|
45
|
-
dts += `
|
|
46
|
-
type Options = typeof fetcher extends VovkClientFetcher<infer U> ? U : never;
|
|
47
|
-
`;
|
|
48
|
-
ts += `
|
|
49
|
-
${validateOnClientImportPath ? `import validateOnClient from '${validateOnClientImportPath}';\n` : '\nconst validateOnClient = undefined;'}
|
|
50
|
-
type Options = typeof fetcher extends VovkClientFetcher<infer U> ? U : never;
|
|
51
|
-
const apiRoot = '${apiEntryPoint}';
|
|
52
|
-
`;
|
|
53
|
-
js += `
|
|
54
|
-
const { default: validateOnClient = null } = ${validateOnClientImportPath ? `require('${validateOnClientImportPath}')` : '{}'};
|
|
55
|
-
const apiRoot = '${apiEntryPoint}';
|
|
56
|
-
`;
|
|
57
|
-
for (let i = 0; i < segments.length; i++) {
|
|
58
|
-
const { segmentName } = segments[i];
|
|
59
|
-
const schema = segmentsSchema[segmentName];
|
|
60
|
-
if (!schema) {
|
|
61
|
-
throw new Error(`Unable to generate client. No schema found for ${formatLoggedSegmentName(segmentName)}`);
|
|
62
|
-
}
|
|
63
|
-
if (!schema.emitSchema)
|
|
64
|
-
continue;
|
|
65
|
-
for (const key of Object.keys(schema.controllers)) {
|
|
66
|
-
dts += `export const ${key}: ReturnType<typeof clientizeController<Controllers${i}["${key}"], Options>>;\n`;
|
|
67
|
-
js += `exports.${key} = clientizeController(schema['${segmentName}'].controllers.${key}, '${segmentName}', { fetcher, validateOnClient, defaultOptions: { apiRoot } });\n`;
|
|
68
|
-
ts += `export const ${key} = clientizeController<Controllers${i}["${key}"], Options>(schema['${segmentName}'].controllers.${key}, '${segmentName}', { fetcher, validateOnClient, defaultOptions: { apiRoot } });\n`;
|
|
69
|
-
}
|
|
70
|
-
for (const key of Object.keys(schema.workers)) {
|
|
71
|
-
dts += `export const ${key}: ReturnType<typeof promisifyWorker<Workers${i}["${key}"]>>;\n`;
|
|
72
|
-
js += `exports.${key} = promisifyWorker(null, schema['${segmentName}'].workers.${key});\n`;
|
|
73
|
-
ts += `export const ${key} = promisifyWorker<Workers${i}["${key}"]>(null, schema['${segmentName}'].workers.${key});\n`;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
const localJsAbsolutePath = path.join(clientoOutDirAbsolutePath, 'client.js');
|
|
77
|
-
const localDtsAbsolutePath = path.join(clientoOutDirAbsolutePath, 'client.d.ts');
|
|
78
|
-
const localTsAbsolutePath = path.join(clientoOutDirAbsolutePath, 'index.ts');
|
|
79
|
-
const existingJs = await fs.readFile(localJsAbsolutePath, 'utf-8').catch(() => '');
|
|
80
|
-
const existingDts = await fs.readFile(localDtsAbsolutePath, 'utf-8').catch(() => '');
|
|
81
|
-
const existingTs = await fs.readFile(localTsAbsolutePath, 'utf-8').catch(() => '');
|
|
82
|
-
if (config.prettifyClient) {
|
|
83
|
-
js = await prettify(js, localJsAbsolutePath);
|
|
84
|
-
dts = await prettify(dts, localDtsAbsolutePath);
|
|
85
|
-
ts = await prettify(ts, localTsAbsolutePath);
|
|
86
|
-
}
|
|
87
|
-
if (existingJs === js && existingDts === dts && existingTs === ts) {
|
|
88
|
-
log.debug(`Client is up to date and doesn't need to be regenerated (${Date.now() - now}ms)`);
|
|
89
|
-
return { written: false, path: clientoOutDirAbsolutePath };
|
|
90
|
-
}
|
|
91
|
-
await fs.mkdir(clientoOutDirAbsolutePath, { recursive: true });
|
|
92
|
-
await fs.writeFile(localJsAbsolutePath, js);
|
|
93
|
-
await fs.writeFile(localDtsAbsolutePath, dts);
|
|
94
|
-
await fs.writeFile(localTsAbsolutePath, ts);
|
|
95
|
-
log.info(`Client generated in ${Date.now() - now}ms`);
|
|
96
|
-
return { written: true, path: clientoOutDirAbsolutePath };
|
|
97
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type { VovkConfig } from '../types.mjs';
|
|
2
|
-
export default function getConfig({ clientOutDir, cwd }: {
|
|
3
|
-
clientOutDir?: string;
|
|
4
|
-
cwd: string;
|
|
5
|
-
}): Promise<{
|
|
6
|
-
config: Required<VovkConfig>;
|
|
7
|
-
srcRoot: string;
|
|
8
|
-
configAbsolutePaths: string[];
|
|
9
|
-
userConfig: VovkConfig | null;
|
|
10
|
-
error: Error | undefined;
|
|
11
|
-
}>;
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import getUserConfig from './getUserConfig.mjs';
|
|
2
|
-
import getRelativeSrcRoot from './getRelativeSrcRoot.mjs';
|
|
3
|
-
export default async function getConfig({ clientOutDir, cwd }) {
|
|
4
|
-
const env = process.env;
|
|
5
|
-
const { configAbsolutePaths, error, userConfig } = await getUserConfig({ cwd });
|
|
6
|
-
const conf = userConfig ?? {};
|
|
7
|
-
const srcRoot = await getRelativeSrcRoot({ cwd });
|
|
8
|
-
const config = {
|
|
9
|
-
modulesDir: env.VOVK_MODULES_DIR ?? conf.modulesDir ?? './' + [srcRoot, 'modules'].filter(Boolean).join('/'),
|
|
10
|
-
validateOnClient: env.VOVK_VALIDATE_ON_CLIENT ?? conf.validateOnClient ?? null,
|
|
11
|
-
validationLibrary: env.VOVK_VALIDATION_LIBRARY ?? conf.validationLibrary ?? null,
|
|
12
|
-
fetcher: env.VOVK_FETCHER ?? conf.fetcher ?? 'vovk/client/defaultFetcher',
|
|
13
|
-
schemaOutDir: env.VOVK_SCHEMA_OUT_DIR ?? conf.schemaOutDir ?? './.vovk-schema',
|
|
14
|
-
clientOutDir: clientOutDir ?? env.VOVK_CLIENT_OUT_DIR ?? conf.clientOutDir ?? './node_modules/.vovk-client',
|
|
15
|
-
origin: (env.VOVK_ORIGIN ?? conf.origin ?? '').replace(/\/$/, ''), // Remove trailing slash
|
|
16
|
-
rootEntry: env.VOVK_ROOT_ENTRY ?? conf.rootEntry ?? 'api',
|
|
17
|
-
rootSegmentModulesDirName: env.VOVK_ROOT_SEGMENT_MODULES_DIR_NAME ?? conf.rootSegmentModulesDirName ?? '',
|
|
18
|
-
logLevel: env.VOVK_LOG_LEVEL ?? conf.logLevel ?? 'warn',
|
|
19
|
-
prettifyClient: (env.VOVK_PRETTIFY_CLIENT ? !!env.VOVK_PRETTIFY_CLIENT : null) ?? conf.prettifyClient ?? false,
|
|
20
|
-
devHttps: (env.VOVK_DEV_HTTPS ? !!env.VOVK_DEV_HTTPS : null) ?? conf.devHttps ?? false,
|
|
21
|
-
templates: {
|
|
22
|
-
service: 'vovk-cli/templates/service.ejs',
|
|
23
|
-
controller: 'vovk-cli/templates/controller.ejs',
|
|
24
|
-
worker: 'vovk-cli/templates/worker.ejs',
|
|
25
|
-
...conf.templates,
|
|
26
|
-
},
|
|
27
|
-
};
|
|
28
|
-
return { config, srcRoot, configAbsolutePaths, userConfig, error };
|
|
29
|
-
}
|
package/dist/postinstall.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/dist/postinstall.mjs
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs/promises';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
/**
|
|
4
|
-
* Checks if a file exists at the given path.
|
|
5
|
-
* @param {string} filePath - The path to the file.
|
|
6
|
-
* @returns {Promise<boolean>} - A promise that resolves to true if the file exists, false otherwise.
|
|
7
|
-
*/
|
|
8
|
-
const getFileSystemEntryType = async (filePath) => !!(await fs.stat(filePath).catch(() => false));
|
|
9
|
-
async function postinstall() {
|
|
10
|
-
const vovk = path.join(import.meta.dirname, '../../.vovk');
|
|
11
|
-
const js = path.join(vovk, 'client.js');
|
|
12
|
-
const ts = path.join(vovk, 'client.d.ts');
|
|
13
|
-
const index = path.join(vovk, 'index.ts');
|
|
14
|
-
if ((await getFileSystemEntryType(js)) ||
|
|
15
|
-
(await getFileSystemEntryType(ts)) ||
|
|
16
|
-
(await getFileSystemEntryType(index))) {
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
await fs.mkdir(vovk, { recursive: true });
|
|
20
|
-
await fs.writeFile(js, '/* postinstall */');
|
|
21
|
-
await fs.writeFile(ts, '/* postinstall */');
|
|
22
|
-
await fs.writeFile(index, '/* postinstall */');
|
|
23
|
-
}
|
|
24
|
-
void postinstall();
|
package/templates/controller.ejs
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
<% var modulePascalName = _.upperFirst(_.camelCase(moduleName)); %>
|
|
2
|
-
<% var modulePascalNamePlural = pluralize(modulePascalName); %>
|
|
3
|
-
<% var controllerName = modulePascalName + 'Controller'; %>
|
|
4
|
-
<% var compiledName = modulePascalName + 'RPC'; %>
|
|
5
|
-
<% var serviceName = modulePascalName + 'Service'; %>
|
|
6
|
-
---
|
|
7
|
-
dir: <%= getModuleDirName(segmentName, moduleName) %>
|
|
8
|
-
fileName: <%= controllerName + '.ts' %>
|
|
9
|
-
sourceName: <%= controllerName %>
|
|
10
|
-
compiledName: <%= compiledName %>
|
|
11
|
-
---
|
|
12
|
-
|
|
13
|
-
import { prefix, get, put, post, del, type VovkRequest } from 'vovk';
|
|
14
|
-
<% if(withService) { %>
|
|
15
|
-
import <%= serviceName %> from './<%= serviceName %>';
|
|
16
|
-
<% } %>
|
|
17
|
-
|
|
18
|
-
@prefix('<%= _.kebabCase(moduleName).toLowerCase() %>')
|
|
19
|
-
export default class <%= controllerName %> {
|
|
20
|
-
@get()
|
|
21
|
-
static get<%= modulePascalNamePlural %> = async (req: VovkRequest<null, { search: string }>) => {
|
|
22
|
-
const search = req.nextUrl.searchParams.get('search');
|
|
23
|
-
<% if(withService) { %>
|
|
24
|
-
return <%= serviceName %>.get<%= modulePascalNamePlural %>(search);
|
|
25
|
-
<% } else { %>
|
|
26
|
-
return { results: [], search };
|
|
27
|
-
<% } %>
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
@put(':id')
|
|
31
|
-
static update<%= modulePascalName %> = async (req: VovkRequest<{ foo: 'bar' | 'baz' }, { q: string }>, params: { id: string }) => {
|
|
32
|
-
const { id } = params;
|
|
33
|
-
const body = await req.json();
|
|
34
|
-
const q = req.nextUrl.searchParams.get('q');
|
|
35
|
-
<% if(withService) { %>
|
|
36
|
-
return <%= serviceName %>.update<%= modulePascalName %>(id, q, body);
|
|
37
|
-
<% } else { %>
|
|
38
|
-
return { id, body, q };
|
|
39
|
-
<% } %>
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
@post()
|
|
43
|
-
static create<%= modulePascalName %> = () => {
|
|
44
|
-
// ...
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
@del(':id')
|
|
48
|
-
static delete<%= modulePascalName %> = () => {
|
|
49
|
-
// ...
|
|
50
|
-
};
|
|
51
|
-
}
|
package/templates/service.ejs
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
<% var modulePascalName = _.upperFirst(_.camelCase(moduleName)); %>
|
|
2
|
-
<% var modulePascalNamePlural = pluralize(modulePascalName); %>
|
|
3
|
-
<% var serviceName = modulePascalName + 'Service'; %>
|
|
4
|
-
<% var controllerName = modulePascalName + 'Controller'; %>
|
|
5
|
-
---
|
|
6
|
-
dir: <%= getModuleDirName(segmentName, moduleName) %>
|
|
7
|
-
fileName: <%= serviceName + '.ts' %>
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
import type { VovkControllerBody, VovkControllerQuery } from 'vovk';
|
|
11
|
-
import type <%= controllerName %> from './<%= controllerName %>';
|
|
12
|
-
|
|
13
|
-
export default class <%= serviceName %> {
|
|
14
|
-
static get<%= modulePascalNamePlural %> = (search: VovkControllerQuery<typeof <%= controllerName %>.get<%= modulePascalNamePlural %>>['search']) => {
|
|
15
|
-
return { results: [], search };
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
static update<%= modulePascalName %> = (
|
|
19
|
-
id: string,
|
|
20
|
-
q: VovkControllerQuery<typeof <%= controllerName %>.update<%= modulePascalName %>>['q'],
|
|
21
|
-
body: VovkControllerBody<typeof <%= controllerName %>.update<%= modulePascalName %>>
|
|
22
|
-
) => {
|
|
23
|
-
return { id, q, body };
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
// ...
|
|
27
|
-
}
|
package/templates/worker.ejs
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
<% var modulePascalName = _.upperFirst(_.camelCase(moduleName)); %>
|
|
2
|
-
<% var modulePascalNamePlural = pluralize(modulePascalName); %>
|
|
3
|
-
<% var workerName = modulePascalName + 'Worker'; %>
|
|
4
|
-
<% var compiledName = modulePascalName + 'WPC'; %>
|
|
5
|
-
---
|
|
6
|
-
dir: <%= getModuleDirName(segmentName, moduleName) %>
|
|
7
|
-
fileName: <%= workerName + '.ts' %>
|
|
8
|
-
sourceName: <%= workerName %>
|
|
9
|
-
compiledName: <%= compiledName %>
|
|
10
|
-
---
|
|
11
|
-
import { worker } from 'vovk';
|
|
12
|
-
|
|
13
|
-
@worker()
|
|
14
|
-
export default class <%= workerName %> {
|
|
15
|
-
static heavyComputation = () => {
|
|
16
|
-
return 'Hello, World';
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
static heavyComputationGenerator = function* () {
|
|
20
|
-
for(const str of ['Hello', 'World'] as const) {
|
|
21
|
-
yield str;
|
|
22
|
-
}
|
|
23
|
-
};
|
|
24
|
-
}
|
/package/dist/getProjectInfo/{importUncachedModule.d.mts → getConfig/importUncachedModule.d.mts}
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|