@kontur.candy/tools 2.147.0 → 2.148.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 +3 -0
- package/distr/Common/ModelPath/ModelPath.js +3 -3
- package/distr/Tools/src/CLICommands/BuildForms/RunBuildForms.js +5 -5
- package/distr/Tools/src/FormWebpackConfiguration/CacheAssetsPlugin.js +9 -7
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js +29 -34
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js.map +1 -1
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js +24 -29
- package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js.map +1 -1
- package/package.json +1 -1
|
@@ -154,16 +154,18 @@ class BuildCache {
|
|
|
154
154
|
|
|
155
155
|
async existsFileCacheOrDownload(gfv, generatorVersion, depsHash) {
|
|
156
156
|
const filePath = this.getCacheFilePath(gfv, generatorVersion, depsHash);
|
|
157
|
-
this.logger.log(`Start search file
|
|
157
|
+
this.logger.log(`Start search file locally: ${filePath}`);
|
|
158
|
+
const filename = path.basename(filePath);
|
|
158
159
|
await (0, _fsExtra.ensureDir)(path.dirname(filePath));
|
|
159
160
|
|
|
160
161
|
if (await (0, _fsExtra.pathExists)(filePath)) {
|
|
161
|
-
this.logger.log(
|
|
162
|
+
this.logger.log("Found file in local directory");
|
|
162
163
|
return filePath;
|
|
163
164
|
} else {
|
|
164
165
|
try {
|
|
165
|
-
this.logger.log(
|
|
166
|
-
|
|
166
|
+
this.logger.log(`Cache file was not found locally: ${filePath}`);
|
|
167
|
+
this.logger.log(`Looking for cache in drive storage: ${filename}`);
|
|
168
|
+
const response = await (0, _nodeFetch.default)(`https://api.kontur.ru/drive/v1/public/${filename}`);
|
|
167
169
|
this.logger.log(`Drive response status code: ${response.status.toString()}`);
|
|
168
170
|
|
|
169
171
|
if (response.status === 200) {
|
|
@@ -171,9 +173,9 @@ class BuildCache {
|
|
|
171
173
|
return filePath;
|
|
172
174
|
} else {
|
|
173
175
|
if (response.status === 404) {
|
|
174
|
-
this.logger.error(
|
|
176
|
+
this.logger.error(`Cache file not found in drive storage: ${filename}. GFV: ${gfv}, GeneratorVersion: ${generatorVersion}, DependenciesHash: ${depsHash}`);
|
|
175
177
|
} else {
|
|
176
|
-
this.logger.error(`Drive storage
|
|
178
|
+
this.logger.error(`Drive storage sent ${response.status} status code, I don't process it in any way`);
|
|
177
179
|
}
|
|
178
180
|
|
|
179
181
|
return undefined;
|
|
@@ -190,4 +192,4 @@ class BuildCache {
|
|
|
190
192
|
}
|
|
191
193
|
|
|
192
194
|
exports.BuildCache = BuildCache;
|
|
193
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/FormWebpackConfiguration/CacheAssetsPlugin.ts"],"names":["singleLimit","CacheAssetsPlugin","constructor","options","apply","compiler","hooks","emit","tapPromise","compilation","cacheItems","assetName","Object","keys","assets","source","Buffer","type","base64content","toString","updateFile","filePath","path","resolve","cacheFile","content","JSON","parse","dirname","stringify","BuildCache","farmDirectory","mode","logger","withPrefix","extract","generatorSource","gfv","depsHash","resourcesDirectory","Error","getCacheFilePath","version","assetPath","contentElement","join","from","exists","BuildCacheMode","Disabled","ForceUpdate","cachedFilePath","existsFileCacheOrDownload","undefined","setContent","fileName","fileContent","cacheFilePath","createWebpackPlugin","ReadOnly","generatorVersion","log","response","basename","status","buffer","error","e"],"mappings":"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","sourcesContent":["import * as path from \"path\";\n\nimport { ensureDir, pathExists, readFile, writeFile } from \"fs-extra\";\nimport md5 from \"md5\";\nimport pLimit from \"p-limit\";\nimport webpack from \"webpack\";\nimport fetch from \"node-fetch\";\n\nimport { GeneratorSource } from \"../BuildTasks/Generator/AcquireFormGenerator\";\nimport { BuildCacheMode } from \"../CLICommands/BuildForms/BuildCacheMode\";\nimport { reject } from \"../../../Common/TypingUtils\";\nimport { ILogger } from \"../Commons/Logging/ILogger\";\nimport { getLogger } from \"../Commons/Logging/StaticLogger\";\n\ninterface CacheAssetsPluginOptions {\n    cacheFile: string;\n}\n\nexport interface FormBuildCacheOptions {\n    farmDirectory: string;\n    mode: BuildCacheMode;\n    generatorVersion: string;\n    gfv: string;\n    depsHash: string;\n}\n\nconst singleLimit = pLimit(1);\n\ninterface BuildResultsSerialized {\n    [path: string]: string | { type: \"Buffer\"; base64content: string };\n}\n\nexport class CacheAssetsPlugin {\n    private readonly options: CacheAssetsPluginOptions;\n\n    public constructor(options: CacheAssetsPluginOptions) {\n        this.options = options;\n    }\n\n    public async apply(compiler: webpack.Compiler): Promise<void> {\n        compiler.hooks.emit.tapPromise(\"CacheAssetsPlugin\", compilation =>\n            singleLimit(async () => {\n                const cacheItems: BuildResultsSerialized = {};\n                // tslint:disable-next-line no-unsafe-any\n                for (const assetName of Object.keys(compilation.assets)) {\n                    // tslint:disable-next-line no-unsafe-any\n                    const source: string | Buffer = compilation.assets[assetName]?.source() ?? reject();\n                    if (source instanceof Buffer) {\n                        cacheItems[assetName] = { type: \"Buffer\", base64content: source.toString(\"base64\") };\n                    } else {\n                        cacheItems[assetName] = source;\n                    }\n                }\n                await this.updateFile(cacheItems);\n            })\n        );\n    }\n\n    private async updateFile(cacheItems: BuildResultsSerialized): Promise<void> {\n        const filePath = path.resolve(this.options.cacheFile);\n        let content: BuildResultsSerialized = (await pathExists(filePath))\n            ? // tslint:disable-next-line no-unsafe-any\n              JSON.parse(await readFile(filePath, \"utf-8\"))\n            : {};\n        content = {\n            ...content,\n            ...cacheItems,\n        };\n        await ensureDir(path.dirname(filePath));\n        await writeFile(filePath, JSON.stringify(content), \"utf-8\");\n    }\n}\n\nexport class BuildCache {\n    private readonly farmDirectory: string;\n    private readonly mode: BuildCacheMode;\n    private readonly logger: ILogger;\n\n    public constructor(farmDirectory: string, mode: BuildCacheMode) {\n        this.farmDirectory = farmDirectory;\n        this.mode = mode;\n        this.logger = getLogger().withPrefix(\"BUILD_CACHE\");\n    }\n\n    public async extract(\n        generatorSource: GeneratorSource,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string\n    ): Promise<void> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        // tslint:disable-next-line no-unsafe-any\n        const content: BuildResultsSerialized = JSON.parse(\n            await readFile(this.getCacheFilePath(gfv, generatorSource.version, depsHash), \"utf-8\")\n        );\n        for (const assetPath of Object.keys(content)) {\n            const contentElement = content[assetPath] ?? reject();\n            const filePath = path.join(resourcesDirectory, assetPath);\n            await ensureDir(path.dirname(filePath));\n            if (typeof contentElement === \"string\") {\n                await writeFile(filePath, contentElement, \"utf8\");\n            } else {\n                await writeFile(filePath, Buffer.from(contentElement.base64content, \"base64\"));\n            }\n        }\n    }\n\n    public async exists(generatorSource: GeneratorSource, gfv: string, depsHash: string): Promise<boolean> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        if (this.mode === BuildCacheMode.Disabled || this.mode === BuildCacheMode.ForceUpdate) {\n            return false;\n        }\n        const cachedFilePath = await this.existsFileCacheOrDownload(gfv, generatorSource.version, depsHash);\n        return cachedFilePath != undefined;\n    }\n\n    public async setContent(\n        generatorSource: string,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string,\n        fileName: string,\n        fileContent: string\n    ): Promise<void> {\n        const cacheFilePath = this.getCacheFilePath(gfv, generatorSource, depsHash);\n        if (!(await pathExists(cacheFilePath))) {\n            return;\n        }\n        // tslint:disable-next-line no-unsafe-any\n        let content: BuildResultsSerialized = JSON.parse(await readFile(cacheFilePath, \"utf-8\"));\n        content = {\n            ...content,\n            [fileName]: fileContent,\n        };\n        await ensureDir(path.dirname(cacheFilePath));\n        await writeFile(cacheFilePath, JSON.stringify(content), \"utf-8\");\n    }\n\n    public async createWebpackPlugin(options: FormBuildCacheOptions): Promise<CacheAssetsPlugin | undefined> {\n        if (options.mode === BuildCacheMode.Disabled || options.mode === BuildCacheMode.ReadOnly) {\n            return undefined;\n        }\n        const cachedFilePath = this.getCacheFilePath(options.gfv, options.generatorVersion, options.depsHash);\n        return new CacheAssetsPlugin({\n            cacheFile: cachedFilePath,\n        });\n    }\n\n    private getCacheFilePath(gfv: string, generatorVersion: string, depsHash: string): string {\n        const fileName = `${md5(gfv)}-${md5(generatorVersion)}-${depsHash}.zip`;\n        return path.join(this.farmDirectory, \".build-cache\", \"compile\", fileName);\n    }\n\n    private async existsFileCacheOrDownload(\n        gfv: string,\n        generatorVersion: string,\n        depsHash: string\n    ): Promise<string | undefined> {\n        const filePath = this.getCacheFilePath(gfv, generatorVersion, depsHash);\n        this.logger.log(`Start search file in local ${filePath}`);\n        await ensureDir(path.dirname(filePath));\n        if (await pathExists(filePath)) {\n            this.logger.log(`Found file in local directory`);\n            return filePath;\n        } else {\n            try {\n                this.logger.log(\"The cache file was not found in the local directory Im looking for it in drive\");\n                const response = await fetch(`https://api.kontur.ru/drive/v1/public/${path.basename(filePath)}`);\n                this.logger.log(`Drive response status code: ${response.status.toString()}`);\n                if (response.status === 200) {\n                    await writeFile(filePath, await response.buffer(), \"utf-8\");\n                    return filePath;\n                } else {\n                    if (response.status === 404) {\n                        this.logger.error(\"The cache file not found in drive storage\");\n                    } else {\n                        this.logger.error(\n                            `Drive storage send ${response.status} status code, I don't process it in any way`\n                        );\n                    }\n                    return undefined;\n                }\n            } catch (e) {\n                this.logger.error(\"Drive storage responded with an error\");\n                this.logger.error(\"The build will continue without a cache\");\n                this.logger.error(e);\n                return undefined;\n            }\n        }\n    }\n}\n"]}
|
|
195
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/FormWebpackConfiguration/CacheAssetsPlugin.ts"],"names":["singleLimit","CacheAssetsPlugin","constructor","options","apply","compiler","hooks","emit","tapPromise","compilation","cacheItems","assetName","Object","keys","assets","source","Buffer","type","base64content","toString","updateFile","filePath","path","resolve","cacheFile","content","JSON","parse","dirname","stringify","BuildCache","farmDirectory","mode","logger","withPrefix","extract","generatorSource","gfv","depsHash","resourcesDirectory","Error","getCacheFilePath","version","assetPath","contentElement","join","from","exists","BuildCacheMode","Disabled","ForceUpdate","cachedFilePath","existsFileCacheOrDownload","undefined","setContent","fileName","fileContent","cacheFilePath","createWebpackPlugin","ReadOnly","generatorVersion","log","filename","basename","response","status","buffer","error","e"],"mappings":"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","sourcesContent":["import * as path from \"path\";\n\nimport { ensureDir, pathExists, readFile, writeFile } from \"fs-extra\";\nimport md5 from \"md5\";\nimport pLimit from \"p-limit\";\nimport webpack from \"webpack\";\nimport fetch from \"node-fetch\";\n\nimport { GeneratorSource } from \"../BuildTasks/Generator/AcquireFormGenerator\";\nimport { BuildCacheMode } from \"../CLICommands/BuildForms/BuildCacheMode\";\nimport { reject } from \"../../../Common/TypingUtils\";\nimport { ILogger } from \"../Commons/Logging/ILogger\";\nimport { getLogger } from \"../Commons/Logging/StaticLogger\";\n\ninterface CacheAssetsPluginOptions {\n    cacheFile: string;\n}\n\nexport interface FormBuildCacheOptions {\n    farmDirectory: string;\n    mode: BuildCacheMode;\n    generatorVersion: string;\n    gfv: string;\n    depsHash: string;\n}\n\nconst singleLimit = pLimit(1);\n\ninterface BuildResultsSerialized {\n    [path: string]: string | { type: \"Buffer\"; base64content: string };\n}\n\nexport class CacheAssetsPlugin {\n    private readonly options: CacheAssetsPluginOptions;\n\n    public constructor(options: CacheAssetsPluginOptions) {\n        this.options = options;\n    }\n\n    public async apply(compiler: webpack.Compiler): Promise<void> {\n        compiler.hooks.emit.tapPromise(\"CacheAssetsPlugin\", compilation =>\n            singleLimit(async () => {\n                const cacheItems: BuildResultsSerialized = {};\n                // tslint:disable-next-line no-unsafe-any\n                for (const assetName of Object.keys(compilation.assets)) {\n                    // tslint:disable-next-line no-unsafe-any\n                    const source: string | Buffer = compilation.assets[assetName]?.source() ?? reject();\n                    if (source instanceof Buffer) {\n                        cacheItems[assetName] = { type: \"Buffer\", base64content: source.toString(\"base64\") };\n                    } else {\n                        cacheItems[assetName] = source;\n                    }\n                }\n                await this.updateFile(cacheItems);\n            })\n        );\n    }\n\n    private async updateFile(cacheItems: BuildResultsSerialized): Promise<void> {\n        const filePath = path.resolve(this.options.cacheFile);\n        let content: BuildResultsSerialized = (await pathExists(filePath))\n            ? // tslint:disable-next-line no-unsafe-any\n              JSON.parse(await readFile(filePath, \"utf-8\"))\n            : {};\n        content = {\n            ...content,\n            ...cacheItems,\n        };\n        await ensureDir(path.dirname(filePath));\n        await writeFile(filePath, JSON.stringify(content), \"utf-8\");\n    }\n}\n\nexport class BuildCache {\n    private readonly farmDirectory: string;\n    private readonly mode: BuildCacheMode;\n    private readonly logger: ILogger;\n\n    public constructor(farmDirectory: string, mode: BuildCacheMode) {\n        this.farmDirectory = farmDirectory;\n        this.mode = mode;\n        this.logger = getLogger().withPrefix(\"BUILD_CACHE\");\n    }\n\n    public async extract(\n        generatorSource: GeneratorSource,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string\n    ): Promise<void> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        // tslint:disable-next-line no-unsafe-any\n        const content: BuildResultsSerialized = JSON.parse(\n            await readFile(this.getCacheFilePath(gfv, generatorSource.version, depsHash), \"utf-8\")\n        );\n        for (const assetPath of Object.keys(content)) {\n            const contentElement = content[assetPath] ?? reject();\n            const filePath = path.join(resourcesDirectory, assetPath);\n            await ensureDir(path.dirname(filePath));\n            if (typeof contentElement === \"string\") {\n                await writeFile(filePath, contentElement, \"utf8\");\n            } else {\n                await writeFile(filePath, Buffer.from(contentElement.base64content, \"base64\"));\n            }\n        }\n    }\n\n    public async exists(generatorSource: GeneratorSource, gfv: string, depsHash: string): Promise<boolean> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        if (this.mode === BuildCacheMode.Disabled || this.mode === BuildCacheMode.ForceUpdate) {\n            return false;\n        }\n        const cachedFilePath = await this.existsFileCacheOrDownload(gfv, generatorSource.version, depsHash);\n        return cachedFilePath != undefined;\n    }\n\n    public async setContent(\n        generatorSource: string,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string,\n        fileName: string,\n        fileContent: string\n    ): Promise<void> {\n        const cacheFilePath = this.getCacheFilePath(gfv, generatorSource, depsHash);\n        if (!(await pathExists(cacheFilePath))) {\n            return;\n        }\n        // tslint:disable-next-line no-unsafe-any\n        let content: BuildResultsSerialized = JSON.parse(await readFile(cacheFilePath, \"utf-8\"));\n        content = {\n            ...content,\n            [fileName]: fileContent,\n        };\n        await ensureDir(path.dirname(cacheFilePath));\n        await writeFile(cacheFilePath, JSON.stringify(content), \"utf-8\");\n    }\n\n    public async createWebpackPlugin(options: FormBuildCacheOptions): Promise<CacheAssetsPlugin | undefined> {\n        if (options.mode === BuildCacheMode.Disabled || options.mode === BuildCacheMode.ReadOnly) {\n            return undefined;\n        }\n        const cachedFilePath = this.getCacheFilePath(options.gfv, options.generatorVersion, options.depsHash);\n        return new CacheAssetsPlugin({\n            cacheFile: cachedFilePath,\n        });\n    }\n\n    private getCacheFilePath(gfv: string, generatorVersion: string, depsHash: string): string {\n        const fileName = `${md5(gfv)}-${md5(generatorVersion)}-${depsHash}.zip`;\n        return path.join(this.farmDirectory, \".build-cache\", \"compile\", fileName);\n    }\n\n    private async existsFileCacheOrDownload(\n        gfv: string,\n        generatorVersion: string,\n        depsHash: string\n    ): Promise<string | undefined> {\n        const filePath = this.getCacheFilePath(gfv, generatorVersion, depsHash);\n        this.logger.log(`Start search file locally: ${filePath}`);\n        const filename = path.basename(filePath);\n        await ensureDir(path.dirname(filePath));\n        if (await pathExists(filePath)) {\n            this.logger.log(\"Found file in local directory\");\n            return filePath;\n        } else {\n            try {\n                this.logger.log(`Cache file was not found locally: ${filePath}`);\n                this.logger.log(`Looking for cache in drive storage: ${filename}`);\n                const response = await fetch(`https://api.kontur.ru/drive/v1/public/${filename}`);\n                this.logger.log(`Drive response status code: ${response.status.toString()}`);\n                if (response.status === 200) {\n                    await writeFile(filePath, await response.buffer(), \"utf-8\");\n                    return filePath;\n                } else {\n                    if (response.status === 404) {\n                        this.logger.error(\n                            `Cache file not found in drive storage: ${filename}. GFV: ${gfv}, GeneratorVersion: ${generatorVersion}, DependenciesHash: ${depsHash}`\n                        );\n                    } else {\n                        this.logger.error(\n                            `Drive storage sent ${response.status} status code, I don't process it in any way`\n                        );\n                    }\n                    return undefined;\n                }\n            } catch (e) {\n                this.logger.error(\"Drive storage responded with an error\");\n                this.logger.error(\"The build will continue without a cache\");\n                this.logger.error(e);\n                return undefined;\n            }\n        }\n    }\n}\n"]}
|