@jtff/miztemplate-lib 2.2.0 → 3.0.0-rc2

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.
Files changed (65) hide show
  1. package/index.js +4 -3
  2. package/lib/jtff-lib-ci.js +1 -307
  3. package/lib/mizlib.js +337 -0
  4. package/lua/lib/Hercules_Cargo.lua +686 -0
  5. package/lua/lib/Moose_.lua +117314 -0
  6. package/lua/lib/Splash_Damage_2_0.lua +472 -0
  7. package/lua/lib/gemman.lua +1 -0
  8. package/lua/lib/mist_4_5_107.lua +9084 -0
  9. package/lua/lib/skynet-iads-compiled.lua +3864 -0
  10. package/lua/settings/settings-RAT.lua +235 -0
  11. package/lua/settings/settings-airboss.lua +142 -0
  12. package/lua/settings/settings-atis.lua +31 -0
  13. package/lua/settings/settings-awacs.lua +58 -0
  14. package/lua/settings/settings-awacsondemand.lua +26 -0
  15. package/lua/settings/settings-beacons.lua +10 -0
  16. package/lua/settings/settings-capwarzone.lua +164 -0
  17. package/lua/settings/settings-capzone.lua +32 -0
  18. package/lua/settings/settings-fac_ranges.lua +17 -0
  19. package/lua/settings/settings-foxzone.lua +14 -0
  20. package/lua/settings/settings-gemman.lua +6 -0
  21. package/lua/settings/settings-global.lua +31 -0
  22. package/lua/settings/settings-intercept.lua +23 -0
  23. package/lua/settings/settings-logistics.lua +22 -0
  24. package/lua/settings/settings-ondemandawacs.lua +29 -0
  25. package/lua/settings/settings-ondemandtankers.lua +29 -0
  26. package/lua/settings/settings-pedros.lua +11 -0
  27. package/lua/settings/settings-ranges.lua +28 -0
  28. package/lua/settings/settings-reapers.lua +25 -0
  29. package/lua/settings/settings-sams.lua +19 -0
  30. package/lua/settings/settings-skynet.lua +239 -0
  31. package/lua/settings/settings-tankers.lua +32 -0
  32. package/lua/settings/settings-training_ranges.lua +37 -0
  33. package/lua/src/010-root_menus.lua +5 -0
  34. package/lua/src/020-mission_functions.lua +1059 -0
  35. package/lua/src/110-set_clients.lua +61 -0
  36. package/lua/src/120-tankers.lua +589 -0
  37. package/lua/src/130-airboss.lua +621 -0
  38. package/lua/src/135-pedro.lua +21 -0
  39. package/lua/src/140-beacons.lua +19 -0
  40. package/lua/src/150-awacs.lua +599 -0
  41. package/lua/src/160-atis.lua +53 -0
  42. package/lua/src/170-cap_zone_training.lua +127 -0
  43. package/lua/src/172-cap_zone_war.lua +190 -0
  44. package/lua/src/173-fox_zone_training.lua +87 -0
  45. package/lua/src/176-random_air_traffic.lua +73 -0
  46. package/lua/src/178-training-intercept.lua +263 -0
  47. package/lua/src/180-logistics.lua +80 -0
  48. package/lua/src/190-ranges.lua +54 -0
  49. package/lua/src/191-sams.lua +49 -0
  50. package/lua/src/193-training_ranges.lua +191 -0
  51. package/lua/src/195-reaper-ondemand.lua +522 -0
  52. package/lua/src/196-fac_ranges.lua +34 -0
  53. package/lua/src/199-skynet.lua +721 -0
  54. package/lua/src/200-mission.lua +3 -0
  55. package/package.json +4 -3
  56. package/resources/radios/.gitkeep +0 -0
  57. package/resources/sounds/CTLD/beacon.ogg +0 -0
  58. package/resources/sounds/CTLD/beaconsilent.ogg +0 -0
  59. package/resources/sounds/Misc/.gitkeep +0 -0
  60. package/resources/sounds/Misc/2_Bips.ogg +0 -0
  61. package/resources/sounds/Misc/Bip.ogg +0 -0
  62. package/resources/sounds/Misc/crash_wood.ogg +0 -0
  63. package/scripts/build.js +2 -1
  64. package/scripts/inject-scripts.js +127 -230
  65. package/scripts/template-update.js +1 -1
package/index.js CHANGED
@@ -1,4 +1,5 @@
1
- const {MizTemplateCI,MizLib} = require("./lib/jtff-lib-ci.js");
1
+ const MizTemplateCI = require("./lib/jtff-lib-ci.js");
2
+ const mizlib = require("./lib/mizlib.js");
2
3
  const build = require("./scripts/build.js");
3
4
  const clean = require("./scripts/clean.js");
4
5
  const ftpupload = require("./scripts/ftpupload.js");
@@ -12,7 +13,6 @@ const templateUpdate = require("./scripts/template-update.js");
12
13
 
13
14
  module.exports = {
14
15
  MizTemplateCI: MizTemplateCI,
15
- MizLib: MizLib,
16
16
  build:build,
17
17
  clean:clean,
18
18
  ftpupload:ftpupload,
@@ -23,5 +23,6 @@ module.exports = {
23
23
  injectScripts:injectScripts,
24
24
  nextversionPrepare:nextversionPrepare,
25
25
  release:release,
26
- templateUpdate:templateUpdate
26
+ templateUpdate:templateUpdate,
27
+ mizlib: mizlib,
27
28
  };
@@ -1,18 +1,13 @@
1
1
  "use strict";
2
2
 
3
- const jszip = require("jszip");
4
3
  const fs = require("fs");
5
4
  const path = require("path");
6
- const { promisify } = require('util');
7
- const lstat = promisify(fs.lstat);
8
5
  const { google } = require("googleapis");
9
- const { format, parse } = require("lua-json");
10
6
  const ftpClient = require('ftp');
11
7
 
12
8
  class MizTemplateCI{
13
9
  constructor(config) {
14
10
  this.config = config
15
- this.mizlib = new MizLib()
16
11
  }
17
12
 
18
13
  getVersion() {
@@ -192,307 +187,6 @@ class MizTemplateCI{
192
187
  }
193
188
  }
194
189
 
195
- class MizLib{
196
- constructor() {
197
- }
198
- injectScripts(tObject, trObject, mrObject, strTitle, scriptFilesArray, timingInSeconds, hexColor) {
199
- let nextIndex = Object.keys(trObject).length + 1;
200
- if (nextIndex === 1) {
201
- tObject['actions'] = {};
202
- tObject['func'] = {};
203
- tObject['conditions'] = {};
204
- tObject['flag'] = {};
205
- trObject = {};
206
- }
207
- let actionSentence = "";
208
- let actionsObject = {};
209
- for (const [index, scriptFile] of scriptFilesArray.entries()) {
210
- actionSentence += "a_do_script_file(getValueResourceByKey(\"" + scriptFile + "\")); "
211
- actionsObject[index + 1] = {
212
- file: scriptFile,
213
- predicate: 'a_do_script_file',
214
- };
215
- mrObject[scriptFile] = scriptFile;
216
- }
217
- actionSentence += "mission.trig.func[" + nextIndex + "]=nil;"
218
- tObject['actions'][nextIndex] = actionSentence;
219
- tObject['func'][nextIndex] = "if mission.trig.conditions[" + nextIndex + "]() then mission.trig.actions[" + nextIndex + "]() end";
220
- tObject['conditions'][nextIndex] = "return(c_time_after(" + timingInSeconds + ") )";
221
- tObject['flag'][nextIndex] = true;
222
- trObject[nextIndex] = {
223
- rules: {
224
- 1: {
225
- coalitionlist: 'red',
226
- seconds: timingInSeconds,
227
- predicate: 'c_time_after',
228
- zone: ''
229
- }
230
- },
231
- eventlist: '',
232
- comment: strTitle,
233
- actions: actionsObject,
234
- predicate: 'triggerOnce',
235
- colorItem: hexColor
236
- };
237
- return { tObject: tObject, trObject: trObject, mrObject: mrObject };
238
- }
239
-
240
- async mizOpen(mizPath) {
241
- var MizFile = new jszip();
242
- const mizData = fs.readFileSync(mizPath);
243
- return MizFile.loadAsync(mizData);
244
- }
245
-
246
- async mizUpdate(mizPath, copyPath, strTheatreSettings) {
247
- const zip = await this.mizOpen(mizPath);
248
- this.mizUpdateSrcLuaFiles(zip);
249
- this.mizUpdateLibLuaFiles(zip);
250
- if (strTheatreSettings === null) {
251
- // TODO: Inject fake data
252
- console.log("NO THEATRE SPECIFIED. RADIO PRESETS WILL NOT BE AVAILABLE !");
253
- } else {
254
- await this.mizUpdateRadioPresets(zip, 'resources/radios/' + strTheatreSettings);
255
- }
256
- this.mizUpdateSettingsLuaFiles(zip, strTheatreSettings);
257
- await this.mizUpdateSoundFolders(zip);
258
- const inputZip = await zip.generateAsync({
259
- type: 'nodebuffer',
260
- streamFiles: true,
261
- compression: "DEFLATE",
262
- compressionOptions: {
263
- level: 9
264
- }
265
- });
266
- fs.writeFileSync(copyPath ? copyPath : mizPath, inputZip);
267
- }
268
-
269
- async mizInjectMissionDataFile(mizPath, missionObject) {
270
- const zip = await this.mizOpen(mizPath);
271
- this.mizUpdateMissionDataFile(zip, missionObject);
272
- const inputZip = await zip.generateAsync({
273
- type: 'nodebuffer',
274
- streamFiles: true,
275
- compression: "DEFLATE",
276
- compressionOptions: {
277
- level: 9
278
- }
279
- });
280
- fs.writeFileSync(mizPath, inputZip);
281
- }
282
-
283
- async mizInjectSettingsFolder(mizPath, settingsFolder) {
284
- const zip = await this.mizOpen(mizPath);
285
- for (let file of fs.readdirSync(settingsFolder).filter(file => file.endsWith(".lua"))) {
286
- this.mizUpdateLuaFile(zip, [
287
- settingsFolder,
288
- "/",
289
- file].join(""));
290
- }
291
- const inputZip = await zip.generateAsync({
292
- type: 'nodebuffer',
293
- streamFiles: true,
294
- compression: "DEFLATE",
295
- compressionOptions: {
296
- level: 9
297
- }
298
- });
299
- fs.writeFileSync(mizPath, inputZip);
300
- }
301
-
302
- async mizInjectMapResourceFile(mizPath, mapResourceObject) {
303
- const zip = await this.mizOpen(mizPath);
304
- this.mizUpdateMapResourceFile(zip, mapResourceObject);
305
- const inputZip = await zip.generateAsync({
306
- type: 'nodebuffer',
307
- streamFiles: true,
308
- compression: "DEFLATE",
309
- compressionOptions: {
310
- level: 9
311
- }
312
- });
313
- fs.writeFileSync(mizPath, inputZip);
314
- }
315
-
316
- mizUpdateLuaFile(zip, filePath) {
317
- zip.remove("l10n/DEFAULT/" + path.basename(filePath));
318
- var stream = fs.createReadStream(filePath);
319
- zip.file("l10n/DEFAULT/" + path.basename(filePath), stream);
320
- }
321
-
322
- mizUpdateSrcLuaFiles(zip) {
323
- for (let file of fs.readdirSync('src').filter(file => file.endsWith(".lua"))) {
324
- console.log('updating src/' + file + ' file in miz file');
325
- this.mizUpdateLuaFile(zip, "src/" + file);
326
- };
327
- }
328
-
329
- mizUpdateMissionDataFile(zip, missionObject) {
330
- zip.remove("mission");
331
- let missionLuaT = format(missionObject, { singleQuote: false })
332
- missionLuaT = missionLuaT
333
- .split('\n')
334
- .slice(1, -1)
335
- .join('\n')
336
- .slice(0, -1)
337
- .replace(/\[\"(\d+)\"\] = /g, "[$1] = ");
338
- zip.file("mission", missionLuaT);
339
- }
340
-
341
- mizUpdateMapResourceFile(zip, mapResourceObject) {
342
- zip.remove("l10n/DEFAULT/mapResource");
343
- let mapResourceLuaT = format(mapResourceObject, { singleQuote: false })
344
- mapResourceLuaT = mapResourceLuaT
345
- .split('\n')
346
- .slice(1, -1)
347
- .join('\n')
348
- .slice(0, -1)
349
- .replace(/\[\"(\d+)\"\] = /g, "[$1] = ");
350
- zip.file("l10n/DEFAULT/mapResource", mapResourceLuaT);
351
- }
352
-
353
- mizOpenMissionData(zipStream) {
354
- return zipStream.file("mission").async("string");
355
- }
356
190
 
357
- mizOpenMapResource(zipStream) {
358
- return zipStream.file("l10n/DEFAULT/mapResource").async("string");
359
- }
360
-
361
- mizUpdateLibLuaFiles(zip) {
362
- for (let file of fs.readdirSync('lib').filter(file => file.endsWith(".lua"))) {
363
- console.log('updating lib/' + file + ' file in miz file');
364
- this.mizUpdateLuaFile(zip, "lib/" + file);
365
- };
366
- }
367
-
368
- async mizUpdateRadioPresets(zip, preset_folder) {
369
- // Create folder Avionics to make sure it exists then delete it to remove any old preset in the template
370
- // Allows adding presets for A-10C
371
- zip.folder("Avionics");
372
- zip.remove("Avionics");
373
-
374
- const mission_object = await this.getMissionObjectFromZip(zip);
375
- for (let file of fs.readdirSync(preset_folder).filter(file => file.endsWith(".lua"))) {
376
- const file_data = fs.readFileSync(preset_folder + '/' + file).toString();
377
- const lua_string = file_data.substring(0, file_data.indexOf("radio_descriptor_table =") - 1);
378
- const radio_descriptor_table = parse("return {" + lua_string + "}").descriptor;
379
-
380
- console.log('updating radio presets (aircraft: ' + radio_descriptor_table["aircraft"] + ', group_name: ' + radio_descriptor_table["group_name"] + ') with preset in ' + preset_folder + ' folder');
381
- const dcs_radio_presets = file_data.substring(file_data.indexOf("radio_descriptor_table =") + 24);
382
-
383
- for (const coalition_key in mission_object.coalition) {
384
- const coalition = mission_object.coalition[coalition_key];
385
- for (const country_list_key in coalition) {
386
- if (country_list_key != "country") continue;
387
- const country_list = coalition[country_list_key];
388
- for (const country_key in country_list) {
389
- const country = country_list[country_key];
390
- for (const plane_key in country["plane"]) {
391
- const plane = country["plane"][plane_key];
392
- for (const group_key in plane) {
393
- const group = plane[group_key];
394
- if (group["name"].match(radio_descriptor_table["group_name"]) == null) continue;
395
- for (const unit_key in group) {
396
- if (unit_key != "units") continue;
397
- const unit = group[unit_key];
398
- for (const sub_unit_key in unit) {
399
- const sub_unit = unit[sub_unit_key];
400
- if (sub_unit["skill"] != "Client") continue;
401
- // Aircraft is an A10CII, use A10C mode by creating files in the root with the unit id
402
- // if (radio_descriptor_table["aircraft"] == 'A-10C_2') {
403
- // const unit_id = sub_unit["unitId"];
404
- // ["UHF_RADIO", "VHF_AM_RADIO", "VHF_FM_RADIO"].forEach(folder => {
405
- // var zip_folder = zip.folder("Avionics/A-10C_2/" + unit_id + "/" + folder);
406
- // var file = parse("return " + dcs_radio_presets)[folder];
407
- // file = format(file, { singleQuote: false });
408
- // file = file
409
- // .split('\n')
410
- // .slice(1, -1)
411
- // .join('\n')
412
- // .slice(0, -1)
413
- // .replace(/\[\"(\d+)\"\] = /g, "[$1] = ");
414
- // zip_folder.file("SETTINGS.lua", file);
415
- // });
416
- // continue;
417
- // }
418
- if (sub_unit["type"] != radio_descriptor_table["aircraft"]) continue;
419
- // GROUP FOUND, SET RADIOS
420
- sub_unit["Radio"] = parse("return " + dcs_radio_presets)
421
- }
422
- }
423
- }
424
- }
425
- }
426
- }
427
- }
428
- };
429
- this.mizUpdateMissionDataFile(zip, {mission: mission_object});
430
- }
431
-
432
- mizUpdateSettingsLuaFiles(zip, strTheatre) {
433
- for (let file of fs.readdirSync('settings/' + strTheatre).filter(file => file.endsWith(".lua"))) {
434
- console.log('updating settings/' + strTheatre + '/' + file + ' file in miz file');
435
- this.mizUpdateLuaFile(zip, 'settings/' + strTheatre + '/' + file);
436
- };
437
- }
438
-
439
- async mizUpdateSoundFolders(zip) {
440
- const folderArray = fs.readdirSync('resources/sounds');
441
- for (const folder of folderArray) {
442
- // if(zip.folder(new RegExp(folder)).length > 0 ) {
443
- if (fs.existsSync('resources/sounds/' + folder) && fs.lstatSync('resources/sounds/' + folder).isDirectory()) {
444
- await this.mizUpdateSingleSoundFolder(zip, folder);
445
- }
446
- // }
447
- }
448
- }
449
-
450
- async mizUpdateSingleSoundFolder(zip, folder) {
451
- console.log('adding sound files from resources/sounds/' + folder + ' folder...');
452
- zip = zip.remove(folder).folder(folder);
453
- await this.addFilesToZip(zip, 'resources/sounds/' + folder, fs.readdirSync('resources/sounds/' + folder));
454
- }
455
-
456
- async addFilesToZip(zip, directoryPath, filesToInclude) {
457
- const promiseArr = await filesToInclude.map(async file => {
458
- const filePath = path.join(directoryPath, file)
459
- try {
460
- const fileStats = await lstat(filePath)
461
- const isDirectory = fileStats.isDirectory()
462
- if (isDirectory) {
463
- const directory = zip.remove(file).folder(file)
464
- const subFiles = fs.readdirSync(filePath)
465
- return this.addFilesToZip(directory, filePath, subFiles)
466
- } else {
467
- // console.log('added file : '+file);
468
- return zip.file(file, fs.createReadStream(filePath))
469
- }
470
- } catch (err) {
471
- console.log(err)
472
- return Promise.resolve()
473
- }
474
- })
475
- return Promise.all(promiseArr)
476
- }
477
-
478
- async copyMiz(srcMizPath, dstMizPath) {
479
- await fs.createReadStream(srcMizPath).pipe(fs.createWriteStream(dstMizPath));
480
- }
481
-
482
- async getMissionObjectFromMiz(MizPath) {
483
- let luaTable = 'return { \n' + await this.mizOpenMissionData(await this.mizOpen(MizPath)) + ' }';
484
- return parse(luaTable).mission;
485
- }
486
-
487
- async getMissionObjectFromZip(zip) {
488
- let luaTable = 'return { \n' + await this.mizOpenMissionData(zip) + ' }';
489
- return parse(luaTable).mission;
490
- }
491
-
492
- async getMapResourceObjectFromMiz(MizPath) {
493
- let luaTable = 'return { \n' + await this.mizOpenMapResource(await this.mizOpen(MizPath)) + ' }';
494
- return parse(luaTable).mapResource;
495
- }
496
- }
497
191
 
498
- module.exports = {MizTemplateCI, MizLib};
192
+ module.exports = MizTemplateCI;
package/lib/mizlib.js ADDED
@@ -0,0 +1,337 @@
1
+ "use strict";
2
+
3
+ const jszip = require("jszip");
4
+ const path = require("path");
5
+ const {format, parse} = require("lua-json");
6
+ const {promisify} = require("util");
7
+ const fs = require("fs");
8
+ const lstat = promisify(fs.lstat);
9
+
10
+ function injectLuaScriptsInMissionObject(tObject, trObject, mrObject, strTitle, scriptFilesArray, timingInSeconds, hexColor) {
11
+ let nextIndex = Object.keys(trObject).length + 1;
12
+ if (nextIndex === 1) {
13
+ tObject['actions'] = {};
14
+ tObject['func'] = {};
15
+ tObject['conditions'] = {};
16
+ tObject['flag'] = {};
17
+ trObject = {};
18
+ }
19
+ let actionSentence = "";
20
+ let actionsObject = {};
21
+ for (const [index, scriptFile] of scriptFilesArray.entries()) {
22
+ actionSentence += "a_do_script_file(getValueResourceByKey(\"" + scriptFile + "\")); "
23
+ actionsObject[index + 1] = {
24
+ file: scriptFile,
25
+ predicate: 'a_do_script_file',
26
+ };
27
+ mrObject[scriptFile] = scriptFile;
28
+ }
29
+ actionSentence += "mission.trig.func[" + nextIndex + "]=nil;"
30
+ tObject['actions'][nextIndex] = actionSentence;
31
+ tObject['func'][nextIndex] = "if mission.trig.conditions[" + nextIndex + "]() then mission.trig.actions[" + nextIndex + "]() end";
32
+ tObject['conditions'][nextIndex] = "return(c_time_after(" + timingInSeconds + ") )";
33
+ tObject['flag'][nextIndex] = true;
34
+ trObject[nextIndex] = {
35
+ rules: {
36
+ 1: {
37
+ coalitionlist: 'red',
38
+ seconds: timingInSeconds,
39
+ predicate: 'c_time_after',
40
+ zone: ''
41
+ }
42
+ },
43
+ eventlist: '',
44
+ comment: strTitle,
45
+ actions: actionsObject,
46
+ predicate: 'triggerOnce',
47
+ colorItem: hexColor
48
+ };
49
+ return { tObject: tObject, trObject: trObject, mrObject: mrObject };
50
+ }
51
+
52
+ async function getZipObjectFromMizPath(mizPath) {
53
+ var MizFile = new jszip();
54
+ const mizData = fs.readFileSync(mizPath);
55
+ return MizFile.loadAsync(mizData);
56
+ }
57
+
58
+ async function mizUpdate(mizPath, copyPath, strTheatreSettings) {
59
+ const zip = await getZipObjectFromMizPath(mizPath);
60
+ injectLuaFilesFromFolderIntoZipObject(zip,'src');
61
+ injectLuaFilesFromFolderIntoZipObject(zip,'lib');
62
+ if (strTheatreSettings === null) {
63
+ // TODO: Inject fake data
64
+ console.log("NO THEATRE SPECIFIED. RADIO PRESETS WILL NOT BE AVAILABLE !");
65
+ } else {
66
+ await mizUpdateRadioPresets(zip, 'resources/radios/' + strTheatreSettings);
67
+ }
68
+ mizUpdateSettingsLuaFiles(zip, strTheatreSettings);
69
+ await mizUpdateSoundFolders(zip);
70
+ const inputZip = await zip.generateAsync({
71
+ type: 'nodebuffer',
72
+ streamFiles: true,
73
+ compression: "DEFLATE",
74
+ compressionOptions: {
75
+ level: 9
76
+ }
77
+ });
78
+ fs.writeFileSync(copyPath ? copyPath : mizPath, inputZip);
79
+ }
80
+
81
+ async function mizInjectMissionDataFile(mizPath, missionObject) {
82
+ const zip = await getZipObjectFromMizPath(mizPath);
83
+ mizUpdateMissionDataFile(zip, missionObject);
84
+ const inputZip = await zip.generateAsync({
85
+ type: 'nodebuffer',
86
+ streamFiles: true,
87
+ compression: "DEFLATE",
88
+ compressionOptions: {
89
+ level: 9
90
+ }
91
+ });
92
+ fs.writeFileSync(mizPath, inputZip);
93
+ }
94
+
95
+ async function injectLuaSettingsFromFolderPathToMizPath(mizPath, settingsFolder) {
96
+ const zip = await getZipObjectFromMizPath(mizPath);
97
+ await injectLuaSettingsFromFolderPathToZipObject(zip,settingsFolder);
98
+ const outputZip = await zip.generateAsync({
99
+ type: 'nodebuffer',
100
+ streamFiles: true,
101
+ compression: "DEFLATE",
102
+ compressionOptions: {
103
+ level: 9
104
+ }
105
+ });
106
+ fs.writeFileSync(mizPath, outputZip);
107
+ }
108
+
109
+ async function injectLuaSettingsFromFolderPathToZipObject(zip, settingsFolder) {
110
+ for (let file of fs.readdirSync(settingsFolder).filter(file => file.endsWith(".lua"))) {
111
+ injectFileIntoZipObject(zip, [
112
+ settingsFolder,
113
+ "/",
114
+ file].join(""));
115
+ }
116
+ }
117
+
118
+
119
+ async function mizInjectMapResourceFile(mizPath, mapResourceObject) {
120
+ const zip = await getZipObjectFromMizPath(mizPath);
121
+ mizUpdateMapResourceFile(zip, mapResourceObject);
122
+ const inputZip = await zip.generateAsync({
123
+ type: 'nodebuffer',
124
+ streamFiles: true,
125
+ compression: "DEFLATE",
126
+ compressionOptions: {
127
+ level: 9
128
+ }
129
+ });
130
+ fs.writeFileSync(mizPath, inputZip);
131
+ }
132
+
133
+ function injectFileIntoZipObject(zip, filePath) {
134
+ zip.remove("l10n/DEFAULT/" + path.basename(filePath));
135
+ var stream = fs.createReadStream(filePath);
136
+ zip.file("l10n/DEFAULT/" + path.basename(filePath), stream);
137
+ }
138
+
139
+ function mizUpdateMissionDataFile(zip, missionObject) {
140
+ zip.remove("mission");
141
+ let missionLuaT = format(missionObject, { singleQuote: false })
142
+ missionLuaT = missionLuaT
143
+ .split('\n')
144
+ .slice(1, -1)
145
+ .join('\n')
146
+ .slice(0, -1)
147
+ .replace(/\[\"(\d+)\"\] = /g, "[$1] = ");
148
+ zip.file("mission", missionLuaT);
149
+ }
150
+
151
+ function mizUpdateMapResourceFile(zip, mapResourceObject) {
152
+ zip.remove("l10n/DEFAULT/mapResource");
153
+ let mapResourceLuaT = format(mapResourceObject, { singleQuote: false })
154
+ mapResourceLuaT = mapResourceLuaT
155
+ .split('\n')
156
+ .slice(1, -1)
157
+ .join('\n')
158
+ .slice(0, -1)
159
+ .replace(/\[\"(\d+)\"\] = /g, "[$1] = ");
160
+ zip.file("l10n/DEFAULT/mapResource", mapResourceLuaT);
161
+ }
162
+
163
+ function getMissionLuaStringFromZipObject(zipStream) {
164
+ return zipStream.file("mission").async("string");
165
+ }
166
+
167
+ function getMapResourceLuaStringFromZipObject(zipStream) {
168
+ return zipStream.file("l10n/DEFAULT/mapResource").async("string");
169
+ }
170
+
171
+ function injectLuaFilesFromFolderIntoZipObject(zip, folderPath) {
172
+ for (let file of fs.readdirSync(folderPath).filter(file => file.endsWith(".lua"))) {
173
+ console.log('injecting up2date ' + folderPath + '/' + file + ' file in archive');
174
+ injectFileIntoZipObject(zip, folderPath + "/" + file);
175
+ };
176
+ }
177
+
178
+
179
+ async function mizUpdateRadioPresets(zip, preset_folder) {
180
+ // Create folder Avionics to make sure it exists then delete it to remove any old preset in the template
181
+ // Allows adding presets for A-10C
182
+ zip.folder("Avionics");
183
+ zip.remove("Avionics");
184
+
185
+ const mission_object = await getMissionObjectFromZipObject(zip);
186
+ for (let file of fs.readdirSync(preset_folder).filter(file => file.endsWith(".lua"))) {
187
+ const file_data = fs.readFileSync(preset_folder + '/' + file).toString();
188
+ const lua_string = file_data.substring(0, file_data.indexOf("radio_descriptor_table =") - 1);
189
+ const radio_descriptor_table = parse("return {" + lua_string + "}").descriptor;
190
+
191
+ console.log('updating radio presets (aircraft: ' + radio_descriptor_table["aircraft"] + ', group_name: ' + radio_descriptor_table["group_name"] + ') with preset in ' + preset_folder + ' folder');
192
+ const dcs_radio_presets = file_data.substring(file_data.indexOf("radio_descriptor_table =") + 24);
193
+
194
+ for (const coalition_key in mission_object.coalition) {
195
+ const coalition = mission_object.coalition[coalition_key];
196
+ for (const country_list_key in coalition) {
197
+ if (country_list_key != "country") continue;
198
+ const country_list = coalition[country_list_key];
199
+ for (const country_key in country_list) {
200
+ const country = country_list[country_key];
201
+ for (const plane_key in country["plane"]) {
202
+ const plane = country["plane"][plane_key];
203
+ for (const group_key in plane) {
204
+ const group = plane[group_key];
205
+ if (group["name"].match(radio_descriptor_table["group_name"]) == null) continue;
206
+ for (const unit_key in group) {
207
+ if (unit_key != "units") continue;
208
+ const unit = group[unit_key];
209
+ for (const sub_unit_key in unit) {
210
+ const sub_unit = unit[sub_unit_key];
211
+ if (sub_unit["skill"] != "Client") continue;
212
+ // Aircraft is an A10CII, use A10C mode by creating files in the root with the unit id
213
+ // if (radio_descriptor_table["aircraft"] == 'A-10C_2') {
214
+ // const unit_id = sub_unit["unitId"];
215
+ // ["UHF_RADIO", "VHF_AM_RADIO", "VHF_FM_RADIO"].forEach(folder => {
216
+ // var zip_folder = zip.folder("Avionics/A-10C_2/" + unit_id + "/" + folder);
217
+ // var file = parse("return " + dcs_radio_presets)[folder];
218
+ // file = format(file, { singleQuote: false });
219
+ // file = file
220
+ // .split('\n')
221
+ // .slice(1, -1)
222
+ // .join('\n')
223
+ // .slice(0, -1)
224
+ // .replace(/\[\"(\d+)\"\] = /g, "[$1] = ");
225
+ // zip_folder.file("SETTINGS.lua", file);
226
+ // });
227
+ // continue;
228
+ // }
229
+ if (sub_unit["type"] != radio_descriptor_table["aircraft"]) continue;
230
+ // GROUP FOUND, SET RADIOS
231
+ sub_unit["Radio"] = parse("return " + dcs_radio_presets)
232
+ }
233
+ }
234
+ }
235
+ }
236
+ }
237
+ }
238
+ }
239
+ };
240
+ mizUpdateMissionDataFile(zip, {mission: mission_object});
241
+ }
242
+
243
+ function mizUpdateSettingsLuaFiles(zip, strTheatre) {
244
+ for (let file of fs.readdirSync('settings/' + strTheatre).filter(file => file.endsWith(".lua"))) {
245
+ console.log('updating settings/' + strTheatre + '/' + file + ' file in miz file');
246
+ injectFileIntoZipObject(zip, 'settings/' + strTheatre + '/' + file);
247
+ };
248
+ }
249
+
250
+ async function mizUpdateSoundFolders(zip) {
251
+ if (fs.existsSync('resources/sounds') && fs.lstatSync('resources/sounds').isDirectory()) {
252
+ const folderArray = fs.readdirSync('resources/sounds');
253
+ for (const folder of folderArray) {
254
+ await mizUpdateSingleSoundFolder(zip, folder);
255
+ }
256
+ }
257
+ }
258
+
259
+ async function mizUpdateSingleSoundFolder(zip, folder) {
260
+ if (fs.existsSync('resources/sounds/' + folder) && fs.lstatSync('resources/sounds/' + folder).isDirectory()) {
261
+ console.log('adding sound files from resources/sounds/' + folder + ' folder...');
262
+ zip = zip.remove(folder).folder(folder);
263
+ await addFilesToZip(zip, 'resources/sounds/' + folder, fs.readdirSync('resources/sounds/' + folder));
264
+ }
265
+ }
266
+
267
+ async function addFilesToZip(zip, directoryPath, filesToInclude) {
268
+ const promiseArr = await filesToInclude.map(async file => {
269
+ const filePath = path.join(directoryPath, file)
270
+ try {
271
+ const fileStats = await lstat(filePath)
272
+ const isDirectory = fileStats.isDirectory()
273
+ if (isDirectory) {
274
+ const directory = zip.remove(file).folder(file)
275
+ const subFiles = fs.readdirSync(filePath)
276
+ return addFilesToZip(directory, filePath, subFiles)
277
+ } else {
278
+ // console.log('added file : '+file);
279
+ return zip.file(file, fs.createReadStream(filePath))
280
+ }
281
+ } catch (err) {
282
+ console.log(err)
283
+ return Promise.resolve()
284
+ }
285
+ })
286
+ return Promise.all(promiseArr)
287
+ }
288
+
289
+ async function copyMiz(srcMizPath, dstMizPath) {
290
+ await fs.createReadStream(srcMizPath).pipe(fs.createWriteStream(dstMizPath));
291
+ }
292
+
293
+ async function getMissionObjectFromMizPath(MizPath) {
294
+ let luaTable = 'return { \n' + await getMissionLuaStringFromZipObject(await getZipObjectFromMizPath(MizPath)) + ' }';
295
+ return parse(luaTable).mission;
296
+ }
297
+
298
+ async function getMissionObjectFromZipObject(zip) {
299
+ let luaTable = 'return { \n' + await getMissionLuaStringFromZipObject(zip) + ' }';
300
+ return parse(luaTable).mission;
301
+ }
302
+
303
+ async function getMapResourceObjectFromMizPath(MizPath) {
304
+ let luaTable = 'return { \n' + await getMapResourceLuaStringFromZipObject(await getZipObjectFromMizPath(MizPath)) + ' }';
305
+ return parse(luaTable).mapResource;
306
+ }
307
+
308
+ async function getMapResourceObjectFromZipObject(zip) {
309
+ let luaTable = 'return { \n' + await getMapResourceLuaStringFromZipObject(zip) + ' }';
310
+ return parse(luaTable).mapResource;
311
+ }
312
+
313
+ module.exports = {
314
+ injectLuaScriptsInMissionObject: injectLuaScriptsInMissionObject,
315
+ getZipObjectFromMizPath: getZipObjectFromMizPath,
316
+ mizUpdate: mizUpdate,
317
+ mizInjectMissionDataFile: mizInjectMissionDataFile,
318
+ injectLuaSettingsFromFolderPathToMizPath: injectLuaSettingsFromFolderPathToMizPath,
319
+ injectLuaSettingsFromFolderPathToZipObject: injectLuaSettingsFromFolderPathToZipObject,
320
+ mizInjectMapResourceFile: mizInjectMapResourceFile,
321
+ injectFileIntoZipObject: injectFileIntoZipObject,
322
+ mizUpdateMissionDataFile: mizUpdateMissionDataFile,
323
+ mizUpdateMapResourceFile: mizUpdateMapResourceFile,
324
+ getMissionLuaStringFromZipObject: getMissionLuaStringFromZipObject,
325
+ getMapResourceLuaStringFromZipObject: getMapResourceLuaStringFromZipObject,
326
+ mizUpdateRadioPresets: mizUpdateRadioPresets,
327
+ mizUpdateSettingsLuaFiles: mizUpdateSettingsLuaFiles,
328
+ mizUpdateSoundFolders: mizUpdateSoundFolders,
329
+ mizUpdateSingleSoundFolder: mizUpdateSingleSoundFolder,
330
+ addFilesToZip: addFilesToZip,
331
+ copyMiz: copyMiz,
332
+ getMissionObjectFromMizPath: getMissionObjectFromMizPath,
333
+ getMissionObjectFromZipObject: getMissionObjectFromZipObject,
334
+ getMapResourceObjectFromMizPath: getMapResourceObjectFromMizPath,
335
+ getMapResourceObjectFromZipObject: getMapResourceObjectFromZipObject,
336
+ injectLuaFilesFromFolderIntoZipObject: injectLuaFilesFromFolderIntoZipObject
337
+ };