Fix GitHub widget/data endpoints to prefer /github/api routes

This commit is contained in:
svemagie
2026-03-08 05:44:36 +01:00
parent 64e861873e
commit 722ff22328
10 changed files with 120 additions and 60 deletions
+21 -14
View File
@@ -16,21 +16,28 @@ const FALLBACK_FEATURED_REPOS = process.env.GITHUB_FEATURED_REPOS?.split(",").fi
* Fetch from Indiekit's public GitHub API endpoint * Fetch from Indiekit's public GitHub API endpoint
*/ */
async function fetchFromIndiekit(endpoint) { async function fetchFromIndiekit(endpoint) {
try { const urls = [
const url = `${INDIEKIT_URL}/githubapi/api/${endpoint}`; `${INDIEKIT_URL}/github/api/${endpoint}`,
console.log(`[githubActivity] Fetching from Indiekit: ${url}`); `${INDIEKIT_URL}/githubapi/api/${endpoint}`,
const data = await EleventyFetch(url, { ];
duration: "15m",
type: "json", for (const url of urls) {
}); try {
console.log(`[githubActivity] Indiekit ${endpoint} success`); console.log(`[githubActivity] Fetching from Indiekit: ${url}`);
return data; const data = await EleventyFetch(url, {
} catch (error) { duration: "15m",
console.log( type: "json",
`[githubActivity] Indiekit API unavailable for ${endpoint}: ${error.message}` });
); console.log(`[githubActivity] Indiekit ${endpoint} success via ${url}`);
return null; return data;
} catch (error) {
console.log(
`[githubActivity] Indiekit API unavailable for ${endpoint} at ${url}: ${error.message}`
);
}
} }
return null;
} }
/** /**
+21 -9
View File
@@ -12,16 +12,28 @@ const INDIEKIT_URL = process.env.SITE_URL || "https://example.com";
export default async function () { export default async function () {
try { try {
const url = `${INDIEKIT_URL}/githubapi/api/starred/all`; const urls = [
const response = await EleventyFetch(url, { `${INDIEKIT_URL}/github/api/starred/all`,
duration: "15m", `${INDIEKIT_URL}/githubapi/api/starred/all`,
type: "json", ];
});
return { for (const url of urls) {
totalCount: response.totalCount || 0, try {
buildDate: new Date().toISOString(), const response = await EleventyFetch(url, {
}; duration: "15m",
type: "json",
});
return {
totalCount: response.totalCount || 0,
buildDate: new Date().toISOString(),
};
} catch (error) {
console.log(`[githubStarred] Could not fetch ${url}: ${error.message}`);
}
}
throw new Error("No GitHub starred endpoint responded");
} catch (error) { } catch (error) {
console.log(`[githubStarred] Could not fetch starred count: ${error.message}`); console.log(`[githubStarred] Could not fetch starred count: ${error.message}`);
return { return {
@@ -255,9 +255,9 @@ function githubWidget(username) {
try { try {
const [commitsRes, featuredRes, contribRes] = await Promise.all([ const [commitsRes, featuredRes, contribRes] = await Promise.all([
this.fetchJson(['/githubapi/api/commits', '/github/api/commits']), this.fetchJson(['/github/api/commits', '/githubapi/api/commits']),
this.fetchJson(['/githubapi/api/featured', '/github/api/featured']), this.fetchJson(['/github/api/featured', '/githubapi/api/featured']),
this.fetchJson(['/githubapi/api/contributions', '/github/api/contributions']), this.fetchJson(['/github/api/contributions', '/githubapi/api/contributions']),
]); ]);
if (commitsRes.ok) { if (commitsRes.ok) {
+1 -1
View File
@@ -182,8 +182,8 @@ function changelogApp() {
async fetchChangelog(days) { async fetchChangelog(days) {
try { try {
const result = await this.fetchJson([ const result = await this.fetchJson([
'/githubapi/api/changelog?days=' + days,
'/github/api/changelog?days=' + days, '/github/api/changelog?days=' + days,
'/githubapi/api/changelog?days=' + days,
]); ]);
if (!result.ok) throw new Error('Failed to fetch'); if (!result.ok) throw new Error('Failed to fetch');
+14 -3
View File
@@ -422,9 +422,20 @@ document.addEventListener("alpine:init", () => {
async init() { async init() {
try { try {
const res = await fetch("/githubapi/api/starred/all"); let data = null;
if (!res.ok) throw new Error("API returned " + res.status); for (const path of ["/github/api/starred/all", "/githubapi/api/starred/all"]) {
const data = await res.json(); try {
const res = await fetch(path);
if (res.ok) {
data = await res.json();
break;
}
} catch {
// Try next candidate path.
}
}
if (!data) throw new Error("API returned no usable response");
this.allStars = data.stars || []; this.allStars = data.stars || [];
this.listMeta = (data.listMeta || []).sort((a, b) => a.name.localeCompare(b.name)); this.listMeta = (data.listMeta || []).sort((a, b) => a.name.localeCompare(b.name));
this.totalCount = data.totalCount || 0; this.totalCount = data.totalCount || 0;
+21 -14
View File
@@ -16,21 +16,28 @@ const FALLBACK_FEATURED_REPOS = process.env.GITHUB_FEATURED_REPOS?.split(",").fi
* Fetch from Indiekit's public GitHub API endpoint * Fetch from Indiekit's public GitHub API endpoint
*/ */
async function fetchFromIndiekit(endpoint) { async function fetchFromIndiekit(endpoint) {
try { const urls = [
const url = `${INDIEKIT_URL}/githubapi/api/${endpoint}`; `${INDIEKIT_URL}/github/api/${endpoint}`,
console.log(`[githubActivity] Fetching from Indiekit: ${url}`); `${INDIEKIT_URL}/githubapi/api/${endpoint}`,
const data = await EleventyFetch(url, { ];
duration: "15m",
type: "json", for (const url of urls) {
}); try {
console.log(`[githubActivity] Indiekit ${endpoint} success`); console.log(`[githubActivity] Fetching from Indiekit: ${url}`);
return data; const data = await EleventyFetch(url, {
} catch (error) { duration: "15m",
console.log( type: "json",
`[githubActivity] Indiekit API unavailable for ${endpoint}: ${error.message}` });
); console.log(`[githubActivity] Indiekit ${endpoint} success via ${url}`);
return null; return data;
} catch (error) {
console.log(
`[githubActivity] Indiekit API unavailable for ${endpoint} at ${url}: ${error.message}`
);
}
} }
return null;
} }
/** /**
+21 -9
View File
@@ -12,16 +12,28 @@ const INDIEKIT_URL = process.env.SITE_URL || "https://example.com";
export default async function () { export default async function () {
try { try {
const url = `${INDIEKIT_URL}/githubapi/api/starred/all`; const urls = [
const response = await EleventyFetch(url, { `${INDIEKIT_URL}/github/api/starred/all`,
duration: "15m", `${INDIEKIT_URL}/githubapi/api/starred/all`,
type: "json", ];
});
return { for (const url of urls) {
totalCount: response.totalCount || 0, try {
buildDate: new Date().toISOString(), const response = await EleventyFetch(url, {
}; duration: "15m",
type: "json",
});
return {
totalCount: response.totalCount || 0,
buildDate: new Date().toISOString(),
};
} catch (error) {
console.log(`[githubStarred] Could not fetch ${url}: ${error.message}`);
}
}
throw new Error("No GitHub starred endpoint responded");
} catch (error) { } catch (error) {
console.log(`[githubStarred] Could not fetch starred count: ${error.message}`); console.log(`[githubStarred] Could not fetch starred count: ${error.message}`);
return { return {
@@ -247,9 +247,9 @@ function githubWidget(username) {
try { try {
const [commitsRes, featuredRes, contribRes] = await Promise.all([ const [commitsRes, featuredRes, contribRes] = await Promise.all([
this.fetchJson(['/githubapi/api/commits', '/github/api/commits']), this.fetchJson(['/github/api/commits', '/githubapi/api/commits']),
this.fetchJson(['/githubapi/api/featured', '/github/api/featured']), this.fetchJson(['/github/api/featured', '/githubapi/api/featured']),
this.fetchJson(['/githubapi/api/contributions', '/github/api/contributions']), this.fetchJson(['/github/api/contributions', '/githubapi/api/contributions']),
]); ]);
if (commitsRes.ok) { if (commitsRes.ok) {
+1 -1
View File
@@ -180,8 +180,8 @@ function changelogApp() {
async fetchChangelog(days) { async fetchChangelog(days) {
try { try {
const result = await this.fetchJson([ const result = await this.fetchJson([
'/githubapi/api/changelog?days=' + days,
'/github/api/changelog?days=' + days, '/github/api/changelog?days=' + days,
'/githubapi/api/changelog?days=' + days,
]); ]);
if (!result.ok) throw new Error('Failed to fetch'); if (!result.ok) throw new Error('Failed to fetch');
+14 -3
View File
@@ -416,9 +416,20 @@ document.addEventListener("alpine:init", () => {
async init() { async init() {
try { try {
const res = await fetch("/githubapi/api/starred/all"); let data = null;
if (!res.ok) throw new Error("API returned " + res.status); for (const path of ["/github/api/starred/all", "/githubapi/api/starred/all"]) {
const data = await res.json(); try {
const res = await fetch(path);
if (res.ok) {
data = await res.json();
break;
}
} catch {
// Try next candidate path.
}
}
if (!data) throw new Error("API returned no usable response");
this.allStars = data.stars || []; this.allStars = data.stars || [];
this.listMeta = (data.listMeta || []).sort((a, b) => a.name.localeCompare(b.name)); this.listMeta = (data.listMeta || []).sort((a, b) => a.name.localeCompare(b.name));
this.totalCount = data.totalCount || 0; this.totalCount = data.totalCount || 0;