-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.ts
83 lines (60 loc) · 2.18 KB
/
index.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
#!/usr/bin/env node
import chalk from 'chalk'
import figlet from 'figlet'
import { Command } from 'commander'
import { Logger } from '@secjs/logger'
import { dirname, parse, resolve } from 'path'
import { Templating } from './src/Templating'
import { FieldsSanitizer } from './src/FieldsSanitizer'
const command = new Command()
const packageJson = require('./package.json')
command.version(packageJson.version, '-v, --version')
command
.command('generateFile [filePath]')
.description(
'Generate the file according to file template and environment variables.',
)
.option('-s, --set [fields...]', 'Subscribe environment variables')
.action(async (filePath, fields) => {
const logger = new Logger('CLI')
try {
filePath = resolve(filePath)
fields = FieldsSanitizer.validateAll(fields.set)
const templating = new Templating()
await templating.forFile(filePath)
await templating.formatEnvs()
await templating.formatFields(fields)
await templating.generate()
const { base } = parse(filePath)
logger.success(`✅ File ${base} has been replaced!`)
} catch (error) {
logger.error(`❌ Something went wrong: ${error.toString()}`)
}
})
command
.command('generate [path]')
.description(
'Generate the files according to template path and environment variables.',
)
.option('-s, --set [fields...]', 'Subscribe environment variables')
.action(async (path, fields) => {
const logger = new Logger('CLI')
try {
path = resolve(path)
fields = FieldsSanitizer.validateAll(fields.set)
const templating = new Templating()
await templating.load(path)
await templating.formatEnvs()
await templating.formatFields(fields)
await templating.generate()
logger.success(`✅ All files generated inside -> ${dirname(path)}`)
} catch (error) {
logger.error(`❌ Something went wrong: ${error.toString()}`)
}
})
command.parse(process.argv)
console.log(chalk.green(figlet.textSync('Templating CLI')))
console.log('\n')
console.log(chalk.green(`🆚 Version: ${packageJson.version}`))
console.log(chalk.green(`👤 Maintainer: ${packageJson.author}`))
console.log('\n')