MingruiZhang's picture
project list
fcd4478
raw
history blame
2.67 kB
import { auth } from '@/auth';
import { redirect } from 'next/navigation';
import { v5 as uuidV5 } from 'uuid';
interface ApiResponse<T> {
code: number; // code from server 0
message: string;
data: T;
}
const clefApiBuilder = <Params extends object | void, Resp>(path: string) => {
return async (params: Params): Promise<Resp> => {
const session = await auth();
if (!session?.user?.email) {
redirect('/');
}
const adminEmail = session.user.email;
const sessionUser = {
id: uuidV5(adminEmail, uuidV5.URL),
orgId: '-1024',
email: adminEmail,
username: adminEmail.split('@')[0],
userRole: 'adminPortal',
bucket: 'fake_bucket',
};
const baseURL = `https://app.dev.landing.ai/${path}`;
// Create a URL object with query params
const url = new URL(baseURL);
Object.entries(params ?? {}).forEach(([key, value]) =>
url.searchParams.append(key, value),
);
const res = await fetch(url.toString(), {
headers: {
'Content-Type': 'application/json',
sessionuser: JSON.stringify(sessionUser),
'X-ROUTE': 'mingruizhang-landing',
},
});
if (!res.ok) {
console.error('ERROR: fetch data failure', res.status);
// This will activate the closest `error.js` Error Boundary
throw new Error('Failed to fetch data');
}
const { data }: ApiResponse<Resp> = await res.json();
return data;
};
};
export type ProjectBaseInfo = {
id: number;
name: string;
created_at: Date;
organization: {
id: number;
name: string;
};
};
/**
* Fetch recent projects from all organizations from past 30 days, excluding
* 1. test organization such as bdd, cypress
* 2. internal organization such as landing, landing-ai, orgId=1
* 3. projects not containing media or only contain sample media
* @author https://github.com/landing-ai/landing-platform/blob/mingrui-04-08-meaningful-project/packages/server-clef/src/main_app/controllers/admin/get_admin_meaningful_project_controller.ts
*/
export const fetchRecentProjectList = clefApiBuilder<void, ProjectBaseInfo[]>(
'api/admin/projects/recent',
);
export type MediaDetails = {
id: number;
name: string;
path: string;
url: string;
projectId: number;
thumbnails: [string, string, string];
properties: {
width: number;
height: number;
format: string;
orientation: number;
};
};
/**
* Randomly fetch 10 media from a given project
* @author https://github.com/landing-ai/landing-platform/blob/mingrui-04-08-meaningful-project/packages/server-clef/src/main_app/controllers/admin/get_admin_meaningful_project_controller.ts
*/
export const fetchProjectMedia = clefApiBuilder<
{ projectId: number },
MediaDetails[]
>('api/admin/project/media');