AeThex-OS/temp-forge-extract/aethex-forge-main/api/admin/foundation/courses.ts
MrPiglr b3c308b2c8 Add functional marketplace modules, bottom nav bar, root terminal, arcade games
- ModuleManager: Central tracking for installed marketplace modules
- DataAnalyzerWidget: Real-time CPU/RAM/Battery/Storage widget (unlocked by Data Analyzer module)
- BottomNavBar: Navigation bar for Projects/Chat/Marketplace/Settings
- RootShell: Real root command execution utility
- TerminalActivity: Full root shell with neofetch, sysinfo, real Linux commands
- Terminal Pro module: Adds aliases (ll, la, h), command history
- ArcadeActivity + SnakeGame: Pixel Arcade module unlocks retro games
- fade_in/fade_out animations for smooth transitions
2026-02-18 22:03:50 -07:00

58 lines
1.5 KiB
TypeScript

import { createClient } from "@supabase/supabase-js";
const supabase = createClient(
process.env.VITE_SUPABASE_URL!,
process.env.SUPABASE_SERVICE_ROLE!,
);
export default async function handler(req: any, res: any) {
if (req.method === "GET") {
try {
const { data: courses, error } = await supabase
.from("foundation_courses")
.select(
`
id,
slug,
title,
description,
category,
difficulty,
instructor_id,
cover_image_url,
estimated_hours,
is_published,
user_profiles!foundation_courses_instructor_id_fkey (
id,
full_name
)
`,
)
.order("created_at", { ascending: false });
if (error) throw error;
const formattedCourses = (courses || []).map((c: any) => ({
id: c.id,
slug: c.slug,
title: c.title,
description: c.description,
category: c.category,
difficulty: c.difficulty,
instructor_id: c.instructor_id,
instructor_name: c.user_profiles?.full_name,
cover_image_url: c.cover_image_url,
estimated_hours: c.estimated_hours,
is_published: c.is_published,
}));
res.status(200).json(formattedCourses);
} catch (error: any) {
res
.status(500)
.json({ error: error.message || "Failed to fetch courses" });
}
} else {
res.status(405).json({ error: "Method not allowed" });
}
}