1 |
|
2 | import { loadTemplatizedYaml } from './renderer';
|
3 | import * as Path from 'path';
|
4 | import deepmerge = require('deepmerge');
|
5 | import * as fs from 'fs-extra-plus';
|
6 |
|
7 |
|
8 |
|
9 | export interface RawVdevConfig {
|
10 | system: string;
|
11 | baseBlockDir: string;
|
12 | k8sDir: string;
|
13 | realms: { [name: string]: any };
|
14 | blocks: (string | any)[];
|
15 |
|
16 | versionFiles: string[];
|
17 | }
|
18 |
|
19 |
|
20 |
|
21 |
|
22 | export async function loadVersionFiles() {
|
23 | const rawConfig = await loadVdevConfig();
|
24 | return rawConfig.versionFiles || [];
|
25 | }
|
26 |
|
27 | const overwriteMerge = (target: any[], source: any[], options?: deepmerge.Options) => source
|
28 |
|
29 |
|
30 | export async function loadVdevConfig(rootDir?: string): Promise<RawVdevConfig> {
|
31 | rootDir = rootDir || "./";
|
32 | const vdevFile = Path.join(rootDir, 'vdev.yaml');
|
33 |
|
34 | let vdevObj = await loadVdevFile(vdevFile, true);
|
35 |
|
36 |
|
37 |
|
38 |
|
39 | if (vdevObj.vdevFiles) {
|
40 | for (const subRelVdevFile of vdevObj.vdevFiles) {
|
41 | const subVdevFile = Path.join(rootDir, subRelVdevFile);
|
42 | const exists = await fs.pathExists(subVdevFile);
|
43 | if (exists) {
|
44 | console.log(`INFO - Loading extra vdev file: ${subVdevFile}`);
|
45 | try {
|
46 | let subVdevObj = await loadVdevFile(subVdevFile);
|
47 | vdevObj = deepmerge(vdevObj, subVdevObj, { arrayMerge: overwriteMerge });
|
48 | } catch (ex) {
|
49 | console.log(`ERROR - Cannot load vdev files ${subVdevFile} (skipping file)\n\tCause: ${ex}`);
|
50 | }
|
51 | }
|
52 |
|
53 | }
|
54 | }
|
55 |
|
56 |
|
57 | return vdevObj as RawVdevConfig;
|
58 | }
|
59 |
|
60 |
|
61 |
|
62 |
|
63 |
|
64 |
|
65 | async function loadVdevFile(vdevFile: string, base = false): Promise<any> {
|
66 | const vdevRawObj = await loadTemplatizedYaml(vdevFile);
|
67 |
|
68 | return vdevRawObj;
|
69 | } |
\ | No newline at end of file |