website: add a script to automatically replace the list of available schemas.
This script, `list-blueprint-schemas`, is a blunt and fragile object, but it can get the work done. Every time it is run, it will get a list of all version tags from Git, compare them to all the available schemas available by version, and print out a copy of `./website/docs/customize/blueprints/v1/structure.md` where it has replaced the existing `Available Older Blueprint Schemas` collapse block with the most up-to-date version. I will have to talk to @beryju and @tanberry to find out what they want done with this; would it be fine to just run this at build time *before* the site is compiled, replacing the structure.md file with this dynamic block, or can we generate it separately and [include it as a markdown extension](https://stackoverflow.com/questions/65741307/how-to-include-import-markdown-file-content-in-docusaurus-v2)?
This commit is contained in:
59
website/scripts/list-blueprint-schemas.mjs
Normal file
59
website/scripts/list-blueprint-schemas.mjs
Normal file
@ -0,0 +1,59 @@
|
||||
import { execSync } from "child_process";
|
||||
import { fileURLToPath } from "url";
|
||||
import { readFileSync } from "fs";
|
||||
import path from "path";
|
||||
|
||||
const __dirname = fileURLToPath(new URL(".", import.meta.url));
|
||||
const structureFilePath = path.join(__dirname, "../docs/customize/blueprints/v1/structure.md");
|
||||
|
||||
const cmd = ["git", "ls-remote", "--tags", "origin"].join(" ");
|
||||
const tagblob = execSync(cmd, { encoding: "utf8" });
|
||||
const itsadate = /\d{4}\.\d{1,2}\.\d{1,2}$/;
|
||||
const sortfn = (d1, d2) => {
|
||||
const [y1, m1, y2, m2] = [d1[0], d1[1], d2[0], d2[1]].map((s) => parseInt(s, 10));
|
||||
return y1 < y2 ? 1 : y1 > y2 ? -1 : m1 < m2 ? 1 : m1 > m2 ? -1 : 0;
|
||||
};
|
||||
|
||||
const taglines = tagblob
|
||||
.split("\n")
|
||||
.filter((line) => itsadate.test(line))
|
||||
.map((line) =>
|
||||
line
|
||||
.split("\t")[1]
|
||||
.replace("refs/tags/version/", "")
|
||||
.replace(/\.\d{1,2}$/, "")
|
||||
.split("."),
|
||||
)
|
||||
.toSorted(sortfn)
|
||||
.map(([a, b]) => `${a}-${b}`)
|
||||
.reduce((acc, a) => (acc.includes(a) ? acc : [...acc, a]), []);
|
||||
|
||||
const results = await Promise.allSettled(
|
||||
taglines.map((version) =>
|
||||
fetch(`https://version-${version}.goauthentik.io/blueprints/schema.json`, {
|
||||
method: "HEAD",
|
||||
}),
|
||||
),
|
||||
);
|
||||
|
||||
const version = /version-(\d{4}-\d{1,2})/;
|
||||
|
||||
const valid = results
|
||||
.filter((result) => result.status === "fulfilled" && result.value.status === 200)
|
||||
.map((result) => result.value.url)
|
||||
.map((url) => {
|
||||
const thedate = version.exec(url)[1];
|
||||
return `- [Version ${thedate}](${url})`;
|
||||
});
|
||||
|
||||
const structurefile = readFileSync(structureFilePath, "utf-8");
|
||||
const schemablock = /<Collapse title="Available Older Blueprint Schemas">.*?<\/Collapse>/m;
|
||||
|
||||
console.log(
|
||||
structurefile.replace(
|
||||
schemablock,
|
||||
`<Collapse title="Available Older Blueprint Schemas">
|
||||
${valid.join("\n")}
|
||||
</Collapse>`,
|
||||
),
|
||||
);
|
||||
Reference in New Issue
Block a user