@kontur.candy/tools 2.138.0 → 2.140.0-debug

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 (37) hide show
  1. package/CHANGELOG.md +79 -0
  2. package/distr/Common/CandyApiClient/CandyApiClient.js +80 -9
  3. package/distr/Common/CandyApiClient/FakeCandyApiClient.js +26 -4
  4. package/distr/Common/CandyApiClient/Types/GetInner/ServerRawResponse.js +11 -0
  5. package/distr/Common/CandyApiClient/Types/MassActions/MassActionParameters.js +6 -0
  6. package/distr/Common/CandyApiClient/Types/Print/PrintResponse.js +6 -0
  7. package/distr/Common/CandyApiClient/Types/Print/PrintType.js +14 -0
  8. package/distr/Common/CandyApiClient/Types/Staff/ImportEmployeesOptions.js +6 -0
  9. package/distr/Common/HttpClient/HttpClient.js +5 -2
  10. package/distr/Common/IterableUtils.js +26 -1
  11. package/distr/Common/KCLangRuntimeUtils.js +10 -2
  12. package/distr/Common/ModelPath/BuildIterationSequence.js +3 -2
  13. package/distr/Common/ModelPath/ModelPath.js +15 -4
  14. package/distr/Common/StringArrayKey.js +4 -12
  15. package/distr/Common/UseShowOnce.js +88 -0
  16. package/distr/Common/hashUtils.js +17 -0
  17. package/distr/Tools/src/BuildTasks/Form/CompileForm.js +10 -4
  18. package/distr/Tools/src/BuildTasks/Generator/GeneratorWorker/GeneratorRequireUtils.js +45 -2
  19. package/distr/Tools/src/BuildTasks/Generator/GeneratorWorker/ReadSourcesAndProcessSugarWorker.js +3 -1
  20. package/distr/Tools/src/BuildTasks/ResolveFormInfo.js +1 -1
  21. package/distr/Tools/src/CLICommands/BuildForms/RunBuildForms.js +6 -6
  22. package/distr/Tools/src/CLICommands/BuildServer/ResourcesControllers/BuildServerBackendResourcesController.js +46 -4
  23. package/distr/Tools/src/CLICommands/BuildServer/ResourcesControllers/BuildServerBackendResourcesUpdatesController.js +2 -2
  24. package/distr/Tools/src/CLICommands/BuildServer/ResourcesControllers/DevServers/BuildFormDevServer.js +12 -6
  25. package/distr/Tools/src/CLICommands/DevBuild/RunDevBuild.js +2 -2
  26. package/distr/Tools/src/CLICommands/UpgradeForm/RunUpgradeForm.js +5 -2
  27. package/distr/Tools/src/Commons/ApiClient/ToolsApiClient.js +37 -0
  28. package/distr/Tools/src/FormWebpackConfiguration/CacheAssetsPlugin.js +9 -7
  29. package/distr/Tools/src/FormWebpackConfiguration/createFormWebpackConfiguration.js +5 -3
  30. package/distr/Tools/src/LocalServerFrontEndDist/enhancedClient.js +1 -1
  31. package/distr/Tools/src/LocalServerFrontEndDist/index.js +1 -1
  32. package/distr/Tools/src/LocalServerFrontEndDist/index.js.map +1 -1
  33. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js +151 -57
  34. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js.map +1 -1
  35. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js +226 -137
  36. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js.map +1 -1
  37. package/package.json +1 -1
@@ -23,8 +23,7 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
23
23
 
24
24
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
25
 
26
- temp.track();
27
-
26
+ // temp.track();
28
27
  function tempMKDir(affixes) {
29
28
  return new Promise((resolve, reject) => {
30
29
  temp.mkdir(affixes, (err, result) => {
@@ -52,6 +51,9 @@ async function compileForm(gfv, themes, farmDirectory, resourcesDirectory, resou
52
51
  };
53
52
  const action = (0, _ILogger.buildActionBegin)(logger, "Compile");
54
53
  const formBuildTempDir = await tempMKDir(`candy-forms-${gfv}-build`);
54
+ logger.log("=== все компоненты для билда находятся в этой папке ====");
55
+ logger.log(formBuildTempDir);
56
+ logger.log("========================================================");
55
57
 
56
58
  const formBuildWebpackConfig = _path.default.join(formBuildTempDir, "webpack.config.js");
57
59
 
@@ -61,10 +63,14 @@ module.exports = createConfig(${JSON.stringify(options)})`, "utf8");
61
63
 
62
64
  const pathToWebPackExecutable = _path.default.join(require.resolve("webpack"), "..", "..", "..", ".bin", "webpack");
63
65
 
64
- await (0, _ExecUtils.execCommandAsync)(logger, `${pathToWebPackExecutable} --config ${formBuildWebpackConfig}`, {
66
+ const zzz = `${pathToWebPackExecutable} --config ${formBuildWebpackConfig}`;
67
+ logger.log("============== Команда на исполнение ==============");
68
+ logger.log(zzz);
69
+ logger.log("=======================================================");
70
+ await (0, _ExecUtils.execCommandAsync)(logger, zzz, {
65
71
  caption: "Compiling form",
66
72
  cwd: _path.default.dirname(formBuildWebpackConfig)
67
73
  });
68
74
  action.complete();
69
75
  }
70
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0Zvcm0vQ29tcGlsZUZvcm0udHMiXSwibmFtZXMiOlsidGVtcCIsInRyYWNrIiwidGVtcE1LRGlyIiwiYWZmaXhlcyIsIlByb21pc2UiLCJyZXNvbHZlIiwicmVqZWN0IiwibWtkaXIiLCJlcnIiLCJyZXN1bHQiLCJjb21waWxlRm9ybSIsImdmdiIsInRoZW1lcyIsImZhcm1EaXJlY3RvcnkiLCJyZXNvdXJjZXNEaXJlY3RvcnkiLCJyZXNvdXJjZXNIYXNoIiwiYnVpbGREZWJ1Z09ubHkiLCJwYXJlbnRMb2dnZXIiLCJidWlsZENhY2hlT3B0aW9ucyIsImxvZ2dlciIsIndpdGhQcmVmaXgiLCJwYXRoVG9XZWJwYWNrQ29uZmlnRmFjdG9yeSIsInJlcXVpcmUiLCJvcHRpb25zIiwiZm9ybXNEaXJlY3RvcnlQYXRoIiwicGF0aCIsImpvaW4iLCJyZXNvdXJjZXNEaXJlY3RvcnlQYXRoIiwibW9kZXMiLCJhY3Rpb24iLCJmb3JtQnVpbGRUZW1wRGlyIiwiZm9ybUJ1aWxkV2VicGFja0NvbmZpZyIsIkpTT04iLCJzdHJpbmdpZnkiLCJwYXRoVG9XZWJQYWNrRXhlY3V0YWJsZSIsImNhcHRpb24iLCJjd2QiLCJkaXJuYW1lIiwiY29tcGxldGUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUVBOztBQUVBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7QUFJQUEsSUFBSSxDQUFDQyxLQUFMOztBQUVBLFNBQVNDLFNBQVQsQ0FBbUJDLE9BQW5CLEVBQTBFO0FBQ3RFLFNBQU8sSUFBSUMsT0FBSixDQUFvQixDQUFDQyxPQUFELEVBQVVDLE1BQVYsS0FBcUI7QUFDNUNOLElBQUFBLElBQUksQ0FBQ08sS0FBTCxDQUFXSixPQUFYLEVBQW9CLENBQUNLLEdBQUQsRUFBTUMsTUFBTixLQUFpQjtBQUNqQyxVQUFJRCxHQUFKLEVBQVM7QUFDTEYsUUFBQUEsTUFBTSxDQUFDRSxHQUFELENBQU47QUFDSCxPQUZELE1BRU87QUFDSEgsUUFBQUEsT0FBTyxDQUFDSSxNQUFELENBQVA7QUFDSDtBQUNKLEtBTkQ7QUFPSCxHQVJNLENBQVA7QUFTSDs7QUFFTSxlQUFlQyxXQUFmLENBQ0hDLEdBREcsRUFFSEMsTUFGRyxFQUdIQyxhQUhHLEVBSUhDLGtCQUpHLEVBS0hDLGFBTEcsRUFNSEMsY0FORyxFQU9IQyxZQUFxQixHQUFHLDhCQVByQixFQVFIQyxpQkFSRyxFQVNVO0FBQ2IsUUFBTUMsTUFBTSxHQUFHRixZQUFZLENBQUNHLFVBQWIsQ0FBeUIsV0FBVVQsR0FBSSxFQUF2QyxDQUFmOztBQUNBLFFBQU1VLDBCQUEwQixHQUFHQyxPQUFPLENBQUNqQixPQUFSLGlFQUFuQzs7QUFFQSxRQUFNa0IsT0FBMEMsR0FBRztBQUMvQ1osSUFBQUEsR0FBRyxFQUFFQSxHQUQwQztBQUUvQ0ksSUFBQUEsYUFBYSxFQUFFQSxhQUZnQztBQUcvQ1MsSUFBQUEsa0JBQWtCLEVBQUVDLGNBQUtDLElBQUwsQ0FBVWIsYUFBVixFQUF5QixPQUF6QixDQUgyQjtBQUkvQ2MsSUFBQUEsc0JBQXNCLEVBQUViLGtCQUp1QjtBQUsvQ2MsSUFBQUEsS0FBSyxFQUFFWixjQUFjLEdBQUcsQ0FBQyxhQUFELENBQUgsR0FBcUIsQ0FBQyxZQUFELEVBQWUsYUFBZixDQUxLO0FBTS9DRSxJQUFBQSxpQkFBaUIsRUFBRUE7QUFONEIsR0FBbkQ7QUFTQSxRQUFNVyxNQUFNLEdBQUcsK0JBQWlCVixNQUFqQixFQUF5QixTQUF6QixDQUFmO0FBRUEsUUFBTVcsZ0JBQWdCLEdBQUcsTUFBTTVCLFNBQVMsQ0FBRSxlQUFjUyxHQUFJLFFBQXBCLENBQXhDOztBQUNBLFFBQU1vQixzQkFBc0IsR0FBR04sY0FBS0MsSUFBTCxDQUFVSSxnQkFBVixFQUE0QixtQkFBNUIsQ0FBL0I7O0FBQ0EsUUFBTSw2QkFDRkMsc0JBREUsRUFFRDtBQUNULCtCQUErQkMsSUFBSSxDQUFDQyxTQUFMLENBQWVaLDBCQUFmLENBQTJDO0FBQzFFLGdDQUFnQ1csSUFBSSxDQUFDQyxTQUFMLENBQWVWLE9BQWYsQ0FBd0IsR0FKOUMsRUFLRixNQUxFLENBQU47O0FBT0EsUUFBTVcsdUJBQXVCLEdBQUdULGNBQUtDLElBQUwsQ0FBVUosT0FBTyxDQUFDakIsT0FBUixDQUFnQixTQUFoQixDQUFWLEVBQXNDLElBQXRDLEVBQTRDLElBQTVDLEVBQWtELElBQWxELEVBQXdELE1BQXhELEVBQWdFLFNBQWhFLENBQWhDOztBQUNBLFFBQU0saUNBQWlCYyxNQUFqQixFQUEwQixHQUFFZSx1QkFBd0IsYUFBWUgsc0JBQXVCLEVBQXZGLEVBQTBGO0FBQzVGSSxJQUFBQSxPQUFPLEVBQUUsZ0JBRG1GO0FBRTVGQyxJQUFBQSxHQUFHLEVBQUVYLGNBQUtZLE9BQUwsQ0FBYU4sc0JBQWI7QUFGdUYsR0FBMUYsQ0FBTjtBQUtBRixFQUFBQSxNQUFNLENBQUNTLFFBQVA7QUFDSCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCI7XG5cbmltcG9ydCAqIGFzIHRlbXAgZnJvbSBcInRlbXBcIjtcblxuaW1wb3J0IHsgZXhlY0NvbW1hbmRBc3luYyB9IGZyb20gXCIuLi8uLi9Db21tb25zL0V4ZWNVdGlsc1wiO1xuaW1wb3J0IHsgd3JpdGVGaWxlQXN5bmMgfSBmcm9tIFwiLi4vLi4vQ29tbW9ucy9Gc1V0aWxzXCI7XG5pbXBvcnQgeyBidWlsZEFjdGlvbkJlZ2luLCBJTG9nZ2VyIH0gZnJvbSBcIi4uLy4uL0NvbW1vbnMvTG9nZ2luZy9JTG9nZ2VyXCI7XG5pbXBvcnQgeyBnZXRMb2dnZXIgfSBmcm9tIFwiLi4vLi4vQ29tbW9ucy9Mb2dnaW5nL1N0YXRpY0xvZ2dlclwiO1xuaW1wb3J0IHsgQ3JlYXRlV2VicGFja0NvbmZpZ3VyYXRpb25PcHRpb25zIH0gZnJvbSBcIi4uLy4uL0Zvcm1XZWJwYWNrQ29uZmlndXJhdGlvbi9jcmVhdGVGb3JtV2VicGFja0NvbmZpZ3VyYXRpb25cIjtcbmltcG9ydCB7IEZvcm1CdWlsZENhY2hlT3B0aW9ucyB9IGZyb20gXCIuLi8uLi9Gb3JtV2VicGFja0NvbmZpZ3VyYXRpb24vQ2FjaGVBc3NldHNQbHVnaW5cIjtcblxudGVtcC50cmFjaygpO1xuXG5mdW5jdGlvbiB0ZW1wTUtEaXIoYWZmaXhlcz86IHN0cmluZyB8IHRlbXAuQWZmaXhPcHRpb25zKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICByZXR1cm4gbmV3IFByb21pc2U8c3RyaW5nPigocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICAgIHRlbXAubWtkaXIoYWZmaXhlcywgKGVyciwgcmVzdWx0KSA9PiB7XG4gICAgICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgICAgICAgcmVqZWN0KGVycik7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHJlc29sdmUocmVzdWx0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfSk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjb21waWxlRm9ybShcbiAgICBnZnY6IHN0cmluZyxcbiAgICB0aGVtZXM6IHVuZGVmaW5lZCB8IHN0cmluZ1tdLFxuICAgIGZhcm1EaXJlY3Rvcnk6IHN0cmluZyxcbiAgICByZXNvdXJjZXNEaXJlY3Rvcnk6IHN0cmluZyxcbiAgICByZXNvdXJjZXNIYXNoOiBzdHJpbmcsXG4gICAgYnVpbGREZWJ1Z09ubHk6IGJvb2xlYW4sXG4gICAgcGFyZW50TG9nZ2VyOiBJTG9nZ2VyID0gZ2V0TG9nZ2VyKCksXG4gICAgYnVpbGRDYWNoZU9wdGlvbnM/OiBGb3JtQnVpbGRDYWNoZU9wdGlvbnNcbik6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGxvZ2dlciA9IHBhcmVudExvZ2dlci53aXRoUHJlZml4KGBDT01QSUxFOiR7Z2Z2fWApO1xuICAgIGNvbnN0IHBhdGhUb1dlYnBhY2tDb25maWdGYWN0b3J5ID0gcmVxdWlyZS5yZXNvbHZlKFwiLi4vLi4vRm9ybVdlYnBhY2tDb25maWd1cmF0aW9uL2NyZWF0ZUZvcm1XZWJwYWNrQ29uZmlndXJhdGlvblwiKTtcblxuICAgIGNvbnN0IG9wdGlvbnM6IENyZWF0ZVdlYnBhY2tDb25maWd1cmF0aW9uT3B0aW9ucyA9IHtcbiAgICAgICAgZ2Z2OiBnZnYsXG4gICAgICAgIHJlc291cmNlc0hhc2g6IHJlc291cmNlc0hhc2gsXG4gICAgICAgIGZvcm1zRGlyZWN0b3J5UGF0aDogcGF0aC5qb2luKGZhcm1EaXJlY3RvcnksIFwiZm9ybXNcIiksXG4gICAgICAgIHJlc291cmNlc0RpcmVjdG9yeVBhdGg6IHJlc291cmNlc0RpcmVjdG9yeSxcbiAgICAgICAgbW9kZXM6IGJ1aWxkRGVidWdPbmx5ID8gW1wiZGV2ZWxvcG1lbnRcIl0gOiBbXCJwcm9kdWN0aW9uXCIsIFwiZGV2ZWxvcG1lbnRcIl0sXG4gICAgICAgIGJ1aWxkQ2FjaGVPcHRpb25zOiBidWlsZENhY2hlT3B0aW9ucyxcbiAgICB9O1xuXG4gICAgY29uc3QgYWN0aW9uID0gYnVpbGRBY3Rpb25CZWdpbihsb2dnZXIsIFwiQ29tcGlsZVwiKTtcblxuICAgIGNvbnN0IGZvcm1CdWlsZFRlbXBEaXIgPSBhd2FpdCB0ZW1wTUtEaXIoYGNhbmR5LWZvcm1zLSR7Z2Z2fS1idWlsZGApO1xuICAgIGNvbnN0IGZvcm1CdWlsZFdlYnBhY2tDb25maWcgPSBwYXRoLmpvaW4oZm9ybUJ1aWxkVGVtcERpciwgXCJ3ZWJwYWNrLmNvbmZpZy5qc1wiKTtcbiAgICBhd2FpdCB3cml0ZUZpbGVBc3luYyhcbiAgICAgICAgZm9ybUJ1aWxkV2VicGFja0NvbmZpZyxcbiAgICAgICAgYFxuY29uc3QgY3JlYXRlQ29uZmlnID0gcmVxdWlyZSgke0pTT04uc3RyaW5naWZ5KHBhdGhUb1dlYnBhY2tDb25maWdGYWN0b3J5KX0pLmNyZWF0ZUNvbmZpZztcbm1vZHVsZS5leHBvcnRzID0gY3JlYXRlQ29uZmlnKCR7SlNPTi5zdHJpbmdpZnkob3B0aW9ucyl9KWAsXG4gICAgICAgIFwidXRmOFwiXG4gICAgKTtcbiAgICBjb25zdCBwYXRoVG9XZWJQYWNrRXhlY3V0YWJsZSA9IHBhdGguam9pbihyZXF1aXJlLnJlc29sdmUoXCJ3ZWJwYWNrXCIpLCBcIi4uXCIsIFwiLi5cIiwgXCIuLlwiLCBcIi5iaW5cIiwgXCJ3ZWJwYWNrXCIpO1xuICAgIGF3YWl0IGV4ZWNDb21tYW5kQXN5bmMobG9nZ2VyLCBgJHtwYXRoVG9XZWJQYWNrRXhlY3V0YWJsZX0gLS1jb25maWcgJHtmb3JtQnVpbGRXZWJwYWNrQ29uZmlnfWAsIHtcbiAgICAgICAgY2FwdGlvbjogXCJDb21waWxpbmcgZm9ybVwiLFxuICAgICAgICBjd2Q6IHBhdGguZGlybmFtZShmb3JtQnVpbGRXZWJwYWNrQ29uZmlnKSxcbiAgICB9KTtcblxuICAgIGFjdGlvbi5jb21wbGV0ZSgpO1xufVxuIl19
76
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0Zvcm0vQ29tcGlsZUZvcm0udHMiXSwibmFtZXMiOlsidGVtcE1LRGlyIiwiYWZmaXhlcyIsIlByb21pc2UiLCJyZXNvbHZlIiwicmVqZWN0IiwidGVtcCIsIm1rZGlyIiwiZXJyIiwicmVzdWx0IiwiY29tcGlsZUZvcm0iLCJnZnYiLCJ0aGVtZXMiLCJmYXJtRGlyZWN0b3J5IiwicmVzb3VyY2VzRGlyZWN0b3J5IiwicmVzb3VyY2VzSGFzaCIsImJ1aWxkRGVidWdPbmx5IiwicGFyZW50TG9nZ2VyIiwiYnVpbGRDYWNoZU9wdGlvbnMiLCJsb2dnZXIiLCJ3aXRoUHJlZml4IiwicGF0aFRvV2VicGFja0NvbmZpZ0ZhY3RvcnkiLCJyZXF1aXJlIiwib3B0aW9ucyIsImZvcm1zRGlyZWN0b3J5UGF0aCIsInBhdGgiLCJqb2luIiwicmVzb3VyY2VzRGlyZWN0b3J5UGF0aCIsIm1vZGVzIiwiYWN0aW9uIiwiZm9ybUJ1aWxkVGVtcERpciIsImxvZyIsImZvcm1CdWlsZFdlYnBhY2tDb25maWciLCJKU09OIiwic3RyaW5naWZ5IiwicGF0aFRvV2ViUGFja0V4ZWN1dGFibGUiLCJ6enoiLCJjYXB0aW9uIiwiY3dkIiwiZGlybmFtZSIsImNvbXBsZXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7O0FBSUE7QUFFQSxTQUFTQSxTQUFULENBQW1CQyxPQUFuQixFQUEwRTtBQUN0RSxTQUFPLElBQUlDLE9BQUosQ0FBb0IsQ0FBQ0MsT0FBRCxFQUFVQyxNQUFWLEtBQXFCO0FBQzVDQyxJQUFBQSxJQUFJLENBQUNDLEtBQUwsQ0FBV0wsT0FBWCxFQUFvQixDQUFDTSxHQUFELEVBQU1DLE1BQU4sS0FBaUI7QUFDakMsVUFBSUQsR0FBSixFQUFTO0FBQ0xILFFBQUFBLE1BQU0sQ0FBQ0csR0FBRCxDQUFOO0FBQ0gsT0FGRCxNQUVPO0FBQ0hKLFFBQUFBLE9BQU8sQ0FBQ0ssTUFBRCxDQUFQO0FBQ0g7QUFDSixLQU5EO0FBT0gsR0FSTSxDQUFQO0FBU0g7O0FBRU0sZUFBZUMsV0FBZixDQUNIQyxHQURHLEVBRUhDLE1BRkcsRUFHSEMsYUFIRyxFQUlIQyxrQkFKRyxFQUtIQyxhQUxHLEVBTUhDLGNBTkcsRUFPSEMsWUFBcUIsR0FBRyw4QkFQckIsRUFRSEMsaUJBUkcsRUFTVTtBQUNiLFFBQU1DLE1BQU0sR0FBR0YsWUFBWSxDQUFDRyxVQUFiLENBQXlCLFdBQVVULEdBQUksRUFBdkMsQ0FBZjs7QUFDQSxRQUFNVSwwQkFBMEIsR0FBR0MsT0FBTyxDQUFDbEIsT0FBUixpRUFBbkM7O0FBRUEsUUFBTW1CLE9BQTBDLEdBQUc7QUFDL0NaLElBQUFBLEdBQUcsRUFBRUEsR0FEMEM7QUFFL0NJLElBQUFBLGFBQWEsRUFBRUEsYUFGZ0M7QUFHL0NTLElBQUFBLGtCQUFrQixFQUFFQyxjQUFLQyxJQUFMLENBQVViLGFBQVYsRUFBeUIsT0FBekIsQ0FIMkI7QUFJL0NjLElBQUFBLHNCQUFzQixFQUFFYixrQkFKdUI7QUFLL0NjLElBQUFBLEtBQUssRUFBRVosY0FBYyxHQUFHLENBQUMsYUFBRCxDQUFILEdBQXFCLENBQUMsWUFBRCxFQUFlLGFBQWYsQ0FMSztBQU0vQ0UsSUFBQUEsaUJBQWlCLEVBQUVBO0FBTjRCLEdBQW5EO0FBU0EsUUFBTVcsTUFBTSxHQUFHLCtCQUFpQlYsTUFBakIsRUFBeUIsU0FBekIsQ0FBZjtBQUVBLFFBQU1XLGdCQUFnQixHQUFHLE1BQU03QixTQUFTLENBQUUsZUFBY1UsR0FBSSxRQUFwQixDQUF4QztBQUNBUSxFQUFBQSxNQUFNLENBQUNZLEdBQVAsQ0FBVywwREFBWDtBQUNBWixFQUFBQSxNQUFNLENBQUNZLEdBQVAsQ0FBV0QsZ0JBQVg7QUFDQVgsRUFBQUEsTUFBTSxDQUFDWSxHQUFQLENBQVcsMERBQVg7O0FBQ0EsUUFBTUMsc0JBQXNCLEdBQUdQLGNBQUtDLElBQUwsQ0FBVUksZ0JBQVYsRUFBNEIsbUJBQTVCLENBQS9COztBQUNBLFFBQU0sNkJBQ0ZFLHNCQURFLEVBRUQ7QUFDVCwrQkFBK0JDLElBQUksQ0FBQ0MsU0FBTCxDQUFlYiwwQkFBZixDQUEyQztBQUMxRSxnQ0FBZ0NZLElBQUksQ0FBQ0MsU0FBTCxDQUFlWCxPQUFmLENBQXdCLEdBSjlDLEVBS0YsTUFMRSxDQUFOOztBQU9BLFFBQU1ZLHVCQUF1QixHQUFHVixjQUFLQyxJQUFMLENBQVVKLE9BQU8sQ0FBQ2xCLE9BQVIsQ0FBZ0IsU0FBaEIsQ0FBVixFQUFzQyxJQUF0QyxFQUE0QyxJQUE1QyxFQUFrRCxJQUFsRCxFQUF3RCxNQUF4RCxFQUFnRSxTQUFoRSxDQUFoQzs7QUFDQSxRQUFNZ0MsR0FBRyxHQUFJLEdBQUVELHVCQUF3QixhQUFZSCxzQkFBdUIsRUFBMUU7QUFDQWIsRUFBQUEsTUFBTSxDQUFDWSxHQUFQLENBQVcscURBQVg7QUFDQVosRUFBQUEsTUFBTSxDQUFDWSxHQUFQLENBQVdLLEdBQVg7QUFDQWpCLEVBQUFBLE1BQU0sQ0FBQ1ksR0FBUCxDQUFXLHlEQUFYO0FBQ0EsUUFBTSxpQ0FBaUJaLE1BQWpCLEVBQXlCaUIsR0FBekIsRUFBOEI7QUFDaENDLElBQUFBLE9BQU8sRUFBRSxnQkFEdUI7QUFFaENDLElBQUFBLEdBQUcsRUFBRWIsY0FBS2MsT0FBTCxDQUFhUCxzQkFBYjtBQUYyQixHQUE5QixDQUFOO0FBS0FILEVBQUFBLE1BQU0sQ0FBQ1csUUFBUDtBQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHBhdGggZnJvbSBcInBhdGhcIjtcblxuaW1wb3J0ICogYXMgdGVtcCBmcm9tIFwidGVtcFwiO1xuXG5pbXBvcnQgeyBleGVjQ29tbWFuZEFzeW5jIH0gZnJvbSBcIi4uLy4uL0NvbW1vbnMvRXhlY1V0aWxzXCI7XG5pbXBvcnQgeyB3cml0ZUZpbGVBc3luYyB9IGZyb20gXCIuLi8uLi9Db21tb25zL0ZzVXRpbHNcIjtcbmltcG9ydCB7IGJ1aWxkQWN0aW9uQmVnaW4sIElMb2dnZXIgfSBmcm9tIFwiLi4vLi4vQ29tbW9ucy9Mb2dnaW5nL0lMb2dnZXJcIjtcbmltcG9ydCB7IGdldExvZ2dlciB9IGZyb20gXCIuLi8uLi9Db21tb25zL0xvZ2dpbmcvU3RhdGljTG9nZ2VyXCI7XG5pbXBvcnQgeyBDcmVhdGVXZWJwYWNrQ29uZmlndXJhdGlvbk9wdGlvbnMgfSBmcm9tIFwiLi4vLi4vRm9ybVdlYnBhY2tDb25maWd1cmF0aW9uL2NyZWF0ZUZvcm1XZWJwYWNrQ29uZmlndXJhdGlvblwiO1xuaW1wb3J0IHsgRm9ybUJ1aWxkQ2FjaGVPcHRpb25zIH0gZnJvbSBcIi4uLy4uL0Zvcm1XZWJwYWNrQ29uZmlndXJhdGlvbi9DYWNoZUFzc2V0c1BsdWdpblwiO1xuXG4vLyB0ZW1wLnRyYWNrKCk7XG5cbmZ1bmN0aW9uIHRlbXBNS0RpcihhZmZpeGVzPzogc3RyaW5nIHwgdGVtcC5BZmZpeE9wdGlvbnMpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZTxzdHJpbmc+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgICAgdGVtcC5ta2RpcihhZmZpeGVzLCAoZXJyLCByZXN1bHQpID0+IHtcbiAgICAgICAgICAgIGlmIChlcnIpIHtcbiAgICAgICAgICAgICAgICByZWplY3QoZXJyKTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgcmVzb2x2ZShyZXN1bHQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9KTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGNvbXBpbGVGb3JtKFxuICAgIGdmdjogc3RyaW5nLFxuICAgIHRoZW1lczogdW5kZWZpbmVkIHwgc3RyaW5nW10sXG4gICAgZmFybURpcmVjdG9yeTogc3RyaW5nLFxuICAgIHJlc291cmNlc0RpcmVjdG9yeTogc3RyaW5nLFxuICAgIHJlc291cmNlc0hhc2g6IHN0cmluZyxcbiAgICBidWlsZERlYnVnT25seTogYm9vbGVhbixcbiAgICBwYXJlbnRMb2dnZXI6IElMb2dnZXIgPSBnZXRMb2dnZXIoKSxcbiAgICBidWlsZENhY2hlT3B0aW9ucz86IEZvcm1CdWlsZENhY2hlT3B0aW9uc1xuKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgbG9nZ2VyID0gcGFyZW50TG9nZ2VyLndpdGhQcmVmaXgoYENPTVBJTEU6JHtnZnZ9YCk7XG4gICAgY29uc3QgcGF0aFRvV2VicGFja0NvbmZpZ0ZhY3RvcnkgPSByZXF1aXJlLnJlc29sdmUoXCIuLi8uLi9Gb3JtV2VicGFja0NvbmZpZ3VyYXRpb24vY3JlYXRlRm9ybVdlYnBhY2tDb25maWd1cmF0aW9uXCIpO1xuXG4gICAgY29uc3Qgb3B0aW9uczogQ3JlYXRlV2VicGFja0NvbmZpZ3VyYXRpb25PcHRpb25zID0ge1xuICAgICAgICBnZnY6IGdmdixcbiAgICAgICAgcmVzb3VyY2VzSGFzaDogcmVzb3VyY2VzSGFzaCxcbiAgICAgICAgZm9ybXNEaXJlY3RvcnlQYXRoOiBwYXRoLmpvaW4oZmFybURpcmVjdG9yeSwgXCJmb3Jtc1wiKSxcbiAgICAgICAgcmVzb3VyY2VzRGlyZWN0b3J5UGF0aDogcmVzb3VyY2VzRGlyZWN0b3J5LFxuICAgICAgICBtb2RlczogYnVpbGREZWJ1Z09ubHkgPyBbXCJkZXZlbG9wbWVudFwiXSA6IFtcInByb2R1Y3Rpb25cIiwgXCJkZXZlbG9wbWVudFwiXSxcbiAgICAgICAgYnVpbGRDYWNoZU9wdGlvbnM6IGJ1aWxkQ2FjaGVPcHRpb25zLFxuICAgIH07XG5cbiAgICBjb25zdCBhY3Rpb24gPSBidWlsZEFjdGlvbkJlZ2luKGxvZ2dlciwgXCJDb21waWxlXCIpO1xuXG4gICAgY29uc3QgZm9ybUJ1aWxkVGVtcERpciA9IGF3YWl0IHRlbXBNS0RpcihgY2FuZHktZm9ybXMtJHtnZnZ9LWJ1aWxkYCk7XG4gICAgbG9nZ2VyLmxvZyhcIj09PSDQstGB0LUg0LrQvtC80L/QvtC90LXQvdGC0Ysg0LTQu9GPINCx0LjQu9C00LAg0L3QsNGF0L7QtNGP0YLRgdGPINCyINGN0YLQvtC5INC/0LDQv9C60LUgPT09PVwiKTtcbiAgICBsb2dnZXIubG9nKGZvcm1CdWlsZFRlbXBEaXIpO1xuICAgIGxvZ2dlci5sb2coXCI9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVwiKTtcbiAgICBjb25zdCBmb3JtQnVpbGRXZWJwYWNrQ29uZmlnID0gcGF0aC5qb2luKGZvcm1CdWlsZFRlbXBEaXIsIFwid2VicGFjay5jb25maWcuanNcIik7XG4gICAgYXdhaXQgd3JpdGVGaWxlQXN5bmMoXG4gICAgICAgIGZvcm1CdWlsZFdlYnBhY2tDb25maWcsXG4gICAgICAgIGBcbmNvbnN0IGNyZWF0ZUNvbmZpZyA9IHJlcXVpcmUoJHtKU09OLnN0cmluZ2lmeShwYXRoVG9XZWJwYWNrQ29uZmlnRmFjdG9yeSl9KS5jcmVhdGVDb25maWc7XG5tb2R1bGUuZXhwb3J0cyA9IGNyZWF0ZUNvbmZpZygke0pTT04uc3RyaW5naWZ5KG9wdGlvbnMpfSlgLFxuICAgICAgICBcInV0ZjhcIlxuICAgICk7XG4gICAgY29uc3QgcGF0aFRvV2ViUGFja0V4ZWN1dGFibGUgPSBwYXRoLmpvaW4ocmVxdWlyZS5yZXNvbHZlKFwid2VicGFja1wiKSwgXCIuLlwiLCBcIi4uXCIsIFwiLi5cIiwgXCIuYmluXCIsIFwid2VicGFja1wiKTtcbiAgICBjb25zdCB6enogPSBgJHtwYXRoVG9XZWJQYWNrRXhlY3V0YWJsZX0gLS1jb25maWcgJHtmb3JtQnVpbGRXZWJwYWNrQ29uZmlnfWA7XG4gICAgbG9nZ2VyLmxvZyhcIj09PT09PT09PT09PT09INCa0L7QvNCw0L3QtNCwINC90LAg0LjRgdC/0L7Qu9C90LXQvdC40LUgPT09PT09PT09PT09PT1cIik7XG4gICAgbG9nZ2VyLmxvZyh6enopO1xuICAgIGxvZ2dlci5sb2coXCI9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XCIpO1xuICAgIGF3YWl0IGV4ZWNDb21tYW5kQXN5bmMobG9nZ2VyLCB6enosIHtcbiAgICAgICAgY2FwdGlvbjogXCJDb21waWxpbmcgZm9ybVwiLFxuICAgICAgICBjd2Q6IHBhdGguZGlybmFtZShmb3JtQnVpbGRXZWJwYWNrQ29uZmlnKSxcbiAgICB9KTtcblxuICAgIGFjdGlvbi5jb21wbGV0ZSgpO1xufVxuIl19
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.GeneratorSourcesImporter = void 0;
6
+ exports.GeneratorSourcesValidator = exports.GeneratorSourcesImporter = void 0;
7
7
 
8
8
  var path = _interopRequireWildcard(require("path"));
9
9
 
@@ -15,6 +15,8 @@ var _EngineStructureUtils = require("../../EngineStructureUtils");
15
15
 
16
16
  var _ReadFormSource = require("../../ReadFormSource");
17
17
 
18
+ var _ToolsApiClient = require("../../../Commons/ApiClient/ToolsApiClient");
19
+
18
20
  var _RequireUncached = require("./RequireUncached");
19
21
 
20
22
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
@@ -98,4 +100,45 @@ class GeneratorSourcesImporter {
98
100
  }
99
101
 
100
102
  exports.GeneratorSourcesImporter = GeneratorSourcesImporter;
101
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../src/BuildTasks/Generator/GeneratorWorker/GeneratorRequireUtils.ts"],"names":["GeneratorSourcesImporter","constructor","purgeCache","importReadSources","pathToGenerator","readSourcesPath","path","join","requireUncachedDefault","readFormSource","generatorMain","requireUncachedAllNamed","importGetAllDependencies","undefined","importGetAllDependenciesHash","importProcessSugar","processSugarPath","require","default","importLocalization","localizationEntryPointPath","module"],"mappings":";;;;;;;AACA;;AAEA;;AAEA;;AACA;;AAEA;;AAEA;;;;;;AAVA;AAkBO,MAAMA,wBAAN,CAA+B;AAG3BC,EAAAA,WAAW,CAACC,UAAD,EAAsB;AAAA,SAFvBA,UAEuB;AACpC,SAAKA,UAAL,GAAkBA,UAAlB;AACH;;AAE6B,QAAjBC,iBAAiB,CAACC,eAAD,EAAiE;AAC3F,QAAI,MAAM,0DAA+BA,eAA/B,CAAV,EAA2D;AACvD,YAAMC,eAAe,GAAGC,IAAI,CAACC,IAAL,CAAUH,eAAV,EAA2B,MAA3B,EAAmC,YAAnC,EAAiD,gBAAjD,CAAxB;;AAEA,UAAI,MAAM,2BAAaC,eAAb,CAAV,EAAyC;AACrC,eAAO,KAAKG,sBAAL,CAA4BH,eAA5B,CAAP;AACH,OAFD,MAEO;AACH,eAAOI,8BAAP;AACH;AACJ,KARD,MAQO;AACH,YAAMC,aAAa,GAAG,KAAKC,uBAAL,CAA6BP,eAA7B,CAAtB;AACA,aAAOM,aAAa,CAAC,aAAD,CAApB;AACH;AACJ;;AAEoC,QAAxBE,wBAAwB,CACjCR,eADiC,EAEuB;AACxD,QAAI,MAAM,0DAA+BA,eAA/B,CAAV,EAA2D;AACvD,aAAOS,SAAP;AACH;;AACD,UAAMH,aAAa,GAAG,KAAKC,uBAAL,CAA6BP,eAA7B,CAAtB;AACA,WAAOM,aAAa,CAAC,oBAAD,CAApB;AACH;;AAEwC,QAA5BI,4BAA4B,CACrCV,eADqC,EAEuB;AAC5D,QAAI,MAAM,0DAA+BA,eAA/B,CAAV,EAA2D;AACvD,aAAOS,SAAP;AACH;;AACD,UAAMH,aAAa,GAAG,KAAKC,uBAAL,CAA6BP,eAA7B,CAAtB;AACA,WAAOM,aAAa,CAAC,wBAAD,CAApB;AACH;;AAE8B,QAAlBK,kBAAkB,CAACX,eAAD,EAAqD;AAChF,QAAI,MAAM,0DAA+BA,eAA/B,CAAV,EAA2D;AACvD,YAAMY,gBAAgB,GAAGV,IAAI,CAACC,IAAL,CAAUH,eAAV,EAA2B,MAA3B,EAAmC,YAAnC,EAAiD,iBAAjD,CAAzB,CADuD,CAEvD;;AACA,aAAOa,OAAO,CAACD,gBAAD,CAAP,CAA0BE,OAAjC;AACH,KAJD,MAIO;AACH,YAAMR,aAAa,GAAG,KAAKC,uBAAL,CAA6BP,eAA7B,CAAtB;AACA,aAAOM,aAAa,CAAC,cAAD,CAApB;AACH;AACJ;;AAE8B,QAAlBS,kBAAkB,CAACf,eAAD,EAAuE;AAClG,QAAI,MAAM,0DAA+BA,eAA/B,CAAV,EAA2D;AACvD,YAAMgB,0BAA0B,GAAGd,IAAI,CAACC,IAAL,CAAUH,eAAV,EAA2B,MAA3B,EAAmC,YAAnC,EAAiD,iBAAjD,CAAnC;;AACA,UAAI,EAAE,MAAM,yBAAWgB,0BAAX,CAAR,CAAJ,EAAqD;AACjD,eAAOP,SAAP;AACH;;AACD,aAAOI,OAAO,CAACG,0BAAD,CAAd;AACH,KAND,MAMO;AACH,YAAMV,aAAa,GAAG,KAAKC,uBAAL,CAA6BP,eAA7B,CAAtB;AACA,aAAOM,aAAa,CAAC,cAAD,CAApB;AACH;AACJ;;AACOF,EAAAA,sBAAsB,CAACa,MAAD,EAAuC;AACjE,WAAO,6CAAuBA,MAAvB,EAA+B,KAAKnB,UAApC,CAAP;AACH;;AAEOS,EAAAA,uBAAuB,CAACU,MAAD,EAAuC;AAClE,WAAO,8CAAwBA,MAAxB,EAAgC,KAAKnB,UAArC,CAAP;AACH;;AAvEiC","sourcesContent":["/* eslint-disable @typescript-eslint/no-unsafe-return */\nimport * as path from \"path\";\n\nimport { pathExists } from \"fs-extra\";\n\nimport { isFileExists } from \"../../../Commons/FsUtils\";\nimport { isOldGeneratorSourcesStructure } from \"../../EngineStructureUtils\";\nimport { FormGenerator, GeneratedForm, GenerationOptions, LocalizationEntryPoint } from \"../../Form/GenerateForm\";\nimport { FormResources, readFormSource, SugarContent } from \"../../ReadFormSource\";\n\nimport { RequireDefaultResult, requireUncachedAllNamed, requireUncachedDefault } from \"./RequireUncached\";\n\ntype ProcessSugarFunc = (\n    sugarFiles: SugarContent,\n    resources: FormResources,\n    generationOptions?: GenerationOptions\n) => GeneratedForm | Promise<GeneratedForm>;\n\nexport class GeneratorSourcesImporter {\n    private readonly purgeCache: boolean;\n\n    public constructor(purgeCache: boolean) {\n        this.purgeCache = purgeCache;\n    }\n\n    public async importReadSources(pathToGenerator: string): Promise<FormGenerator[\"readSources\"]> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            const readSourcesPath = path.join(pathToGenerator, \"dist\", \"generators\", \"readSources.js\");\n\n            if (await isFileExists(readSourcesPath)) {\n                return this.requireUncachedDefault(readSourcesPath);\n            } else {\n                return readFormSource;\n            }\n        } else {\n            const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n            return generatorMain[\"readSources\"];\n        }\n    }\n\n    public async importGetAllDependencies(\n        pathToGenerator: string\n    ): Promise<FormGenerator[\"getAllDependencies\"] | undefined> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            return undefined;\n        }\n        const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n        return generatorMain[\"getAllDependencies\"];\n    }\n\n    public async importGetAllDependenciesHash(\n        pathToGenerator: string\n    ): Promise<FormGenerator[\"getAllDependenciesHash\"] | undefined> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            return undefined;\n        }\n        const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n        return generatorMain[\"getAllDependenciesHash\"];\n    }\n\n    public async importProcessSugar(pathToGenerator: string): Promise<ProcessSugarFunc> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            const processSugarPath = path.join(pathToGenerator, \"dist\", \"generators\", \"processSugar.js\");\n            // eslint-disable-next-line @typescript-eslint/no-var-requires\n            return require(processSugarPath).default;\n        } else {\n            const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n            return generatorMain[\"processSugar\"];\n        }\n    }\n\n    public async importLocalization(pathToGenerator: string): Promise<undefined | LocalizationEntryPoint> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            const localizationEntryPointPath = path.join(pathToGenerator, \"dist\", \"generators\", \"localization.js\");\n            if (!(await pathExists(localizationEntryPointPath))) {\n                return undefined;\n            }\n            return require(localizationEntryPointPath);\n        } else {\n            const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n            return generatorMain[\"localization\"];\n        }\n    }\n    private requireUncachedDefault(module: string): RequireDefaultResult {\n        return requireUncachedDefault(module, this.purgeCache);\n    }\n\n    private requireUncachedAllNamed(module: string): RequireDefaultResult {\n        return requireUncachedAllNamed(module, this.purgeCache);\n    }\n}\n"]}
103
+
104
+ class GeneratorSourcesValidator {
105
+ constructor(generationOptions) {
106
+ this.isLocalDebug = void 0;
107
+ this.apiClient = void 0;
108
+
109
+ this.validate = async formContent => {
110
+ if (!this.isLocalDebug) {
111
+ return;
112
+ }
113
+
114
+ await this.compileNormalizationRulesOrDie(formContent);
115
+ };
116
+
117
+ this.compileNormalizationRulesOrDie = async formContent => {
118
+ var _compileResult$diagno, _compileResult$diagno2;
119
+
120
+ const normalizationRules = formContent["ServerSide.normalize"];
121
+
122
+ if (!normalizationRules || typeof normalizationRules !== "string") {
123
+ return;
124
+ }
125
+
126
+ const compileResult = await this.apiClient.compileNormalizationRules(normalizationRules, "formulas");
127
+
128
+ if (!compileResult || ((_compileResult$diagno = compileResult === null || compileResult === void 0 ? void 0 : (_compileResult$diagno2 = compileResult.diagnosticMessages) === null || _compileResult$diagno2 === void 0 ? void 0 : _compileResult$diagno2.length) !== null && _compileResult$diagno !== void 0 ? _compileResult$diagno : 0) == 0) {
129
+ return;
130
+ }
131
+
132
+ throw Error(`Invalid ServerSide.normalize:\r\n
133
+ ${JSON.stringify(compileResult.diagnosticMessages)}\r\n
134
+ ${compileResult.sourceText}`);
135
+ };
136
+
137
+ this.isLocalDebug = (generationOptions === null || generationOptions === void 0 ? void 0 : generationOptions.resourcesHash) == "local-hash";
138
+ this.apiClient = new _ToolsApiClient.ToolsApiClient();
139
+ }
140
+
141
+ }
142
+
143
+ exports.GeneratorSourcesValidator = GeneratorSourcesValidator;
144
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../src/BuildTasks/Generator/GeneratorWorker/GeneratorRequireUtils.ts"],"names":["GeneratorSourcesImporter","constructor","purgeCache","importReadSources","pathToGenerator","readSourcesPath","path","join","requireUncachedDefault","readFormSource","generatorMain","requireUncachedAllNamed","importGetAllDependencies","undefined","importGetAllDependenciesHash","importProcessSugar","processSugarPath","require","default","importLocalization","localizationEntryPointPath","module","GeneratorSourcesValidator","generationOptions","isLocalDebug","apiClient","validate","formContent","compileNormalizationRulesOrDie","normalizationRules","compileResult","compileNormalizationRules","diagnosticMessages","length","Error","JSON","stringify","sourceText","resourcesHash","ToolsApiClient"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-unsafe-return */\nimport * as path from \"path\";\n\nimport { pathExists } from \"fs-extra\";\n\nimport { isFileExists } from \"../../../Commons/FsUtils\";\nimport { isOldGeneratorSourcesStructure } from \"../../EngineStructureUtils\";\nimport { FormGenerator, GeneratedForm, GenerationOptions, LocalizationEntryPoint } from \"../../Form/GenerateForm\";\nimport { FormResources, readFormSource, SugarContent } from \"../../ReadFormSource\";\nimport { ToolsApiClient } from \"../../../Commons/ApiClient/ToolsApiClient\";\n\nimport { RequireDefaultResult, requireUncachedAllNamed, requireUncachedDefault } from \"./RequireUncached\";\n\ntype ProcessSugarFunc = (\n    sugarFiles: SugarContent,\n    resources: FormResources,\n    generationOptions?: GenerationOptions\n) => GeneratedForm | Promise<GeneratedForm>;\n\nexport class GeneratorSourcesImporter {\n    private readonly purgeCache: boolean;\n\n    public constructor(purgeCache: boolean) {\n        this.purgeCache = purgeCache;\n    }\n\n    public async importReadSources(pathToGenerator: string): Promise<FormGenerator[\"readSources\"]> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            const readSourcesPath = path.join(pathToGenerator, \"dist\", \"generators\", \"readSources.js\");\n\n            if (await isFileExists(readSourcesPath)) {\n                return this.requireUncachedDefault(readSourcesPath);\n            } else {\n                return readFormSource;\n            }\n        } else {\n            const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n            return generatorMain[\"readSources\"];\n        }\n    }\n\n    public async importGetAllDependencies(\n        pathToGenerator: string\n    ): Promise<FormGenerator[\"getAllDependencies\"] | undefined> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            return undefined;\n        }\n        const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n        return generatorMain[\"getAllDependencies\"];\n    }\n\n    public async importGetAllDependenciesHash(\n        pathToGenerator: string\n    ): Promise<FormGenerator[\"getAllDependenciesHash\"] | undefined> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            return undefined;\n        }\n        const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n        return generatorMain[\"getAllDependenciesHash\"];\n    }\n\n    public async importProcessSugar(pathToGenerator: string): Promise<ProcessSugarFunc> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            const processSugarPath = path.join(pathToGenerator, \"dist\", \"generators\", \"processSugar.js\");\n            // eslint-disable-next-line @typescript-eslint/no-var-requires\n            return require(processSugarPath).default;\n        } else {\n            const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n            return generatorMain[\"processSugar\"];\n        }\n    }\n\n    public async importLocalization(pathToGenerator: string): Promise<undefined | LocalizationEntryPoint> {\n        if (await isOldGeneratorSourcesStructure(pathToGenerator)) {\n            const localizationEntryPointPath = path.join(pathToGenerator, \"dist\", \"generators\", \"localization.js\");\n            if (!(await pathExists(localizationEntryPointPath))) {\n                return undefined;\n            }\n            return require(localizationEntryPointPath);\n        } else {\n            const generatorMain = this.requireUncachedAllNamed(pathToGenerator);\n            return generatorMain[\"localization\"];\n        }\n    }\n    private requireUncachedDefault(module: string): RequireDefaultResult {\n        return requireUncachedDefault(module, this.purgeCache);\n    }\n\n    private requireUncachedAllNamed(module: string): RequireDefaultResult {\n        return requireUncachedAllNamed(module, this.purgeCache);\n    }\n}\n\nexport class GeneratorSourcesValidator {\n    private readonly isLocalDebug: boolean;\n    private readonly apiClient: ToolsApiClient;\n\n    public constructor(generationOptions: GenerationOptions | undefined) {\n        this.isLocalDebug = generationOptions?.resourcesHash == \"local-hash\";\n        this.apiClient = new ToolsApiClient();\n    }\n\n    public validate = async (formContent: GeneratedForm): Promise<void> => {\n        if (!this.isLocalDebug) {\n            return;\n        }\n        await this.compileNormalizationRulesOrDie(formContent);\n    };\n\n    private readonly compileNormalizationRulesOrDie = async (formContent: GeneratedForm): Promise<void> => {\n        const normalizationRules = formContent[\"ServerSide.normalize\"];\n        if (!normalizationRules || typeof normalizationRules !== \"string\") {\n            return;\n        }\n        const compileResult = await this.apiClient.compileNormalizationRules(normalizationRules, \"formulas\");\n        if (!compileResult || (compileResult?.diagnosticMessages?.length ?? 0) == 0) {\n            return;\n        }\n\n        throw Error(\n            `Invalid ServerSide.normalize:\\r\\n\n             ${JSON.stringify(compileResult.diagnosticMessages)}\\r\\n\n             ${compileResult.sourceText}`\n        );\n    };\n}\n"]}
@@ -15,6 +15,8 @@ _TypedProcessWorker.TypedProcessWorker.start(async ([pathToGeneratorProcessSugar
15
15
  formSource = await readSources(formSourcesPath, farmDirectory, hlFarmDirectoryPath);
16
16
  const processSugar = await importer.importProcessSugar(pathToGeneratorProcessSugar);
17
17
  const formContent = await processSugar(formSource.sugarContent, formSource.resources, generationOptions);
18
+ const validator = new _GeneratorRequireUtils.GeneratorSourcesValidator(generationOptions);
19
+ await validator.validate(formContent);
18
20
  const result = {}; // NOTE Because only JSON are allowed for IPC we need to convert Buffer -> Base64
19
21
  // Another solution is use a stream, but formContent still need to convert or send by chunks
20
22
 
@@ -53,4 +55,4 @@ _TypedProcessWorker.TypedProcessWorker.start(async ([pathToGeneratorProcessSugar
53
55
  }
54
56
  }
55
57
  });
56
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0dlbmVyYXRvci9HZW5lcmF0b3JXb3JrZXIvUmVhZFNvdXJjZXNBbmRQcm9jZXNzU3VnYXJXb3JrZXIudHMiXSwibmFtZXMiOlsiVHlwZWRQcm9jZXNzV29ya2VyIiwic3RhcnQiLCJwYXRoVG9HZW5lcmF0b3JQcm9jZXNzU3VnYXIiLCJmb3JtU291cmNlc1BhdGgiLCJmYXJtRGlyZWN0b3J5IiwiaGxGYXJtRGlyZWN0b3J5UGF0aCIsImdlbmVyYXRpb25PcHRpb25zIiwicHVyZ2VDYWNoZSIsInJlcXVlc3ROdW1iZXIiLCJzZW5kIiwiZm9ybVNvdXJjZSIsImltcG9ydGVyIiwiR2VuZXJhdG9yU291cmNlc0ltcG9ydGVyIiwicmVhZFNvdXJjZXMiLCJpbXBvcnRSZWFkU291cmNlcyIsInByb2Nlc3NTdWdhciIsImltcG9ydFByb2Nlc3NTdWdhciIsImZvcm1Db250ZW50Iiwic3VnYXJDb250ZW50IiwicmVzb3VyY2VzIiwicmVzdWx0Iiwia2V5IiwiZm9ybUNvbnRlbnRJdGVtIiwiQnVmZmVyIiwicGF5bG9hZCIsInRvU3RyaW5nIiwiZW5jb2RpbmciLCJ0eXBlIiwiZ2Z2IiwiZ2VuZXJhdGVkRm9ybSIsImVycm9yIiwiRXJyb3IiLCJlcnJvclRleHQiLCJzdGFjayJdLCJtYXBwaW5ncyI6Ijs7QUFFQTs7QUFFQTs7QUFDQTs7QUFXQUEsdUNBQW1CQyxLQUFuQixDQUNJLE9BQ0ksQ0FDSUMsMkJBREosRUFFSUMsZUFGSixFQUdJQyxhQUhKLEVBSUlDLG1CQUpKLEVBS0lDLGlCQUxKLEVBTUlDLFVBTkosRUFPSUMsYUFQSixDQURKLEVBVUlDLElBVkosS0FXb0I7QUFDaEIsTUFBSUMsVUFBSjs7QUFDQSxNQUFJO0FBQ0EsVUFBTUMsUUFBUSxHQUFHLElBQUlDLCtDQUFKLENBQTZCTCxVQUE3QixDQUFqQjtBQUNBLFVBQU1NLFdBQVcsR0FBRyxNQUFNRixRQUFRLENBQUNHLGlCQUFULENBQTJCWiwyQkFBM0IsQ0FBMUI7QUFDQVEsSUFBQUEsVUFBVSxHQUFHLE1BQU1HLFdBQVcsQ0FBQ1YsZUFBRCxFQUFrQkMsYUFBbEIsRUFBaUNDLG1CQUFqQyxDQUE5QjtBQUVBLFVBQU1VLFlBQVksR0FBRyxNQUFNSixRQUFRLENBQUNLLGtCQUFULENBQTRCZCwyQkFBNUIsQ0FBM0I7QUFFQSxVQUFNZSxXQUEwQixHQUFHLE1BQU1GLFlBQVksQ0FDakRMLFVBQVUsQ0FBQ1EsWUFEc0MsRUFFakRSLFVBQVUsQ0FBQ1MsU0FGc0MsRUFHakRiLGlCQUhpRCxDQUFyRDtBQU1BLFVBQU1jLE1BQXdDLEdBQUcsRUFBakQsQ0FiQSxDQWVBO0FBQ0E7O0FBQ0EsU0FBSyxNQUFNLENBQUNDLEdBQUQsRUFBTUMsZUFBTixDQUFYLElBQXFDLG1DQUFlTCxXQUFmLENBQXJDLEVBQWtFO0FBQzlERyxNQUFBQSxNQUFNLENBQUNDLEdBQUQsQ0FBTixHQUNJQyxlQUFlLFlBQVlDLE1BQTNCLEdBQ007QUFBRUMsUUFBQUEsT0FBTyxFQUFFRixlQUFlLENBQUNHLFFBQWhCLENBQXlCLFFBQXpCLENBQVg7QUFBK0NDLFFBQUFBLFFBQVEsRUFBRTtBQUF6RCxPQUROLEdBRU1KLGVBSFY7QUFJSDs7QUFFRGIsSUFBQUEsSUFBSSxDQUFDO0FBQ0RrQixNQUFBQSxJQUFJLEVBQUUsUUFETDtBQUVEQyxNQUFBQSxHQUFHLEVBQUVsQixVQUFVLENBQUNTLFNBQVgsQ0FBcUJTLEdBRnpCO0FBR0RDLE1BQUFBLGFBQWEsRUFBRVQsTUFIZDtBQUlEWixNQUFBQSxhQUFhLEVBQUVBO0FBSmQsS0FBRCxDQUFKO0FBTUgsR0E5QkQsQ0E4QkUsT0FBT3NCLEtBQVAsRUFBYztBQUNaLFFBQUlBLEtBQUssWUFBWUMsS0FBckIsRUFBNEI7QUFBQTs7QUFDeEJ0QixNQUFBQSxJQUFJLENBQUM7QUFDRGtCLFFBQUFBLElBQUksRUFBRSxPQURMO0FBRURDLFFBQUFBLEdBQUcsaUJBQUVsQixVQUFGLGdEQUFFLFlBQVlTLFNBQVosQ0FBc0JTLEdBRjFCO0FBR0RJLFFBQUFBLFNBQVMsRUFBRyxHQUFFRixLQUFLLENBQUNMLFFBQU4sRUFBaUIsS0FBSUssS0FBSyxDQUFDRyxLQUFNLEVBSDlDO0FBSUR6QixRQUFBQSxhQUFhLEVBQUVBO0FBSmQsT0FBRCxDQUFKO0FBTUgsS0FQRCxNQU9PO0FBQUE7O0FBQ0hDLE1BQUFBLElBQUksQ0FBQztBQUNEa0IsUUFBQUEsSUFBSSxFQUFFLE9BREw7QUFFREMsUUFBQUEsR0FBRyxrQkFBRWxCLFVBQUYsaURBQUUsYUFBWVMsU0FBWixDQUFzQlMsR0FGMUI7QUFHREksUUFBQUEsU0FBUyxFQUFHLEdBQUVGLEtBQU0sRUFIbkI7QUFJRHRCLFFBQUFBLGFBQWEsRUFBRUE7QUFKZCxPQUFELENBQUo7QUFNSDtBQUNKO0FBQ0osQ0E3REwiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHZW5lcmF0ZWRGb3JtLCBHZW5lcmF0aW9uT3B0aW9ucyB9IGZyb20gXCIuLi8uLi9Gb3JtL0dlbmVyYXRlRm9ybVwiO1xuaW1wb3J0IHsgRm9ybVNvdXJjZSB9IGZyb20gXCIuLi8uLi9SZWFkRm9ybVNvdXJjZVwiO1xuaW1wb3J0IHsgaXRlcmF0ZUVudHJpZXMgfSBmcm9tIFwiLi4vLi4vLi4vLi4vLi4vQ29tbW9uL0l0ZXJhYmxlVXRpbHNcIjtcblxuaW1wb3J0IHsgR2VuZXJhdG9yU291cmNlc0ltcG9ydGVyIH0gZnJvbSBcIi4vR2VuZXJhdG9yUmVxdWlyZVV0aWxzXCI7XG5pbXBvcnQgeyBUeXBlZFByb2Nlc3NXb3JrZXIgfSBmcm9tIFwiLi9UeXBlZFByb2Nlc3NXb3JrZXJcIjtcblxuZXhwb3J0IGludGVyZmFjZSBHZW5lcmF0ZWRGb3JtSW50ZXJQcm9jZXNzTWVzc2FnZSB7XG4gICAgW3JlbGF0aXZlRmlsZU5hbWU6IHN0cmluZ106IHN0cmluZyB8IHsgcGF5bG9hZDogc3RyaW5nOyBlbmNvZGluZzogc3RyaW5nIH07XG59XG5cbmV4cG9ydCB0eXBlIENhbGxNZXNzYWdlID0gW3N0cmluZywgc3RyaW5nLCBzdHJpbmcsIHN0cmluZywgdW5kZWZpbmVkIHwgR2VuZXJhdGlvbk9wdGlvbnMsIGJvb2xlYW4sIG51bWJlcl07XG5leHBvcnQgdHlwZSBDYWxsUmVzcG9uc2UgPVxuICAgIHwgeyB0eXBlOiBcIlJlc3VsdFwiOyBnZnY6IHN0cmluZzsgZ2VuZXJhdGVkRm9ybTogR2VuZXJhdGVkRm9ybUludGVyUHJvY2Vzc01lc3NhZ2U7IHJlcXVlc3ROdW1iZXI6IG51bWJlciB9XG4gICAgfCB7IHR5cGU6IFwiRXJyb3JcIjsgZ2Z2Pzogc3RyaW5nOyBlcnJvclRleHQ6IHN0cmluZzsgcmVxdWVzdE51bWJlcjogbnVtYmVyIH07XG5cblR5cGVkUHJvY2Vzc1dvcmtlci5zdGFydDxDYWxsTWVzc2FnZSwgQ2FsbFJlc3BvbnNlPihcbiAgICBhc3luYyAoXG4gICAgICAgIFtcbiAgICAgICAgICAgIHBhdGhUb0dlbmVyYXRvclByb2Nlc3NTdWdhcixcbiAgICAgICAgICAgIGZvcm1Tb3VyY2VzUGF0aCxcbiAgICAgICAgICAgIGZhcm1EaXJlY3RvcnksXG4gICAgICAgICAgICBobEZhcm1EaXJlY3RvcnlQYXRoLFxuICAgICAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnMsXG4gICAgICAgICAgICBwdXJnZUNhY2hlLFxuICAgICAgICAgICAgcmVxdWVzdE51bWJlcixcbiAgICAgICAgXSxcbiAgICAgICAgc2VuZFxuICAgICk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgICAgICBsZXQgZm9ybVNvdXJjZTogRm9ybVNvdXJjZSB8IHVuZGVmaW5lZDtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGNvbnN0IGltcG9ydGVyID0gbmV3IEdlbmVyYXRvclNvdXJjZXNJbXBvcnRlcihwdXJnZUNhY2hlKTtcbiAgICAgICAgICAgIGNvbnN0IHJlYWRTb3VyY2VzID0gYXdhaXQgaW1wb3J0ZXIuaW1wb3J0UmVhZFNvdXJjZXMocGF0aFRvR2VuZXJhdG9yUHJvY2Vzc1N1Z2FyKTtcbiAgICAgICAgICAgIGZvcm1Tb3VyY2UgPSBhd2FpdCByZWFkU291cmNlcyhmb3JtU291cmNlc1BhdGgsIGZhcm1EaXJlY3RvcnksIGhsRmFybURpcmVjdG9yeVBhdGgpO1xuXG4gICAgICAgICAgICBjb25zdCBwcm9jZXNzU3VnYXIgPSBhd2FpdCBpbXBvcnRlci5pbXBvcnRQcm9jZXNzU3VnYXIocGF0aFRvR2VuZXJhdG9yUHJvY2Vzc1N1Z2FyKTtcblxuICAgICAgICAgICAgY29uc3QgZm9ybUNvbnRlbnQ6IEdlbmVyYXRlZEZvcm0gPSBhd2FpdCBwcm9jZXNzU3VnYXIoXG4gICAgICAgICAgICAgICAgZm9ybVNvdXJjZS5zdWdhckNvbnRlbnQsXG4gICAgICAgICAgICAgICAgZm9ybVNvdXJjZS5yZXNvdXJjZXMsXG4gICAgICAgICAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnNcbiAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgIGNvbnN0IHJlc3VsdDogR2VuZXJhdGVkRm9ybUludGVyUHJvY2Vzc01lc3NhZ2UgPSB7fTtcblxuICAgICAgICAgICAgLy8gTk9URSBCZWNhdXNlIG9ubHkgSlNPTiBhcmUgYWxsb3dlZCBmb3IgSVBDIHdlIG5lZWQgdG8gY29udmVydCBCdWZmZXIgLT4gQmFzZTY0XG4gICAgICAgICAgICAvLyBBbm90aGVyIHNvbHV0aW9uIGlzIHVzZSBhIHN0cmVhbSwgYnV0IGZvcm1Db250ZW50IHN0aWxsIG5lZWQgdG8gY29udmVydCBvciBzZW5kIGJ5IGNodW5rc1xuICAgICAgICAgICAgZm9yIChjb25zdCBba2V5LCBmb3JtQ29udGVudEl0ZW1dIG9mIGl0ZXJhdGVFbnRyaWVzKGZvcm1Db250ZW50KSkge1xuICAgICAgICAgICAgICAgIHJlc3VsdFtrZXldID1cbiAgICAgICAgICAgICAgICAgICAgZm9ybUNvbnRlbnRJdGVtIGluc3RhbmNlb2YgQnVmZmVyXG4gICAgICAgICAgICAgICAgICAgICAgICA/IHsgcGF5bG9hZDogZm9ybUNvbnRlbnRJdGVtLnRvU3RyaW5nKFwiYmFzZTY0XCIpLCBlbmNvZGluZzogXCJiYXNlNjRcIiB9XG4gICAgICAgICAgICAgICAgICAgICAgICA6IGZvcm1Db250ZW50SXRlbTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgc2VuZCh7XG4gICAgICAgICAgICAgICAgdHlwZTogXCJSZXN1bHRcIixcbiAgICAgICAgICAgICAgICBnZnY6IGZvcm1Tb3VyY2UucmVzb3VyY2VzLmdmdixcbiAgICAgICAgICAgICAgICBnZW5lcmF0ZWRGb3JtOiByZXN1bHQsXG4gICAgICAgICAgICAgICAgcmVxdWVzdE51bWJlcjogcmVxdWVzdE51bWJlcixcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgICAgaWYgKGVycm9yIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICAgICAgICAgICAgICBzZW5kKHtcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogXCJFcnJvclwiLFxuICAgICAgICAgICAgICAgICAgICBnZnY6IGZvcm1Tb3VyY2U/LnJlc291cmNlcy5nZnYsXG4gICAgICAgICAgICAgICAgICAgIGVycm9yVGV4dDogYCR7ZXJyb3IudG9TdHJpbmcoKX1cXG4ke2Vycm9yLnN0YWNrfWAsXG4gICAgICAgICAgICAgICAgICAgIHJlcXVlc3ROdW1iZXI6IHJlcXVlc3ROdW1iZXIsXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNlbmQoe1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiBcIkVycm9yXCIsXG4gICAgICAgICAgICAgICAgICAgIGdmdjogZm9ybVNvdXJjZT8ucmVzb3VyY2VzLmdmdixcbiAgICAgICAgICAgICAgICAgICAgZXJyb3JUZXh0OiBgJHtlcnJvcn1gLFxuICAgICAgICAgICAgICAgICAgICByZXF1ZXN0TnVtYmVyOiByZXF1ZXN0TnVtYmVyLFxuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuKTtcbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0dlbmVyYXRvci9HZW5lcmF0b3JXb3JrZXIvUmVhZFNvdXJjZXNBbmRQcm9jZXNzU3VnYXJXb3JrZXIudHMiXSwibmFtZXMiOlsiVHlwZWRQcm9jZXNzV29ya2VyIiwic3RhcnQiLCJwYXRoVG9HZW5lcmF0b3JQcm9jZXNzU3VnYXIiLCJmb3JtU291cmNlc1BhdGgiLCJmYXJtRGlyZWN0b3J5IiwiaGxGYXJtRGlyZWN0b3J5UGF0aCIsImdlbmVyYXRpb25PcHRpb25zIiwicHVyZ2VDYWNoZSIsInJlcXVlc3ROdW1iZXIiLCJzZW5kIiwiZm9ybVNvdXJjZSIsImltcG9ydGVyIiwiR2VuZXJhdG9yU291cmNlc0ltcG9ydGVyIiwicmVhZFNvdXJjZXMiLCJpbXBvcnRSZWFkU291cmNlcyIsInByb2Nlc3NTdWdhciIsImltcG9ydFByb2Nlc3NTdWdhciIsImZvcm1Db250ZW50Iiwic3VnYXJDb250ZW50IiwicmVzb3VyY2VzIiwidmFsaWRhdG9yIiwiR2VuZXJhdG9yU291cmNlc1ZhbGlkYXRvciIsInZhbGlkYXRlIiwicmVzdWx0Iiwia2V5IiwiZm9ybUNvbnRlbnRJdGVtIiwiQnVmZmVyIiwicGF5bG9hZCIsInRvU3RyaW5nIiwiZW5jb2RpbmciLCJ0eXBlIiwiZ2Z2IiwiZ2VuZXJhdGVkRm9ybSIsImVycm9yIiwiRXJyb3IiLCJlcnJvclRleHQiLCJzdGFjayJdLCJtYXBwaW5ncyI6Ijs7QUFFQTs7QUFFQTs7QUFDQTs7QUFXQUEsdUNBQW1CQyxLQUFuQixDQUNJLE9BQ0ksQ0FDSUMsMkJBREosRUFFSUMsZUFGSixFQUdJQyxhQUhKLEVBSUlDLG1CQUpKLEVBS0lDLGlCQUxKLEVBTUlDLFVBTkosRUFPSUMsYUFQSixDQURKLEVBVUlDLElBVkosS0FXb0I7QUFDaEIsTUFBSUMsVUFBSjs7QUFDQSxNQUFJO0FBQ0EsVUFBTUMsUUFBUSxHQUFHLElBQUlDLCtDQUFKLENBQTZCTCxVQUE3QixDQUFqQjtBQUNBLFVBQU1NLFdBQVcsR0FBRyxNQUFNRixRQUFRLENBQUNHLGlCQUFULENBQTJCWiwyQkFBM0IsQ0FBMUI7QUFDQVEsSUFBQUEsVUFBVSxHQUFHLE1BQU1HLFdBQVcsQ0FBQ1YsZUFBRCxFQUFrQkMsYUFBbEIsRUFBaUNDLG1CQUFqQyxDQUE5QjtBQUVBLFVBQU1VLFlBQVksR0FBRyxNQUFNSixRQUFRLENBQUNLLGtCQUFULENBQTRCZCwyQkFBNUIsQ0FBM0I7QUFFQSxVQUFNZSxXQUEwQixHQUFHLE1BQU1GLFlBQVksQ0FDakRMLFVBQVUsQ0FBQ1EsWUFEc0MsRUFFakRSLFVBQVUsQ0FBQ1MsU0FGc0MsRUFHakRiLGlCQUhpRCxDQUFyRDtBQU1BLFVBQU1jLFNBQVMsR0FBRyxJQUFJQyxnREFBSixDQUE4QmYsaUJBQTlCLENBQWxCO0FBQ0EsVUFBTWMsU0FBUyxDQUFDRSxRQUFWLENBQW1CTCxXQUFuQixDQUFOO0FBRUEsVUFBTU0sTUFBd0MsR0FBRyxFQUFqRCxDQWhCQSxDQWtCQTtBQUNBOztBQUNBLFNBQUssTUFBTSxDQUFDQyxHQUFELEVBQU1DLGVBQU4sQ0FBWCxJQUFxQyxtQ0FBZVIsV0FBZixDQUFyQyxFQUFrRTtBQUM5RE0sTUFBQUEsTUFBTSxDQUFDQyxHQUFELENBQU4sR0FDSUMsZUFBZSxZQUFZQyxNQUEzQixHQUNNO0FBQUVDLFFBQUFBLE9BQU8sRUFBRUYsZUFBZSxDQUFDRyxRQUFoQixDQUF5QixRQUF6QixDQUFYO0FBQStDQyxRQUFBQSxRQUFRLEVBQUU7QUFBekQsT0FETixHQUVNSixlQUhWO0FBSUg7O0FBRURoQixJQUFBQSxJQUFJLENBQUM7QUFDRHFCLE1BQUFBLElBQUksRUFBRSxRQURMO0FBRURDLE1BQUFBLEdBQUcsRUFBRXJCLFVBQVUsQ0FBQ1MsU0FBWCxDQUFxQlksR0FGekI7QUFHREMsTUFBQUEsYUFBYSxFQUFFVCxNQUhkO0FBSURmLE1BQUFBLGFBQWEsRUFBRUE7QUFKZCxLQUFELENBQUo7QUFNSCxHQWpDRCxDQWlDRSxPQUFPeUIsS0FBUCxFQUFjO0FBQ1osUUFBSUEsS0FBSyxZQUFZQyxLQUFyQixFQUE0QjtBQUFBOztBQUN4QnpCLE1BQUFBLElBQUksQ0FBQztBQUNEcUIsUUFBQUEsSUFBSSxFQUFFLE9BREw7QUFFREMsUUFBQUEsR0FBRyxpQkFBRXJCLFVBQUYsZ0RBQUUsWUFBWVMsU0FBWixDQUFzQlksR0FGMUI7QUFHREksUUFBQUEsU0FBUyxFQUFHLEdBQUVGLEtBQUssQ0FBQ0wsUUFBTixFQUFpQixLQUFJSyxLQUFLLENBQUNHLEtBQU0sRUFIOUM7QUFJRDVCLFFBQUFBLGFBQWEsRUFBRUE7QUFKZCxPQUFELENBQUo7QUFNSCxLQVBELE1BT087QUFBQTs7QUFDSEMsTUFBQUEsSUFBSSxDQUFDO0FBQ0RxQixRQUFBQSxJQUFJLEVBQUUsT0FETDtBQUVEQyxRQUFBQSxHQUFHLGtCQUFFckIsVUFBRixpREFBRSxhQUFZUyxTQUFaLENBQXNCWSxHQUYxQjtBQUdESSxRQUFBQSxTQUFTLEVBQUcsR0FBRUYsS0FBTSxFQUhuQjtBQUlEekIsUUFBQUEsYUFBYSxFQUFFQTtBQUpkLE9BQUQsQ0FBSjtBQU1IO0FBQ0o7QUFDSixDQWhFTCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdlbmVyYXRlZEZvcm0sIEdlbmVyYXRpb25PcHRpb25zIH0gZnJvbSBcIi4uLy4uL0Zvcm0vR2VuZXJhdGVGb3JtXCI7XG5pbXBvcnQgeyBGb3JtU291cmNlIH0gZnJvbSBcIi4uLy4uL1JlYWRGb3JtU291cmNlXCI7XG5pbXBvcnQgeyBpdGVyYXRlRW50cmllcyB9IGZyb20gXCIuLi8uLi8uLi8uLi8uLi9Db21tb24vSXRlcmFibGVVdGlsc1wiO1xuXG5pbXBvcnQgeyBHZW5lcmF0b3JTb3VyY2VzSW1wb3J0ZXIsIEdlbmVyYXRvclNvdXJjZXNWYWxpZGF0b3IgfSBmcm9tIFwiLi9HZW5lcmF0b3JSZXF1aXJlVXRpbHNcIjtcbmltcG9ydCB7IFR5cGVkUHJvY2Vzc1dvcmtlciB9IGZyb20gXCIuL1R5cGVkUHJvY2Vzc1dvcmtlclwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEdlbmVyYXRlZEZvcm1JbnRlclByb2Nlc3NNZXNzYWdlIHtcbiAgICBbcmVsYXRpdmVGaWxlTmFtZTogc3RyaW5nXTogc3RyaW5nIHwgeyBwYXlsb2FkOiBzdHJpbmc7IGVuY29kaW5nOiBzdHJpbmcgfTtcbn1cblxuZXhwb3J0IHR5cGUgQ2FsbE1lc3NhZ2UgPSBbc3RyaW5nLCBzdHJpbmcsIHN0cmluZywgc3RyaW5nLCB1bmRlZmluZWQgfCBHZW5lcmF0aW9uT3B0aW9ucywgYm9vbGVhbiwgbnVtYmVyXTtcbmV4cG9ydCB0eXBlIENhbGxSZXNwb25zZSA9XG4gICAgfCB7IHR5cGU6IFwiUmVzdWx0XCI7IGdmdjogc3RyaW5nOyBnZW5lcmF0ZWRGb3JtOiBHZW5lcmF0ZWRGb3JtSW50ZXJQcm9jZXNzTWVzc2FnZTsgcmVxdWVzdE51bWJlcjogbnVtYmVyIH1cbiAgICB8IHsgdHlwZTogXCJFcnJvclwiOyBnZnY/OiBzdHJpbmc7IGVycm9yVGV4dDogc3RyaW5nOyByZXF1ZXN0TnVtYmVyOiBudW1iZXIgfTtcblxuVHlwZWRQcm9jZXNzV29ya2VyLnN0YXJ0PENhbGxNZXNzYWdlLCBDYWxsUmVzcG9uc2U+KFxuICAgIGFzeW5jIChcbiAgICAgICAgW1xuICAgICAgICAgICAgcGF0aFRvR2VuZXJhdG9yUHJvY2Vzc1N1Z2FyLFxuICAgICAgICAgICAgZm9ybVNvdXJjZXNQYXRoLFxuICAgICAgICAgICAgZmFybURpcmVjdG9yeSxcbiAgICAgICAgICAgIGhsRmFybURpcmVjdG9yeVBhdGgsXG4gICAgICAgICAgICBnZW5lcmF0aW9uT3B0aW9ucyxcbiAgICAgICAgICAgIHB1cmdlQ2FjaGUsXG4gICAgICAgICAgICByZXF1ZXN0TnVtYmVyLFxuICAgICAgICBdLFxuICAgICAgICBzZW5kXG4gICAgKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICAgIGxldCBmb3JtU291cmNlOiBGb3JtU291cmNlIHwgdW5kZWZpbmVkO1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgY29uc3QgaW1wb3J0ZXIgPSBuZXcgR2VuZXJhdG9yU291cmNlc0ltcG9ydGVyKHB1cmdlQ2FjaGUpO1xuICAgICAgICAgICAgY29uc3QgcmVhZFNvdXJjZXMgPSBhd2FpdCBpbXBvcnRlci5pbXBvcnRSZWFkU291cmNlcyhwYXRoVG9HZW5lcmF0b3JQcm9jZXNzU3VnYXIpO1xuICAgICAgICAgICAgZm9ybVNvdXJjZSA9IGF3YWl0IHJlYWRTb3VyY2VzKGZvcm1Tb3VyY2VzUGF0aCwgZmFybURpcmVjdG9yeSwgaGxGYXJtRGlyZWN0b3J5UGF0aCk7XG5cbiAgICAgICAgICAgIGNvbnN0IHByb2Nlc3NTdWdhciA9IGF3YWl0IGltcG9ydGVyLmltcG9ydFByb2Nlc3NTdWdhcihwYXRoVG9HZW5lcmF0b3JQcm9jZXNzU3VnYXIpO1xuXG4gICAgICAgICAgICBjb25zdCBmb3JtQ29udGVudDogR2VuZXJhdGVkRm9ybSA9IGF3YWl0IHByb2Nlc3NTdWdhcihcbiAgICAgICAgICAgICAgICBmb3JtU291cmNlLnN1Z2FyQ29udGVudCxcbiAgICAgICAgICAgICAgICBmb3JtU291cmNlLnJlc291cmNlcyxcbiAgICAgICAgICAgICAgICBnZW5lcmF0aW9uT3B0aW9uc1xuICAgICAgICAgICAgKTtcblxuICAgICAgICAgICAgY29uc3QgdmFsaWRhdG9yID0gbmV3IEdlbmVyYXRvclNvdXJjZXNWYWxpZGF0b3IoZ2VuZXJhdGlvbk9wdGlvbnMpO1xuICAgICAgICAgICAgYXdhaXQgdmFsaWRhdG9yLnZhbGlkYXRlKGZvcm1Db250ZW50KTtcblxuICAgICAgICAgICAgY29uc3QgcmVzdWx0OiBHZW5lcmF0ZWRGb3JtSW50ZXJQcm9jZXNzTWVzc2FnZSA9IHt9O1xuXG4gICAgICAgICAgICAvLyBOT1RFIEJlY2F1c2Ugb25seSBKU09OIGFyZSBhbGxvd2VkIGZvciBJUEMgd2UgbmVlZCB0byBjb252ZXJ0IEJ1ZmZlciAtPiBCYXNlNjRcbiAgICAgICAgICAgIC8vIEFub3RoZXIgc29sdXRpb24gaXMgdXNlIGEgc3RyZWFtLCBidXQgZm9ybUNvbnRlbnQgc3RpbGwgbmVlZCB0byBjb252ZXJ0IG9yIHNlbmQgYnkgY2h1bmtzXG4gICAgICAgICAgICBmb3IgKGNvbnN0IFtrZXksIGZvcm1Db250ZW50SXRlbV0gb2YgaXRlcmF0ZUVudHJpZXMoZm9ybUNvbnRlbnQpKSB7XG4gICAgICAgICAgICAgICAgcmVzdWx0W2tleV0gPVxuICAgICAgICAgICAgICAgICAgICBmb3JtQ29udGVudEl0ZW0gaW5zdGFuY2VvZiBCdWZmZXJcbiAgICAgICAgICAgICAgICAgICAgICAgID8geyBwYXlsb2FkOiBmb3JtQ29udGVudEl0ZW0udG9TdHJpbmcoXCJiYXNlNjRcIiksIGVuY29kaW5nOiBcImJhc2U2NFwiIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIDogZm9ybUNvbnRlbnRJdGVtO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBzZW5kKHtcbiAgICAgICAgICAgICAgICB0eXBlOiBcIlJlc3VsdFwiLFxuICAgICAgICAgICAgICAgIGdmdjogZm9ybVNvdXJjZS5yZXNvdXJjZXMuZ2Z2LFxuICAgICAgICAgICAgICAgIGdlbmVyYXRlZEZvcm06IHJlc3VsdCxcbiAgICAgICAgICAgICAgICByZXF1ZXN0TnVtYmVyOiByZXF1ZXN0TnVtYmVyLFxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgICAgICAgICAgIHNlbmQoe1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiBcIkVycm9yXCIsXG4gICAgICAgICAgICAgICAgICAgIGdmdjogZm9ybVNvdXJjZT8ucmVzb3VyY2VzLmdmdixcbiAgICAgICAgICAgICAgICAgICAgZXJyb3JUZXh0OiBgJHtlcnJvci50b1N0cmluZygpfVxcbiR7ZXJyb3Iuc3RhY2t9YCxcbiAgICAgICAgICAgICAgICAgICAgcmVxdWVzdE51bWJlcjogcmVxdWVzdE51bWJlcixcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc2VuZCh7XG4gICAgICAgICAgICAgICAgICAgIHR5cGU6IFwiRXJyb3JcIixcbiAgICAgICAgICAgICAgICAgICAgZ2Z2OiBmb3JtU291cmNlPy5yZXNvdXJjZXMuZ2Z2LFxuICAgICAgICAgICAgICAgICAgICBlcnJvclRleHQ6IGAke2Vycm9yfWAsXG4gICAgICAgICAgICAgICAgICAgIHJlcXVlc3ROdW1iZXI6IHJlcXVlc3ROdW1iZXIsXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9XG4pO1xuIl19
@@ -133,4 +133,4 @@ function getFormConfigFromSource(formConfig, logger) {
133
133
  } : undefined
134
134
  };
135
135
  }
136
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/BuildTasks/ResolveFormInfo.ts"],"names":["FormBuildMode","resolveFormInfo","formJsonFile","pathToForm","_engineDirectory","logger","upgradeFormJson","useLastStableVersion","usePrereleaseVersion","nightly","formConfig","readFormConfig","undefined","Error","dependencies","engine","generator","log","JSON","stringify","prereleaseVersionFormJson","generatorVersion","engineVersion","type","preId","themes","mode","NoEditor","CopyLegacyPrebuiltResources","NormalBuild","formName","path","basename","formSourcesPath","isNewFormJsonFormat","getFormConfigFromSource","settings","useServerSideFLangNormalization","x","build"],"mappings":"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","sourcesContent":["import path from \"path\";\n\nimport { readJson } from \"fs-extra\";\nimport { pickBy } from \"lodash\";\n\nimport { writeFileAsync } from \"../Commons/FsUtils\";\nimport { ILogger } from \"../Commons/Logging/ILogger\";\nimport { getLogger } from \"../Commons/Logging/StaticLogger\";\n\nimport {\n    getLastStableEngineVersion,\n    getLastStableGeneratorVersion,\n    getPrereleaseVersionFormJson,\n} from \"./PublishedVersionUtils\";\nimport { CandyVersionSpec, isValidSemVerVersionRange, parseCandyVersionSpec } from \"./Version\";\n\nexport enum FormBuildMode {\n    NormalBuild,\n    NoEditor,\n    CopyLegacyPrebuiltResources,\n}\n\nexport interface FormInfo {\n    themes?: string[];\n    mode: FormBuildMode;\n    formName: string;\n    formSourcesPath: string;\n    generatorVersion: undefined | CandyVersionSpec;\n    engineVersion: undefined | CandyVersionSpec;\n}\n\nexport interface FormConfigContent {\n    themes?: string[];\n    build?: \"ci\" | \"manual\";\n    mode?: \"no-editor\" | \"copy-legacy-prebuilt-resources\";\n    dependencies?: {\n        generator?: string;\n        engine?: string;\n    };\n    settings?: {\n        useServerSideFLangNormalization?: boolean;\n        autoCalculationCalculatorImpl?: \"calculator2\";\n        disableFlangRulesForEnableAutoFieldFeature?: boolean;\n    };\n}\n\ninterface FormConfig {\n    themes?: string[];\n    build?: \"ci\" | \"manual\";\n    mode?: \"no-editor\" | \"copy-legacy-prebuilt-resources\" | \"normal-build\";\n    dependencies?: {\n        generator: undefined | string;\n        engine: undefined | string;\n    };\n    settings: {\n        useServerSideFLangNormalization: boolean;\n        autoCalculationCalculatorImpl?: \"calculator2\" | \"default\";\n        disableFlangRulesForEnableAutoFieldFeature?: boolean;\n    };\n}\n\nexport async function resolveFormInfo(\n    formJsonFile: string,\n    pathToForm: string,\n    _engineDirectory: undefined | string,\n    logger: ILogger = getLogger(),\n    upgradeFormJson: boolean = false,\n    useLastStableVersion: boolean = false,\n    usePrereleaseVersion?: string,\n    nightly: boolean = false\n): Promise<FormInfo> {\n    const formConfig = await readFormConfig(formJsonFile, logger);\n    if (useLastStableVersion && usePrereleaseVersion != undefined) {\n        throw new Error(\"Необходимо использовать либо флаг useLastStableVersion либо usePrereleaseVersion\");\n    }\n    if (useLastStableVersion) {\n        formConfig.dependencies = {\n            engine: await getLastStableEngineVersion(),\n            generator: await getLastStableGeneratorVersion(),\n        };\n        logger.log(`Updated to last stable version ${formConfig.dependencies.engine}`);\n        await writeFileAsync(formJsonFile, JSON.stringify(formConfig, undefined, \"  \"), \"utf8\");\n    }\n    if (usePrereleaseVersion != undefined) {\n        const prereleaseVersionFormJson = await getPrereleaseVersionFormJson(usePrereleaseVersion);\n        if (prereleaseVersionFormJson != undefined) {\n            formConfig.dependencies = {\n                engine: prereleaseVersionFormJson,\n                generator: prereleaseVersionFormJson,\n            };\n            logger.log(`Updated to last prerelease version ${formConfig.dependencies.engine}`);\n        }\n        await writeFileAsync(formJsonFile, JSON.stringify(formConfig, undefined, \"  \"), \"utf8\");\n    }\n    let generatorVersion =\n        formConfig.dependencies?.generator != undefined\n            ? parseCandyVersionSpec(formConfig.dependencies.generator)\n            : undefined;\n    let engineVersion =\n        formConfig.dependencies?.engine != undefined\n            ? parseCandyVersionSpec(formConfig.dependencies.engine)\n            : undefined;\n    if (nightly) {\n        generatorVersion = { type: \"pre\", preId: \"nightly\" };\n        engineVersion = { type: \"pre\", preId: \"nightly\" };\n    }\n    if (upgradeFormJson) {\n        await writeFileAsync(formJsonFile, JSON.stringify(formConfig, undefined, \"  \"), \"utf8\");\n    }\n    return {\n        themes: formConfig.themes,\n        mode:\n            formConfig.mode === \"no-editor\"\n                ? FormBuildMode.NoEditor\n                : formConfig.mode === \"copy-legacy-prebuilt-resources\"\n                ? FormBuildMode.CopyLegacyPrebuiltResources\n                : FormBuildMode.NormalBuild,\n        formName: path.basename(pathToForm),\n        formSourcesPath: pathToForm,\n        generatorVersion: generatorVersion,\n        engineVersion: engineVersion,\n    };\n}\n\nexport async function isNewFormJsonFormat(formJsonFile: string): Promise<boolean> {\n    // tslint:disable-next-line no-unsafe-any\n    const formConfig: FormConfigContent = await readJson(formJsonFile);\n    return formConfig.dependencies != undefined;\n}\n\nexport async function readFormConfig(formJsonFile: string, logger: ILogger): Promise<FormConfig> {\n    // tslint:disable-next-line no-unsafe-any\n    const formConfig: FormConfigContent = await readJson(formJsonFile);\n    return getFormConfigFromSource(formConfig, logger);\n}\n\nexport function getFormConfigFromSource(formConfig: FormConfigContent, logger: ILogger): FormConfig {\n    // tslint:disable-next-line no-unsafe-any\n    if (\n        formConfig.dependencies?.generator != undefined &&\n        !isValidSemVerVersionRange(formConfig.dependencies.generator)\n    ) {\n        throw new Error(`${formConfig.dependencies.generator} is not valid version format`);\n    }\n\n    if (formConfig.dependencies?.engine != undefined && !isValidSemVerVersionRange(formConfig.dependencies.engine)) {\n        throw new Error(`${formConfig.dependencies.engine} is not valid version format`);\n    }\n\n    const settings = {\n        useServerSideFLangNormalization: false,\n        ...pickBy(formConfig.settings ?? {}, x => x !== undefined),\n    };\n\n    return {\n        themes: formConfig.themes,\n        build: formConfig.build || \"manual\",\n        mode: formConfig.mode ?? \"normal-build\",\n        settings: settings,\n        dependencies:\n            formConfig.dependencies != undefined\n                ? {\n                      generator: formConfig.dependencies.generator,\n                      engine: formConfig.dependencies.engine,\n                  }\n                : undefined,\n    };\n}\n"]}
136
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/BuildTasks/ResolveFormInfo.ts"],"names":["FormBuildMode","resolveFormInfo","formJsonFile","pathToForm","_engineDirectory","logger","upgradeFormJson","useLastStableVersion","usePrereleaseVersion","nightly","formConfig","readFormConfig","undefined","Error","dependencies","engine","generator","log","JSON","stringify","prereleaseVersionFormJson","generatorVersion","engineVersion","type","preId","themes","mode","NoEditor","CopyLegacyPrebuiltResources","NormalBuild","formName","path","basename","formSourcesPath","isNewFormJsonFormat","getFormConfigFromSource","settings","useServerSideFLangNormalization","x","build"],"mappings":"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","sourcesContent":["import path from \"path\";\n\nimport { readJson } from \"fs-extra\";\nimport { pickBy } from \"lodash\";\n\nimport { writeFileAsync } from \"../Commons/FsUtils\";\nimport { ILogger } from \"../Commons/Logging/ILogger\";\nimport { getLogger } from \"../Commons/Logging/StaticLogger\";\n\nimport {\n    getLastStableEngineVersion,\n    getLastStableGeneratorVersion,\n    getPrereleaseVersionFormJson,\n} from \"./PublishedVersionUtils\";\nimport { CandyVersionSpec, isValidSemVerVersionRange, parseCandyVersionSpec } from \"./Version\";\n\nexport enum FormBuildMode {\n    NormalBuild,\n    NoEditor,\n    CopyLegacyPrebuiltResources,\n}\n\nexport interface FormInfo {\n    themes?: string[];\n    mode: FormBuildMode;\n    formName: string;\n    formSourcesPath: string;\n    generatorVersion: undefined | CandyVersionSpec;\n    engineVersion: undefined | CandyVersionSpec;\n}\n\nexport interface FormConfigContent {\n    themes?: string[];\n    build?: \"ci\" | \"manual\";\n    mode?: \"no-editor\" | \"copy-legacy-prebuilt-resources\";\n    dependencies?: {\n        generator?: string;\n        engine?: string;\n    };\n    settings?: {\n        useServerSideFLangNormalization?: boolean;\n        autoCalculationCalculatorImpl?: \"calculator2\";\n        disableFlangRulesForEnableAutoFieldFeature?: boolean;\n        disableFlangRulesForFormulaAndInitNormalizer?: boolean;\n    };\n}\n\ninterface FormConfig {\n    themes?: string[];\n    build?: \"ci\" | \"manual\";\n    mode?: \"no-editor\" | \"copy-legacy-prebuilt-resources\" | \"normal-build\";\n    dependencies?: {\n        generator: undefined | string;\n        engine: undefined | string;\n    };\n    settings: {\n        useServerSideFLangNormalization: boolean;\n        autoCalculationCalculatorImpl?: \"calculator2\" | \"default\";\n        disableFlangRulesForEnableAutoFieldFeature?: boolean;\n        disableFlangRulesForFormulaAndInitNormalizer?: boolean;\n    };\n}\n\nexport async function resolveFormInfo(\n    formJsonFile: string,\n    pathToForm: string,\n    _engineDirectory: undefined | string,\n    logger: ILogger = getLogger(),\n    upgradeFormJson: boolean = false,\n    useLastStableVersion: boolean = false,\n    usePrereleaseVersion?: string,\n    nightly: boolean = false\n): Promise<FormInfo> {\n    const formConfig = await readFormConfig(formJsonFile, logger);\n    if (useLastStableVersion && usePrereleaseVersion != undefined) {\n        throw new Error(\"Необходимо использовать либо флаг useLastStableVersion либо usePrereleaseVersion\");\n    }\n    if (useLastStableVersion) {\n        formConfig.dependencies = {\n            engine: await getLastStableEngineVersion(),\n            generator: await getLastStableGeneratorVersion(),\n        };\n        logger.log(`Updated to last stable version ${formConfig.dependencies.engine}`);\n        await writeFileAsync(formJsonFile, JSON.stringify(formConfig, undefined, \"  \"), \"utf8\");\n    }\n    if (usePrereleaseVersion != undefined) {\n        const prereleaseVersionFormJson = await getPrereleaseVersionFormJson(usePrereleaseVersion);\n        if (prereleaseVersionFormJson != undefined) {\n            formConfig.dependencies = {\n                engine: prereleaseVersionFormJson,\n                generator: prereleaseVersionFormJson,\n            };\n            logger.log(`Updated to last prerelease version ${formConfig.dependencies.engine}`);\n        }\n        await writeFileAsync(formJsonFile, JSON.stringify(formConfig, undefined, \"  \"), \"utf8\");\n    }\n    let generatorVersion =\n        formConfig.dependencies?.generator != undefined\n            ? parseCandyVersionSpec(formConfig.dependencies.generator)\n            : undefined;\n    let engineVersion =\n        formConfig.dependencies?.engine != undefined\n            ? parseCandyVersionSpec(formConfig.dependencies.engine)\n            : undefined;\n    if (nightly) {\n        generatorVersion = { type: \"pre\", preId: \"nightly\" };\n        engineVersion = { type: \"pre\", preId: \"nightly\" };\n    }\n    if (upgradeFormJson) {\n        await writeFileAsync(formJsonFile, JSON.stringify(formConfig, undefined, \"  \"), \"utf8\");\n    }\n    return {\n        themes: formConfig.themes,\n        mode:\n            formConfig.mode === \"no-editor\"\n                ? FormBuildMode.NoEditor\n                : formConfig.mode === \"copy-legacy-prebuilt-resources\"\n                ? FormBuildMode.CopyLegacyPrebuiltResources\n                : FormBuildMode.NormalBuild,\n        formName: path.basename(pathToForm),\n        formSourcesPath: pathToForm,\n        generatorVersion: generatorVersion,\n        engineVersion: engineVersion,\n    };\n}\n\nexport async function isNewFormJsonFormat(formJsonFile: string): Promise<boolean> {\n    // tslint:disable-next-line no-unsafe-any\n    const formConfig: FormConfigContent = await readJson(formJsonFile);\n    return formConfig.dependencies != undefined;\n}\n\nexport async function readFormConfig(formJsonFile: string, logger: ILogger): Promise<FormConfig> {\n    // tslint:disable-next-line no-unsafe-any\n    const formConfig: FormConfigContent = await readJson(formJsonFile);\n    return getFormConfigFromSource(formConfig, logger);\n}\n\nexport function getFormConfigFromSource(formConfig: FormConfigContent, logger: ILogger): FormConfig {\n    // tslint:disable-next-line no-unsafe-any\n    if (\n        formConfig.dependencies?.generator != undefined &&\n        !isValidSemVerVersionRange(formConfig.dependencies.generator)\n    ) {\n        throw new Error(`${formConfig.dependencies.generator} is not valid version format`);\n    }\n\n    if (formConfig.dependencies?.engine != undefined && !isValidSemVerVersionRange(formConfig.dependencies.engine)) {\n        throw new Error(`${formConfig.dependencies.engine} is not valid version format`);\n    }\n\n    const settings = {\n        useServerSideFLangNormalization: false,\n        ...pickBy(formConfig.settings ?? {}, x => x !== undefined),\n    };\n\n    return {\n        themes: formConfig.themes,\n        build: formConfig.build || \"manual\",\n        mode: formConfig.mode ?? \"normal-build\",\n        settings: settings,\n        dependencies:\n            formConfig.dependencies != undefined\n                ? {\n                      generator: formConfig.dependencies.generator,\n                      engine: formConfig.dependencies.engine,\n                  }\n                : undefined,\n    };\n}\n"]}
@@ -86,11 +86,11 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
86
86
  return _Observe.Observe.file(_path.default.join(formDirPath, "form.json")).transform(formJsonFile => (0, _ResolveFormInfo.resolveFormInfo)(formJsonFile, formDirPath, engineDirectory, context.logger.withPrefix(`FORM:${gfv}`), options.upgradeFormJson, options.useLastStableVersion, options.usePrereleaseVersion)).transform(async fi => {
87
87
  if (fi.mode === _ResolveFormInfo.FormBuildMode.NormalBuild) {
88
88
  if (fi.generatorVersion == undefined) {
89
- throw new Error("generatorVersion is no defined");
89
+ throw new Error("generatorVersion is not defined");
90
90
  }
91
91
 
92
92
  if (fi.engineVersion == undefined) {
93
- throw new Error("engineVersion is no defined");
93
+ throw new Error("engineVersion is not defined");
94
94
  }
95
95
 
96
96
  return { ...fi,
@@ -178,8 +178,8 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
178
178
  mode: options.buildCacheMode,
179
179
  farmDirectory: farmDirectory
180
180
  } : undefined;
181
- await (0, _CompileForm.compileForm)(fi.formName, fi.themes, farmDirectory, resourcesDirectory, (_fi$dependenciesHash2 = fi.dependenciesHash) !== null && _fi$dependenciesHash2 !== void 0 ? _fi$dependenciesHash2 : (0, _TypingUtils.reject)("This version of generator is not supported due to dependencies extraction is not supporter"), false, undefined, buildCacheOptions);
182
- await (0, _WriteFormMeta.writeFormMeta)(resourcesDirectory, gfv, fi.engineSource, (_fi$dependenciesHash3 = fi.dependenciesHash) !== null && _fi$dependenciesHash3 !== void 0 ? _fi$dependenciesHash3 : (0, _TypingUtils.reject)("This version of generator is not supported due to dependencies extraction is not supporter"), fi.themes, buildCache, buildCacheOptions);
181
+ await (0, _CompileForm.compileForm)(fi.formName, fi.themes, farmDirectory, resourcesDirectory, (_fi$dependenciesHash2 = fi.dependenciesHash) !== null && _fi$dependenciesHash2 !== void 0 ? _fi$dependenciesHash2 : (0, _TypingUtils.reject)("This version of generator is not supported due to dependencies extraction is not supported"), false, undefined, buildCacheOptions);
182
+ await (0, _WriteFormMeta.writeFormMeta)(resourcesDirectory, gfv, fi.engineSource, (_fi$dependenciesHash3 = fi.dependenciesHash) !== null && _fi$dependenciesHash3 !== void 0 ? _fi$dependenciesHash3 : (0, _TypingUtils.reject)("This version of generator is not supported due to dependencies extraction is not supported"), fi.themes, buildCache, buildCacheOptions);
183
183
  }).do(async fi => {
184
184
  if (fi.generatorSource == undefined) {
185
185
  return;
@@ -200,7 +200,7 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
200
200
  } else {
201
201
  return new _SingleValueProducer.SingleValueProducer("");
202
202
  }
203
- }).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "schemas"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("SCHEMAS"), x, _path.default.join(resourcesDirectory, "schemas")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "converters"), "*").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("CONVERTERS"), x, _path.default.join(resourcesDirectory, "converters")))).attach(async fi => {
203
+ }).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "schemas"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("SCHEMAS"), x, _path.default.join(resourcesDirectory, "schemas")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "converters"), "*").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("CONVERTERS"), x, _path.default.join(resourcesDirectory, "converters")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "mergers"), "*").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("MERGERS"), x, _path.default.join(resourcesDirectory, "mergers")))).attach(async fi => {
204
204
  const modifier = content => content.replace(/<x:include href="[./]+/g, '<x:include href="');
205
205
 
206
206
  return _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "converters"), "*").do(x => _FSTask.FSTask.modifyFilesContent((0, _StaticLogger.getLogger)().withPrefix("FIX-XSLT-INCLUDE"), x, _path.default.join(resourcesDirectory, "converters"), "**/*.xslt", modifier));
@@ -262,4 +262,4 @@ async function cleanTargetDirectory(resourcesDirectory, logger) {
262
262
  await (0, _fsExtra.emptyDir)(resourcesDirectory);
263
263
  logger.log("Resource directory clean");
264
264
  }
265
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/CLICommands/BuildForms/RunBuildForms.ts"],"names":["getGeneratorVersion","generatorSource","type","version","Error","runBuildForms","context","options","farmDirectory","resourcesDirectory","engineDirectory","candyModulesDirectory","hlFarmDirectoryPath","buildOptions","pickListsChain","Observe","files","path","join","do","x","FSTask","copyRecursively","logger","withPrefix","formGlobs","FormGlobs","validateGlobs","resolveSpecifiers","staticResourcesForProductionChain","__dirname","resourcesNuSpecChain","copyByMasks","copiedEngines","Set","buildCache","BuildCache","buildCacheMode","buildFormsChain","directory","splitToParallelChains","gfv","formDirPath","warning","value","file","transform","formJsonFile","upgradeFormJson","useLastStableVersion","usePrereleaseVersion","fi","mode","FormBuildMode","NormalBuild","generatorVersion","undefined","engineVersion","engineSource","attach","SingleValueProducer","NullFormGenerator","useVersionFromCache","y","generator","has","add","formSourcesPath","dependenciesHash","supportsDependenciesExtraction","getAllDependenciesHash","exists","log","skipCodeReformatting","skipGeneratedCodeReformatting","resourcesHash","extract","buildCacheOptions","depsHash","formName","themes","CopyLegacyPrebuiltResources","modifier","content","replace","modifyFilesContent","copyFile","watch","notifier","notify","title","message","clean","cleanTargetDirectory","stopObserve1","observe","stopObserve2","stopObserve3","stopObserve4","waitForExit","startDate","Date","now","currentValue","console","chalk","greenBright","totalTime"],"mappings":"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","sourcesContent":["import path from \"path\";\n\nimport chalk from \"chalk\";\nimport { emptyDir, pathExists } from \"fs-extra\";\nimport notifier from \"node-notifier\";\n\nimport { engineFactory } from \"../../BuildTasks/Engine/AcquireFormEngine\";\nimport { getEngineSourceKey } from \"../../BuildTasks/Engine/EngineSource\";\nimport { compileForm } from \"../../BuildTasks/Form/CompileForm\";\nimport { generateForm } from \"../../BuildTasks/Form/GenerateForm\";\nimport { NullFormGenerator } from \"../../BuildTasks/Form/NullFormGenerator\";\nimport { writeFLangNormalizationFiles } from \"../../BuildTasks/Form/WriteFLangNormalizationFiles\";\nimport { FSTask } from \"../../BuildTasks/FSTask\";\nimport {\n    generatorFactory,\n    GeneratorSource,\n    getGeneratorSourceKey,\n} from \"../../BuildTasks/Generator/AcquireFormGenerator\";\nimport { resolveEngineVersion, resolveGeneratorVersion } from \"../../BuildTasks/PublishedVersionUtils\";\nimport { FormBuildMode, resolveFormInfo } from \"../../BuildTasks/ResolveFormInfo\";\nimport { writeFormMeta } from \"../../BuildTasks/WriteFormMeta\";\nimport { ConsoleApplicationContext } from \"../../Commons/ConsoleApplication/ConsoleApplicationContext\";\nimport { FormGlobs } from \"../../Commons/FormGlobsUtils\";\nimport { ILogger } from \"../../Commons/Logging/ILogger\";\nimport { getLogger } from \"../../Commons/Logging/StaticLogger\";\nimport { Observe } from \"../../Commons/TasksCore/Observe\";\nimport { SingleValueProducer } from \"../../Commons/TasksCore/SingleValueProducer\";\nimport { printTime } from \"../../Commons/TimingUtils\";\nimport { BuildCache } from \"../../FormWebpackConfiguration/CacheAssetsPlugin\";\nimport { reject } from \"../../../../Common/TypingUtils\";\nimport { writeAttachmentPathFiles } from \"../../BuildTasks/Form/WriteAttachmentPathFiles\";\n\nimport { BuildFormsOptions } from \"./BuildFormsOptions\";\n\nfunction getGeneratorVersion(generatorSource: GeneratorSource): string {\n    if (generatorSource.type === \"PublishedGenerator\") {\n        return generatorSource.version;\n    } else {\n        throw new Error(\"InvalidProgramState\");\n    }\n}\n\nexport async function runBuildForms(\n    context: ConsoleApplicationContext,\n    options: BuildFormsOptions,\n    farmDirectory: string,\n    resourcesDirectory: string,\n    engineDirectory: string,\n    candyModulesDirectory: string,\n    hlFarmDirectoryPath: string\n): Promise<void> {\n    const buildOptions = options;\n\n    const pickListsChain = Observe.files(path.join(farmDirectory, \"picklists\"), \"*.json\").do(x =>\n        FSTask.copyRecursively(context.logger.withPrefix(\"PICKLISTS\"), x, path.join(resourcesDirectory, \"picklists\"))\n    );\n\n    const formGlobs = await FormGlobs.validateGlobs(\n        await FormGlobs.resolveSpecifiers(buildOptions.formGlobs, farmDirectory),\n        farmDirectory\n    );\n\n    const staticResourcesForProductionChain = Observe.files(\n        path.join(__dirname, \"..\", \"..\", \"StaticFilesForProductionResourcesDir\"),\n        \"*.js\",\n        \"*.js.map\"\n    ).do(x =>\n        FSTask.copyRecursively(getLogger().withPrefix(\"STATICS\"), x, path.join(resourcesDirectory, \"public\", \"scripts\"))\n    );\n\n    const resourcesNuSpecChain = Observe.files(path.join(farmDirectory), \"*.nuspec\").do(x =>\n        FSTask.copyByMasks(getLogger().withPrefix(\"NUSPEC\"), x, [\"*.nuspec\"], path.join(resourcesDirectory))\n    );\n\n    const copiedEngines = new Set<string>();\n\n    const buildCache = new BuildCache(farmDirectory, options.buildCacheMode);\n    const buildFormsChain = Observe.directory(path.join(farmDirectory, \"forms\"), formGlobs).splitToParallelChains(\n        x => x,\n        x => x,\n        async gfv => {\n            const formDirPath = path.join(farmDirectory, \"forms\", gfv);\n\n            if (!(await pathExists(path.join(formDirPath, \"form.json\")))) {\n                context.logger.warning(\n                    `Form ${gfv} does not have form.json file. To include this form to build process restart build`\n                );\n                return Observe.value({});\n            }\n\n            return Observe.file(path.join(formDirPath, \"form.json\"))\n                .transform(formJsonFile =>\n                    resolveFormInfo(\n                        formJsonFile,\n                        formDirPath,\n                        engineDirectory,\n                        context.logger.withPrefix(`FORM:${gfv}`),\n                        options.upgradeFormJson,\n                        options.useLastStableVersion,\n                        options.usePrereleaseVersion\n                    )\n                )\n                .transform(async fi => {\n                    if (fi.mode === FormBuildMode.NormalBuild) {\n                        if (fi.generatorVersion == undefined) {\n                            throw new Error(\"generatorVersion is no defined\");\n                        }\n                        if (fi.engineVersion == undefined) {\n                            throw new Error(\"engineVersion is no defined\");\n                        }\n                        return {\n                            ...fi,\n                            generatorSource: await resolveGeneratorVersion(\n                                fi.generatorVersion,\n                                context.logger.withPrefix(gfv)\n                            ),\n                            engineSource: await resolveEngineVersion(fi.engineVersion, context.logger.withPrefix(gfv)),\n                        };\n                    } else {\n                        return {\n                            ...fi,\n                            generatorSource: undefined,\n                            engineSource: undefined,\n                        };\n                    }\n                })\n                .attach(\n                    async fi => {\n                        if (fi.generatorSource == undefined) {\n                            return new SingleValueProducer(new NullFormGenerator());\n                        } else {\n                            return generatorFactory(\n                                fi.generatorSource,\n                                candyModulesDirectory,\n                                options.useVersionFromCache\n                            );\n                        }\n                    },\n                    async (fi, y) => ({ ...fi, generator: y }),\n                    async fi =>\n                        fi.generatorSource != undefined\n                            ? getGeneratorSourceKey(fi.generatorSource)\n                            : \"NullFormGenerator\"\n                )\n                .attach(\n                    async fi => {\n                        if (fi.engineSource === undefined) {\n                            return new SingleValueProducer(\"NullEngine\");\n                        }\n                        return engineFactory(fi.engineSource, candyModulesDirectory, options.useVersionFromCache).do(\n                            async x => {\n                                if (!copiedEngines.has(getEngineSourceKey(fi.engineSource))) {\n                                    await FSTask.copyRecursively(\n                                        getLogger().withPrefix(\"ENGINE\"),\n                                        x,\n                                        path.join(resourcesDirectory, \"public\")\n                                    );\n                                    copiedEngines.add(getEngineSourceKey(fi.engineSource));\n                                }\n                            }\n                        );\n                    },\n                    async fi => fi,\n                    async fi => (fi.engineSource != undefined ? getEngineSourceKey(fi.engineSource) : \"NullEngine\")\n                )\n                .attach(async fi =>\n                    Observe.files(\n                        fi.formSourcesPath,\n                        \"../../controls/**/*\",\n                        \"../../xsltTemplates/**/*\",\n                        \"../../jsHelpers/**/*\",\n                        \"schemas/**/*\",\n                        \"sugar/**/*\",\n                        \"controls/**/*\",\n                        \"autocalc/**/*\",\n                        \"helpers/**/*\",\n                        \"validations/**/*\",\n                        \"localization/**/*\"\n                    )\n                )\n                .transform(async fi => {\n                    let dependenciesHash: undefined | string;\n                    if (fi.mode !== FormBuildMode.NormalBuild) {\n                        return {\n                            ...fi,\n                            dependenciesHash: undefined,\n                        };\n                    }\n                    if (await fi.generator.supportsDependenciesExtraction()) {\n                        dependenciesHash = await fi.generator.getAllDependenciesHash(\n                            formDirPath,\n                            farmDirectory,\n                            hlFarmDirectoryPath\n                        );\n                    }\n                    return {\n                        ...fi,\n                        dependenciesHash: dependenciesHash,\n                    };\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return undefined;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`GENERATE:${gfv}`).log(\"Skipped due build cache exits\");\n                            return undefined;\n                        }\n                    }\n                    return generateForm(\n                        fi.formSourcesPath,\n                        farmDirectory,\n                        hlFarmDirectoryPath,\n                        fi.generator,\n                        undefined,\n                        {\n                            skipCodeReformatting: options.skipGeneratedCodeReformatting,\n                            resourcesHash: fi.dependenciesHash ?? \"UndefinedResourcesHash\",\n                        }\n                    );\n                })\n                .attach(async fi => Observe.files(path.join(formDirPath, \"form\"), \"**/*\"))\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`COMPILE:${gfv}`).log(\"Skipped due build cache exists\");\n                            await buildCache.extract(fi.generatorSource, gfv, fi.dependenciesHash, resourcesDirectory);\n                            return;\n                        }\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await compileForm(\n                        fi.formName,\n                        fi.themes,\n                        farmDirectory,\n                        resourcesDirectory,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supporter\"\n                            ),\n                        false,\n                        undefined,\n                        buildCacheOptions\n                    );\n                    await writeFormMeta(\n                        resourcesDirectory,\n                        gfv,\n                        fi.engineSource,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supporter\"\n                            ),\n                        fi.themes,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await writeFLangNormalizationFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                    await writeAttachmentPathFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .attach(async fi => {\n                    if (fi.mode === FormBuildMode.CopyLegacyPrebuiltResources) {\n                        return Observe.files(path.join(fi.formSourcesPath, \"legacy-prebuilt\"), \"*\").do(x =>\n                            FSTask.copyRecursively(\n                                getLogger().withPrefix(\"LEGACY-PREBUILT\"),\n                                x,\n                                path.join(resourcesDirectory)\n                            )\n                        );\n                    } else {\n                        return new SingleValueProducer(\"\");\n                    }\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"schemas\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"SCHEMAS\"),\n                            x,\n                            path.join(resourcesDirectory, \"schemas\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"CONVERTERS\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\")\n                        )\n                    )\n                )\n                .attach(async fi => {\n                    const modifier = (content: string): string =>\n                        content.replace(/<x:include href=\"[./]+/g, '<x:include href=\"');\n                    return Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.modifyFilesContent(\n                            getLogger().withPrefix(\"FIX-XSLT-INCLUDE\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\"),\n                            \"**/*.xslt\",\n                            modifier\n                        )\n                    );\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"..\", \"..\", \"xsltTemplates\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"XSLT-TEMPLATES\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\", \"xsltTemplates\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.file(path.join(fi.formSourcesPath, \"presentations.json\")).do(x =>\n                        FSTask.copyFile(\n                            getLogger().withPrefix(\"PRESENTATIONS\"),\n                            x,\n                            path.join(resourcesDirectory, \"presentations\", `${gfv}.presentations.json`)\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"normalize\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"NORMALIZE\"),\n                            x,\n                            path.join(resourcesDirectory, \"normalize\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"patch\"), \"*.xslt\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"PATCH\"),\n                            x,\n                            path.join(resourcesDirectory, \"patch\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"map\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(getLogger().withPrefix(\"MAP\"), x, path.join(resourcesDirectory, \"map\"))\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"unmap\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"UNMAP\"),\n                            x,\n                            path.join(resourcesDirectory, \"unmap\")\n                        )\n                    )\n                )\n                .do(async fi => {\n                    if (buildOptions.watch) {\n                        notifier.notify({\n                            title: `${fi.formName}: сборка завершена`,\n                            message: `Engine: ${\n                                fi.engineSource == undefined\n                                    ? \"[NoEngine]\"\n                                    : fi.engineSource.type === \"LocalEngineSources\"\n                                    ? \"local\"\n                                    : fi.engineSource.version\n                            }`,\n                        });\n                    }\n                });\n        }\n    );\n\n    if (buildOptions.watch) {\n        if (options.clean) {\n            await cleanTargetDirectory(resourcesDirectory, context.logger);\n        }\n        const stopObserve1 = await pickListsChain.observe();\n        const stopObserve2 = await buildFormsChain.observe();\n        const stopObserve3 = await staticResourcesForProductionChain.observe();\n        const stopObserve4 = await resourcesNuSpecChain.observe();\n        await context.waitForExit();\n        if (stopObserve3 != undefined) {\n            await stopObserve3();\n        }\n        if (stopObserve4 != undefined) {\n            await stopObserve4();\n        }\n        await stopObserve2();\n        await stopObserve1();\n    } else {\n        const startDate = Date.now();\n        try {\n            if (options.clean) {\n                await cleanTargetDirectory(resourcesDirectory, context.logger);\n            }\n            await pickListsChain.currentValue;\n            await staticResourcesForProductionChain.currentValue;\n            await resourcesNuSpecChain.currentValue;\n            await buildFormsChain.currentValue;\n            // eslint-disable-next-line no-console\n            console.log(chalk.greenBright(\"Build success\"));\n        } finally {\n            const totalTime = Date.now() - startDate;\n            // eslint-disable-next-line no-console\n            console.log(`Total time: ${printTime(totalTime)}`);\n        }\n    }\n}\n\nasync function cleanTargetDirectory(resourcesDirectory: string, logger: ILogger): Promise<void> {\n    logger.log(\"Cleaning resource directory. \" + resourcesDirectory);\n    await emptyDir(resourcesDirectory);\n    logger.log(\"Resource directory clean\");\n}\n"]}
265
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/CLICommands/BuildForms/RunBuildForms.ts"],"names":["getGeneratorVersion","generatorSource","type","version","Error","runBuildForms","context","options","farmDirectory","resourcesDirectory","engineDirectory","candyModulesDirectory","hlFarmDirectoryPath","buildOptions","pickListsChain","Observe","files","path","join","do","x","FSTask","copyRecursively","logger","withPrefix","formGlobs","FormGlobs","validateGlobs","resolveSpecifiers","staticResourcesForProductionChain","__dirname","resourcesNuSpecChain","copyByMasks","copiedEngines","Set","buildCache","BuildCache","buildCacheMode","buildFormsChain","directory","splitToParallelChains","gfv","formDirPath","warning","value","file","transform","formJsonFile","upgradeFormJson","useLastStableVersion","usePrereleaseVersion","fi","mode","FormBuildMode","NormalBuild","generatorVersion","undefined","engineVersion","engineSource","attach","SingleValueProducer","NullFormGenerator","useVersionFromCache","y","generator","has","add","formSourcesPath","dependenciesHash","supportsDependenciesExtraction","getAllDependenciesHash","exists","log","skipCodeReformatting","skipGeneratedCodeReformatting","resourcesHash","extract","buildCacheOptions","depsHash","formName","themes","CopyLegacyPrebuiltResources","modifier","content","replace","modifyFilesContent","copyFile","watch","notifier","notify","title","message","clean","cleanTargetDirectory","stopObserve1","observe","stopObserve2","stopObserve3","stopObserve4","waitForExit","startDate","Date","now","currentValue","console","chalk","greenBright","totalTime"],"mappings":"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","sourcesContent":["import path from \"path\";\n\nimport chalk from \"chalk\";\nimport { emptyDir, pathExists } from \"fs-extra\";\nimport notifier from \"node-notifier\";\n\nimport { engineFactory } from \"../../BuildTasks/Engine/AcquireFormEngine\";\nimport { getEngineSourceKey } from \"../../BuildTasks/Engine/EngineSource\";\nimport { compileForm } from \"../../BuildTasks/Form/CompileForm\";\nimport { generateForm } from \"../../BuildTasks/Form/GenerateForm\";\nimport { NullFormGenerator } from \"../../BuildTasks/Form/NullFormGenerator\";\nimport { writeFLangNormalizationFiles } from \"../../BuildTasks/Form/WriteFLangNormalizationFiles\";\nimport { FSTask } from \"../../BuildTasks/FSTask\";\nimport {\n    generatorFactory,\n    GeneratorSource,\n    getGeneratorSourceKey,\n} from \"../../BuildTasks/Generator/AcquireFormGenerator\";\nimport { resolveEngineVersion, resolveGeneratorVersion } from \"../../BuildTasks/PublishedVersionUtils\";\nimport { FormBuildMode, resolveFormInfo } from \"../../BuildTasks/ResolveFormInfo\";\nimport { writeFormMeta } from \"../../BuildTasks/WriteFormMeta\";\nimport { ConsoleApplicationContext } from \"../../Commons/ConsoleApplication/ConsoleApplicationContext\";\nimport { FormGlobs } from \"../../Commons/FormGlobsUtils\";\nimport { ILogger } from \"../../Commons/Logging/ILogger\";\nimport { getLogger } from \"../../Commons/Logging/StaticLogger\";\nimport { Observe } from \"../../Commons/TasksCore/Observe\";\nimport { SingleValueProducer } from \"../../Commons/TasksCore/SingleValueProducer\";\nimport { printTime } from \"../../Commons/TimingUtils\";\nimport { BuildCache } from \"../../FormWebpackConfiguration/CacheAssetsPlugin\";\nimport { reject } from \"../../../../Common/TypingUtils\";\nimport { writeAttachmentPathFiles } from \"../../BuildTasks/Form/WriteAttachmentPathFiles\";\n\nimport { BuildFormsOptions } from \"./BuildFormsOptions\";\n\nfunction getGeneratorVersion(generatorSource: GeneratorSource): string {\n    if (generatorSource.type === \"PublishedGenerator\") {\n        return generatorSource.version;\n    } else {\n        throw new Error(\"InvalidProgramState\");\n    }\n}\n\nexport async function runBuildForms(\n    context: ConsoleApplicationContext,\n    options: BuildFormsOptions,\n    farmDirectory: string,\n    resourcesDirectory: string,\n    engineDirectory: string,\n    candyModulesDirectory: string,\n    hlFarmDirectoryPath: string\n): Promise<void> {\n    const buildOptions = options;\n\n    const pickListsChain = Observe.files(path.join(farmDirectory, \"picklists\"), \"*.json\").do(x =>\n        FSTask.copyRecursively(context.logger.withPrefix(\"PICKLISTS\"), x, path.join(resourcesDirectory, \"picklists\"))\n    );\n\n    const formGlobs = await FormGlobs.validateGlobs(\n        await FormGlobs.resolveSpecifiers(buildOptions.formGlobs, farmDirectory),\n        farmDirectory\n    );\n\n    const staticResourcesForProductionChain = Observe.files(\n        path.join(__dirname, \"..\", \"..\", \"StaticFilesForProductionResourcesDir\"),\n        \"*.js\",\n        \"*.js.map\"\n    ).do(x =>\n        FSTask.copyRecursively(getLogger().withPrefix(\"STATICS\"), x, path.join(resourcesDirectory, \"public\", \"scripts\"))\n    );\n\n    const resourcesNuSpecChain = Observe.files(path.join(farmDirectory), \"*.nuspec\").do(x =>\n        FSTask.copyByMasks(getLogger().withPrefix(\"NUSPEC\"), x, [\"*.nuspec\"], path.join(resourcesDirectory))\n    );\n\n    const copiedEngines = new Set<string>();\n\n    const buildCache = new BuildCache(farmDirectory, options.buildCacheMode);\n    const buildFormsChain = Observe.directory(path.join(farmDirectory, \"forms\"), formGlobs).splitToParallelChains(\n        x => x,\n        x => x,\n        async gfv => {\n            const formDirPath = path.join(farmDirectory, \"forms\", gfv);\n\n            if (!(await pathExists(path.join(formDirPath, \"form.json\")))) {\n                context.logger.warning(\n                    `Form ${gfv} does not have form.json file. To include this form to build process restart build`\n                );\n                return Observe.value({});\n            }\n\n            return Observe.file(path.join(formDirPath, \"form.json\"))\n                .transform(formJsonFile =>\n                    resolveFormInfo(\n                        formJsonFile,\n                        formDirPath,\n                        engineDirectory,\n                        context.logger.withPrefix(`FORM:${gfv}`),\n                        options.upgradeFormJson,\n                        options.useLastStableVersion,\n                        options.usePrereleaseVersion\n                    )\n                )\n                .transform(async fi => {\n                    if (fi.mode === FormBuildMode.NormalBuild) {\n                        if (fi.generatorVersion == undefined) {\n                            throw new Error(\"generatorVersion is not defined\");\n                        }\n                        if (fi.engineVersion == undefined) {\n                            throw new Error(\"engineVersion is not defined\");\n                        }\n                        return {\n                            ...fi,\n                            generatorSource: await resolveGeneratorVersion(\n                                fi.generatorVersion,\n                                context.logger.withPrefix(gfv)\n                            ),\n                            engineSource: await resolveEngineVersion(fi.engineVersion, context.logger.withPrefix(gfv)),\n                        };\n                    } else {\n                        return {\n                            ...fi,\n                            generatorSource: undefined,\n                            engineSource: undefined,\n                        };\n                    }\n                })\n                .attach(\n                    async fi => {\n                        if (fi.generatorSource == undefined) {\n                            return new SingleValueProducer(new NullFormGenerator());\n                        } else {\n                            return generatorFactory(\n                                fi.generatorSource,\n                                candyModulesDirectory,\n                                options.useVersionFromCache\n                            );\n                        }\n                    },\n                    async (fi, y) => ({ ...fi, generator: y }),\n                    async fi =>\n                        fi.generatorSource != undefined\n                            ? getGeneratorSourceKey(fi.generatorSource)\n                            : \"NullFormGenerator\"\n                )\n                .attach(\n                    async fi => {\n                        if (fi.engineSource === undefined) {\n                            return new SingleValueProducer(\"NullEngine\");\n                        }\n                        return engineFactory(fi.engineSource, candyModulesDirectory, options.useVersionFromCache).do(\n                            async x => {\n                                if (!copiedEngines.has(getEngineSourceKey(fi.engineSource))) {\n                                    await FSTask.copyRecursively(\n                                        getLogger().withPrefix(\"ENGINE\"),\n                                        x,\n                                        path.join(resourcesDirectory, \"public\")\n                                    );\n                                    copiedEngines.add(getEngineSourceKey(fi.engineSource));\n                                }\n                            }\n                        );\n                    },\n                    async fi => fi,\n                    async fi => (fi.engineSource != undefined ? getEngineSourceKey(fi.engineSource) : \"NullEngine\")\n                )\n                .attach(async fi =>\n                    Observe.files(\n                        fi.formSourcesPath,\n                        \"../../controls/**/*\",\n                        \"../../xsltTemplates/**/*\",\n                        \"../../jsHelpers/**/*\",\n                        \"schemas/**/*\",\n                        \"sugar/**/*\",\n                        \"controls/**/*\",\n                        \"autocalc/**/*\",\n                        \"helpers/**/*\",\n                        \"validations/**/*\",\n                        \"localization/**/*\"\n                    )\n                )\n                .transform(async fi => {\n                    let dependenciesHash: undefined | string;\n                    if (fi.mode !== FormBuildMode.NormalBuild) {\n                        return {\n                            ...fi,\n                            dependenciesHash: undefined,\n                        };\n                    }\n                    if (await fi.generator.supportsDependenciesExtraction()) {\n                        dependenciesHash = await fi.generator.getAllDependenciesHash(\n                            formDirPath,\n                            farmDirectory,\n                            hlFarmDirectoryPath\n                        );\n                    }\n                    return {\n                        ...fi,\n                        dependenciesHash: dependenciesHash,\n                    };\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return undefined;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`GENERATE:${gfv}`).log(\"Skipped due build cache exits\");\n                            return undefined;\n                        }\n                    }\n                    return generateForm(\n                        fi.formSourcesPath,\n                        farmDirectory,\n                        hlFarmDirectoryPath,\n                        fi.generator,\n                        undefined,\n                        {\n                            skipCodeReformatting: options.skipGeneratedCodeReformatting,\n                            resourcesHash: fi.dependenciesHash ?? \"UndefinedResourcesHash\",\n                        }\n                    );\n                })\n                .attach(async fi => Observe.files(path.join(formDirPath, \"form\"), \"**/*\"))\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`COMPILE:${gfv}`).log(\"Skipped due build cache exists\");\n                            await buildCache.extract(fi.generatorSource, gfv, fi.dependenciesHash, resourcesDirectory);\n                            return;\n                        }\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await compileForm(\n                        fi.formName,\n                        fi.themes,\n                        farmDirectory,\n                        resourcesDirectory,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supported\"\n                            ),\n                        false,\n                        undefined,\n                        buildCacheOptions\n                    );\n                    await writeFormMeta(\n                        resourcesDirectory,\n                        gfv,\n                        fi.engineSource,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supported\"\n                            ),\n                        fi.themes,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await writeFLangNormalizationFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                    await writeAttachmentPathFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .attach(async fi => {\n                    if (fi.mode === FormBuildMode.CopyLegacyPrebuiltResources) {\n                        return Observe.files(path.join(fi.formSourcesPath, \"legacy-prebuilt\"), \"*\").do(x =>\n                            FSTask.copyRecursively(\n                                getLogger().withPrefix(\"LEGACY-PREBUILT\"),\n                                x,\n                                path.join(resourcesDirectory)\n                            )\n                        );\n                    } else {\n                        return new SingleValueProducer(\"\");\n                    }\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"schemas\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"SCHEMAS\"),\n                            x,\n                            path.join(resourcesDirectory, \"schemas\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"CONVERTERS\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"mergers\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"MERGERS\"),\n                            x,\n                            path.join(resourcesDirectory, \"mergers\")\n                        )\n                    )\n                )\n                .attach(async fi => {\n                    const modifier = (content: string): string =>\n                        content.replace(/<x:include href=\"[./]+/g, '<x:include href=\"');\n                    return Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.modifyFilesContent(\n                            getLogger().withPrefix(\"FIX-XSLT-INCLUDE\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\"),\n                            \"**/*.xslt\",\n                            modifier\n                        )\n                    );\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"..\", \"..\", \"xsltTemplates\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"XSLT-TEMPLATES\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\", \"xsltTemplates\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.file(path.join(fi.formSourcesPath, \"presentations.json\")).do(x =>\n                        FSTask.copyFile(\n                            getLogger().withPrefix(\"PRESENTATIONS\"),\n                            x,\n                            path.join(resourcesDirectory, \"presentations\", `${gfv}.presentations.json`)\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"normalize\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"NORMALIZE\"),\n                            x,\n                            path.join(resourcesDirectory, \"normalize\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"patch\"), \"*.xslt\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"PATCH\"),\n                            x,\n                            path.join(resourcesDirectory, \"patch\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"map\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(getLogger().withPrefix(\"MAP\"), x, path.join(resourcesDirectory, \"map\"))\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"unmap\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"UNMAP\"),\n                            x,\n                            path.join(resourcesDirectory, \"unmap\")\n                        )\n                    )\n                )\n                .do(async fi => {\n                    if (buildOptions.watch) {\n                        notifier.notify({\n                            title: `${fi.formName}: сборка завершена`,\n                            message: `Engine: ${\n                                fi.engineSource == undefined\n                                    ? \"[NoEngine]\"\n                                    : fi.engineSource.type === \"LocalEngineSources\"\n                                    ? \"local\"\n                                    : fi.engineSource.version\n                            }`,\n                        });\n                    }\n                });\n        }\n    );\n\n    if (buildOptions.watch) {\n        if (options.clean) {\n            await cleanTargetDirectory(resourcesDirectory, context.logger);\n        }\n        const stopObserve1 = await pickListsChain.observe();\n        const stopObserve2 = await buildFormsChain.observe();\n        const stopObserve3 = await staticResourcesForProductionChain.observe();\n        const stopObserve4 = await resourcesNuSpecChain.observe();\n        await context.waitForExit();\n        if (stopObserve3 != undefined) {\n            await stopObserve3();\n        }\n        if (stopObserve4 != undefined) {\n            await stopObserve4();\n        }\n        await stopObserve2();\n        await stopObserve1();\n    } else {\n        const startDate = Date.now();\n        try {\n            if (options.clean) {\n                await cleanTargetDirectory(resourcesDirectory, context.logger);\n            }\n            await pickListsChain.currentValue;\n            await staticResourcesForProductionChain.currentValue;\n            await resourcesNuSpecChain.currentValue;\n            await buildFormsChain.currentValue;\n            // eslint-disable-next-line no-console\n            console.log(chalk.greenBright(\"Build success\"));\n        } finally {\n            const totalTime = Date.now() - startDate;\n            // eslint-disable-next-line no-console\n            console.log(`Total time: ${printTime(totalTime)}`);\n        }\n    }\n}\n\nasync function cleanTargetDirectory(resourcesDirectory: string, logger: ILogger): Promise<void> {\n    logger.log(\"Cleaning resource directory. \" + resourcesDirectory);\n    await emptyDir(resourcesDirectory);\n    logger.log(\"Resource directory clean\");\n}\n"]}