feat: redeploy from admin panel
This commit is contained in:
parent
cd564c4856
commit
6d7f022230
3 changed files with 63 additions and 0 deletions
9
apps/blog/src/env.d.ts
vendored
9
apps/blog/src/env.d.ts
vendored
|
|
@ -1 +1,10 @@
|
|||
/// <reference types="astro/client" />
|
||||
|
||||
interface ImportMetaEnv {
|
||||
readonly VERCEL_DEPLOY_HOOK: string;
|
||||
readonly ADMIN_GITHUB_ID: string;
|
||||
}
|
||||
|
||||
interface ImportMeta {
|
||||
readonly env: ImportMetaEnv;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -42,6 +42,8 @@ function formatDate(date: Date): string {
|
|||
<h1>guestbook admin</h1>
|
||||
<p>logged in as {session.user?.name} <a href="/api/auth/signout">sign out</a></p>
|
||||
|
||||
<p><button id="deploy">redeploy site</button> <span id="deploy-status"></span></p>
|
||||
|
||||
{entries.length === 0 ? (
|
||||
<p class="muted">no pending entries</p>
|
||||
) : (
|
||||
|
|
@ -60,6 +62,22 @@ function formatDate(date: Date): string {
|
|||
)}
|
||||
|
||||
<script>
|
||||
document.getElementById('deploy')?.addEventListener('click', async (e) => {
|
||||
const btn = e.target as HTMLButtonElement;
|
||||
const status = document.getElementById('deploy-status');
|
||||
btn.disabled = true;
|
||||
if (status) status.textContent = 'deploying...';
|
||||
|
||||
const res = await fetch('/api/deploy', { method: 'POST' });
|
||||
if (res.ok) {
|
||||
if (status) status.textContent = 'deploy triggered!';
|
||||
} else {
|
||||
const data = await res.json();
|
||||
if (status) status.textContent = data.error || 'deploy failed';
|
||||
}
|
||||
btn.disabled = false;
|
||||
});
|
||||
|
||||
document.querySelectorAll('#entries li').forEach(li => {
|
||||
const id = li.getAttribute('data-id');
|
||||
|
||||
|
|
|
|||
36
apps/blog/src/pages/api/deploy.ts
Normal file
36
apps/blog/src/pages/api/deploy.ts
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
import type { APIRoute } from 'astro';
|
||||
import { getSession } from 'auth-astro/server';
|
||||
import { isAdmin } from '../../lib/auth';
|
||||
|
||||
export const prerender = false;
|
||||
|
||||
export const POST: APIRoute = async ({ request }) => {
|
||||
const session = await getSession(request);
|
||||
|
||||
if (!session?.user?.id || !isAdmin(session.user.id)) {
|
||||
return new Response(JSON.stringify({ error: 'Unauthorized' }), {
|
||||
status: 403,
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
});
|
||||
}
|
||||
|
||||
const hookUrl = import.meta.env.VERCEL_DEPLOY_HOOK;
|
||||
if (!hookUrl) {
|
||||
return new Response(JSON.stringify({ error: 'Deploy hook not configured' }), {
|
||||
status: 500,
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
});
|
||||
}
|
||||
|
||||
const res = await fetch(hookUrl, { method: 'POST' });
|
||||
if (!res.ok) {
|
||||
return new Response(JSON.stringify({ error: 'Failed to trigger deploy' }), {
|
||||
status: 502,
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
});
|
||||
}
|
||||
|
||||
return new Response(JSON.stringify({ success: true }), {
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
});
|
||||
};
|
||||
Loading…
Add table
Add a link
Reference in a new issue