Tell if we should update kcGen based on the hash
This commit is contained in:
parent
329b4cb0fb
commit
c83319d6f3
@ -4,6 +4,7 @@ import { join as pathJoin } from "path";
|
|||||||
import { existsAsync } from "./tools/fs.existsAsync";
|
import { existsAsync } from "./tools/fs.existsAsync";
|
||||||
import { maybeDelegateCommandToCustomHandler } from "./shared/customHandler_delegate";
|
import { maybeDelegateCommandToCustomHandler } from "./shared/customHandler_delegate";
|
||||||
import { runFormat } from "./tools/runFormat";
|
import { runFormat } from "./tools/runFormat";
|
||||||
|
import * as crypto from "crypto";
|
||||||
|
|
||||||
export async function command(params: { buildContext: BuildContext }) {
|
export async function command(params: { buildContext: BuildContext }) {
|
||||||
const { buildContext } = params;
|
const { buildContext } = params;
|
||||||
@ -19,17 +20,16 @@ export async function command(params: { buildContext: BuildContext }) {
|
|||||||
|
|
||||||
const filePath = pathJoin(buildContext.themeSrcDirPath, `kc.gen.tsx`);
|
const filePath = pathJoin(buildContext.themeSrcDirPath, `kc.gen.tsx`);
|
||||||
|
|
||||||
const currentContent = (await existsAsync(filePath))
|
|
||||||
? await fs.readFile(filePath)
|
|
||||||
: undefined;
|
|
||||||
|
|
||||||
const hasLoginTheme = buildContext.implementedThemeTypes.login.isImplemented;
|
const hasLoginTheme = buildContext.implementedThemeTypes.login.isImplemented;
|
||||||
const hasAccountTheme = buildContext.implementedThemeTypes.account.isImplemented;
|
const hasAccountTheme = buildContext.implementedThemeTypes.account.isImplemented;
|
||||||
|
|
||||||
const newContent = Buffer.from(
|
const newContent = [
|
||||||
[
|
|
||||||
``,
|
``,
|
||||||
`// This file is auto-generated by Keycloakify, do not modify it manually.`,
|
`/* eslint-disable */`,
|
||||||
|
``,
|
||||||
|
`// @ts-nocheck`,
|
||||||
|
``,
|
||||||
|
`// noinspection JSUnusedGlobalSymbols`,
|
||||||
``,
|
``,
|
||||||
`import { lazy, Suspense, type ReactNode } from "react";`,
|
`import { lazy, Suspense, type ReactNode } from "react";`,
|
||||||
``,
|
``,
|
||||||
@ -90,15 +90,36 @@ export async function command(params: { buildContext: BuildContext }) {
|
|||||||
``
|
``
|
||||||
]
|
]
|
||||||
.filter(item => typeof item === "string")
|
.filter(item => typeof item === "string")
|
||||||
.join("\n"),
|
.join("\n");
|
||||||
"utf8"
|
|
||||||
);
|
const hash = crypto.createHash("sha256").update(newContent).digest("hex");
|
||||||
|
|
||||||
|
skip_if_no_changes: {
|
||||||
|
if (!(await existsAsync(filePath))) {
|
||||||
|
break skip_if_no_changes;
|
||||||
|
}
|
||||||
|
|
||||||
|
const currentContent = (await fs.readFile(filePath)).toString("utf8");
|
||||||
|
|
||||||
|
if (!currentContent.includes(hash)) {
|
||||||
|
break skip_if_no_changes;
|
||||||
|
}
|
||||||
|
|
||||||
if (currentContent !== undefined && currentContent.equals(newContent)) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
await fs.writeFile(filePath, newContent);
|
await fs.writeFile(
|
||||||
|
filePath,
|
||||||
|
Buffer.from(
|
||||||
|
[
|
||||||
|
`// This file is auto-generated by the \`update-kc-gen\` command. Do not edit it manually.`,
|
||||||
|
`// Hash: ${hash}`,
|
||||||
|
``,
|
||||||
|
newContent
|
||||||
|
].join("\n"),
|
||||||
|
"utf8"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
runFormat({ packageJsonFilePath: buildContext.packageJsonFilePath });
|
runFormat({ packageJsonFilePath: buildContext.packageJsonFilePath });
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user