mirror of
https://github.com/ajnart/homarr.git
synced 2026-03-02 18:30:53 +01:00
* fix(deps): update dependency drizzle-zod to ^0.8.2 * chore: update zod to v4 import * fix: path is no longer available in transform context * fix: AnyZodObject does no longer exist * fix: auth env.ts using wrong createEnv and remove unused file env-validation.ts * fix: required_error no longer exists on z.string * fix: zod error map is deprecated and replaced with config * fix: default requires callback now * fix: migrate zod resolver for mantine * fix: remove unused form translation file * fix: wrong enum type * fix: record now requires two arguments * fix: add-confirm-password-refinement type issues * fix: add missing first record argument for entityStateSchema * fix: migrate superrefine to check * fix(deps): upgrade zod-form-data to v3 * fix: migrate superRefine to check for mediaUploadSchema * fix: authProvidersSchema default is array * fix: use stringbool instead of custom implementation * fix: record requires first argument * fix: migrate superRefine to check for certificate router * fix: confirm pasword refinement is overwriting types * fix: email optional not working * fix: migrate intersection to object converter * fix: safe parse return value rename * fix: easier access for min and max number value * fix: migrate superRefine to check for oldmarr import file * fix: inference of enum shape for old-import board-size wrong * fix: errors renamed to issues * chore: address pull request feedback * fix: zod form requires object * fix: inference for use-zod-form not working * fix: remove unnecessary convertion * fix(deps): upgrade trpc-to-openapi to v3 * fix: build error * fix: migrate missing zod imports to v4 * fix: migrate zod records to v4 * fix: missing core package dependency in api module * fix: unable to convert custom zod schema to openapi schema * fix(deps): upgrade zod to v4 * chore(renovate): enable zod dependency updates * test: add simple unit test for convertIntersectionToZodObject --------- Co-authored-by: homarr-renovate[bot] <158783068+homarr-renovate[bot]@users.noreply.github.com>
76 lines
2.2 KiB
TypeScript
76 lines
2.2 KiB
TypeScript
import fs from "node:fs/promises";
|
|
import path, { dirname } from "node:path";
|
|
import { fileURLToPath } from "node:url";
|
|
import { XMLParser } from "fast-xml-parser";
|
|
import { z } from "zod/v4";
|
|
|
|
import { createDocumentationLink } from "./index";
|
|
|
|
const __filename = fileURLToPath(import.meta.url);
|
|
const __dirname = dirname(__filename);
|
|
|
|
const removeCommonUrl = (url: string) => {
|
|
return url.replace("https://homarr.dev", "");
|
|
};
|
|
|
|
const sitemapSchema = z.object({
|
|
urlset: z.object({
|
|
url: z.array(
|
|
z.object({
|
|
loc: z.string(),
|
|
}),
|
|
),
|
|
}),
|
|
});
|
|
|
|
const fetchSitemapAsync = async () => {
|
|
const response = await fetch(createDocumentationLink("/sitemap.xml"));
|
|
return await response.text();
|
|
};
|
|
|
|
const parseXml = (sitemapXml: string) => {
|
|
const parser = new XMLParser();
|
|
const data: unknown = parser.parse(sitemapXml);
|
|
const result = sitemapSchema.safeParse(data);
|
|
if (!result.success) {
|
|
throw new Error("Invalid sitemap schema");
|
|
}
|
|
|
|
return result.data;
|
|
};
|
|
|
|
const mapSitemapXmlToPaths = (sitemapData: z.infer<typeof sitemapSchema>) => {
|
|
return sitemapData.urlset.url.map((url) => removeCommonUrl(url.loc));
|
|
};
|
|
|
|
const createSitemapPathType = (paths: string[]) => {
|
|
return "export type HomarrDocumentationPath =\n" + paths.map((path) => ` | "${path.replace(/\/$/, "")}"`).join("\n");
|
|
};
|
|
|
|
const updateSitemapTypeFileAsync = async (sitemapPathType: string) => {
|
|
const content =
|
|
"// This file is auto-generated by the codegen script\n" +
|
|
"// it uses the sitemap.xml to generate the HomarrDocumentationPath type\n" +
|
|
sitemapPathType +
|
|
";\n";
|
|
|
|
await fs.writeFile(path.join(__dirname, "homarr-docs-sitemap.ts"), content);
|
|
};
|
|
|
|
/**
|
|
* This script fetches the sitemap.xml and generates the HomarrDocumentationPath type
|
|
* which is used for typesafe documentation links
|
|
*/
|
|
// eslint-disable-next-line no-restricted-syntax
|
|
const main = async () => {
|
|
const sitemapXml = await fetchSitemapAsync();
|
|
const sitemapData = parseXml(sitemapXml);
|
|
const paths = mapSitemapXmlToPaths(sitemapData);
|
|
// Adding sitemap as it's not in the sitemap.xml and we need it for this file
|
|
paths.push("/sitemap.xml");
|
|
const sitemapPathType = createSitemapPathType(paths);
|
|
await updateSitemapTypeFileAsync(sitemapPathType);
|
|
};
|
|
|
|
void main();
|