-
-
Notifications
You must be signed in to change notification settings - Fork 192
/
Copy pathmodels.ts
124 lines (103 loc) · 3.73 KB
/
models.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
import Command from '../../core/base';
import { load } from '../../core/models/SpecificationFile';
import { formatOutput, parse, ValidateOptions } from '../../core/parser';
import { cancel, intro, isCancel, select, spinner, text } from '@clack/prompts';
import { green, inverse } from 'picocolors';
import { generateModels, Languages, ModelinaArgs } from '@asyncapi/modelina-cli';
import { modelsFlags } from '../../core/flags/generate/models.flags';
export default class Models extends Command {
static description = 'Generates typed models';
static readonly args = ModelinaArgs as any;
static flags = modelsFlags();
async run() {
const { args, flags } = await this.parse(Models);
let { language, file } = args;
let { output } = flags;
const interactive = !flags['no-interactive'];
if (!interactive) {
intro(inverse('AsyncAPI Generate Models'));
const parsedArgs = await this.parseArgs(args, output);
language = parsedArgs.language;
file = parsedArgs.file;
output = parsedArgs.output;
}
const inputFile = (await load(file)) || (await load());
const { document, diagnostics ,status } = await parse(this, inputFile, flags as ValidateOptions);
if (!document || status === 'invalid') {
const severityErrors = diagnostics.filter((obj) => obj.severity === 0);
this.log(`Input is not a correct AsyncAPI document so it cannot be processed.${formatOutput(severityErrors,'stylish','error')}`);
return;
}
const logger = {
info: (message: string) => {
this.log(message);
},
debug: (message: string) => {
this.debug(message);
},
warn: (message: string) => {
this.warn(message);
},
error: (message: string) => {
this.error(message);
},
};
const s = spinner();
s.start('Generating models...');
const generatedModels = await generateModels({...flags, output}, document, logger, language as Languages);
if (output !== 'stdout') {
const generatedModelStrings = generatedModels.map((model) => { return model.modelName; });
s.stop(green(`Successfully generated the following models: ${generatedModelStrings.join(', ')}`));
return;
}
const generatedModelStrings = generatedModels.map((model) => {
return `
## Model name: ${model.modelName}
${model.result}
`;
});
s.stop(green(`Successfully generated the following models: ${generatedModelStrings.join('\n')}`));
}
private async parseArgs(args: Record<string, any>, output?: string) {
let { language, file } = args;
let askForOutput = false;
const operationCancelled = 'Operation cancelled by the user.';
if (!language) {
language = await select({
message: 'Select the language you want to generate models for',
options: Object.keys(Languages).map((key) =>
({ value: key, label: key, hint: Languages[key as keyof typeof Languages] })
),
});
askForOutput = true;
}
if (isCancel(language)) {
cancel(operationCancelled);
this.exit();
}
if (!file) {
file = await text({
message: 'Enter the path or URL to the AsyncAPI document',
defaultValue: 'asyncapi.yaml',
placeholder: 'asyncapi.yaml',
});
askForOutput = true;
}
if (isCancel(file)) {
cancel(operationCancelled);
this.exit();
}
if (!output && askForOutput) {
output = await text({
message: 'Enter the output directory or stdout to write the models to',
defaultValue: 'stdout',
placeholder: 'stdout',
}) as string;
}
if (isCancel(output)) {
cancel(operationCancelled);
this.exit();
}
return { language, file, output: output ?? 'stdout' };
}
}