@kontur.candy/tools 2.151.0 → 2.152.0
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.
- package/CHANGELOG.md +13 -0
- package/distr/Common/CandyApiClient/CandyApiClient.js +44 -18
- package/distr/Common/CandyApiClient/FakeCandyApiClient.js +14 -2
- package/distr/Common/CandyApiClient/Types/ErrorLog/CandyPopdProtocol.js +14 -0
- package/distr/Common/CandyApiClient/Types/ErrorLog/ServerErrorLog.js +17 -1
- package/distr/Common/CandyApiClient/Types/InstancesDeleting/InstancesDeletingRule.js +6 -0
- package/distr/Common/CandyApiClient/Types/TestClassification.js +6 -0
- package/distr/Common/KCLangRuntimeUtils.js +72 -1
- package/distr/Common/ModelPath/ModelPath.js +3 -3
- package/distr/Common/UseShowOnce.js +7 -19
- package/distr/Tools/src/BuildTasks/Form/WriteFLangNormalizationFiles.js +6 -4
- package/distr/Tools/src/CLICommands/BuildForms/RunBuildForms.js +18 -12
- package/distr/Tools/src/LocalServerFrontEndDist/index.js +1 -1
- package/distr/Tools/src/LocalServerFrontEndDist/index.js.map +1 -1
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js +38 -42
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js.map +1 -1
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js +51 -55
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js.map +1 -1
- package/package.json +1 -1
|
@@ -138,6 +138,16 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
|
|
|
138
138
|
return { ...fi,
|
|
139
139
|
dependenciesHash: dependenciesHash
|
|
140
140
|
};
|
|
141
|
+
}).transform(async fi => {
|
|
142
|
+
let buildCacheExist = false;
|
|
143
|
+
|
|
144
|
+
if (fi.dependenciesHash != undefined && fi.generatorSource != undefined) {
|
|
145
|
+
buildCacheExist = await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash);
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
return { ...fi,
|
|
149
|
+
buildCacheExist: buildCacheExist
|
|
150
|
+
};
|
|
141
151
|
}).do(async fi => {
|
|
142
152
|
var _fi$dependenciesHash;
|
|
143
153
|
|
|
@@ -145,11 +155,9 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
|
|
|
145
155
|
return undefined;
|
|
146
156
|
}
|
|
147
157
|
|
|
148
|
-
if (fi.
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
return undefined;
|
|
152
|
-
}
|
|
158
|
+
if (fi.buildCacheExist) {
|
|
159
|
+
context.logger.withPrefix(`GENERATE:${gfv}`).log("Skipped due build cache exits");
|
|
160
|
+
return undefined;
|
|
153
161
|
}
|
|
154
162
|
|
|
155
163
|
return (0, _GenerateForm.generateForm)(fi.formSourcesPath, farmDirectory, hlFarmDirectoryPath, fi.generator, undefined, {
|
|
@@ -163,12 +171,10 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
|
|
|
163
171
|
return;
|
|
164
172
|
}
|
|
165
173
|
|
|
166
|
-
if (fi.dependenciesHash != undefined) {
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
return;
|
|
171
|
-
}
|
|
174
|
+
if (fi.dependenciesHash != undefined && fi.buildCacheExist) {
|
|
175
|
+
context.logger.withPrefix(`COMPILE:${gfv}`).log("Skipped due build cache exists");
|
|
176
|
+
await buildCache.extract(fi.generatorSource, gfv, fi.dependenciesHash, resourcesDirectory);
|
|
177
|
+
return;
|
|
172
178
|
}
|
|
173
179
|
|
|
174
180
|
const buildCacheOptions = fi.dependenciesHash != undefined ? {
|
|
@@ -262,4 +268,4 @@ async function cleanTargetDirectory(resourcesDirectory, logger) {
|
|
|
262
268
|
await (0, _fsExtra.emptyDir)(resourcesDirectory);
|
|
263
269
|
logger.log("Resource directory clean");
|
|
264
270
|
}
|
|
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"]}
|
|
271
|
+
//# 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","buildCacheExist","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                .transform(async fi => {\n                    let buildCacheExist: boolean = false;\n                    if (fi.dependenciesHash != undefined && fi.generatorSource != undefined) {\n                        buildCacheExist = await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash);\n                    }\n                    return {\n                        ...fi,\n                        buildCacheExist: buildCacheExist,\n                    };\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return undefined;\n                    }\n                    if (fi.buildCacheExist) {\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 && fi.buildCacheExist) {\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                    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\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\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"]}
|