All checks were successful
Build and Push Docker Image to Gitea / build-and-push (push) Successful in 4m23s
- Remove "type": "module" and switch tsconfig to CommonJS/Node resolution to fix drizzle-kit ESM/CJS incompatibility - Strip .js extensions from all backend TypeScript imports - Fix gamification resolver: combine two .where() calls using and() - Fix index.ts: wrap top-level awaits in async main(), fix Fastify+yoga request handling via handleNodeRequestAndResponse - Generate initial Drizzle SQL migration (0000_pale_hellion.sql) for all 15 tables - Add src/scripts/migrate.ts: programmatic Drizzle migrator for production - Copy migrations folder into Docker image (Dockerfile.backend) - Add schema:migrate npm script Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
30 lines
858 B
TypeScript
30 lines
858 B
TypeScript
import { builder } from "../builder";
|
|
import { StatsType } from "../types/index";
|
|
import { users, videos } from "../../db/schema/index";
|
|
import { eq, count } from "drizzle-orm";
|
|
|
|
builder.queryField("stats", (t) =>
|
|
t.field({
|
|
type: StatsType,
|
|
resolve: async (_root, _args, ctx) => {
|
|
const modelsCount = await ctx.db
|
|
.select({ count: count() })
|
|
.from(users)
|
|
.where(eq(users.role, "model"));
|
|
const viewersCount = await ctx.db
|
|
.select({ count: count() })
|
|
.from(users)
|
|
.where(eq(users.role, "viewer"));
|
|
const videosCount = await ctx.db
|
|
.select({ count: count() })
|
|
.from(videos);
|
|
|
|
return {
|
|
models_count: modelsCount[0]?.count || 0,
|
|
viewers_count: viewersCount[0]?.count || 0,
|
|
videos_count: videosCount[0]?.count || 0,
|
|
};
|
|
},
|
|
}),
|
|
);
|