mirror of
https://github.com/nestriness/nestri.git
synced 2025-12-12 08:45:38 +02:00
## Description <!-- Briefly describe the purpose and scope of your changes --> <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Added AWS queue infrastructure and SQS handler for processing Steam game libraries and images. - Introduced event-driven handling for new credentials and game additions, including image uploads to S3. - Added client functions to fetch Steam user libraries, friends lists, app info, and related images. - Added new database columns and schema updates to track game acquisition, playtime, and family sharing. - Added utility function for chunking arrays. - Added new event notifications for library queue processing and game creation. - Added new lookup functions for categories and teams by slug. - Introduced a new Team API with endpoints to list and fetch teams by slug. - Added a new Steam library page displaying game images. - **Enhancements** - Improved game creation with event notifications and upsert logic. - Enhanced category and team retrieval with new lookup functions. - Renamed and refined image categories for clearer classification. - Expanded dependencies for image processing and AWS SDK integration. - Improved image processing utilities with caching, ranking, and metadata extraction. - Refined Steam client utilities for concurrency and error handling. - **Bug Fixes** - Fixed event publishing timing and removed deprecated credential retrieval methods. - **Chores** - Updated infrastructure configurations with increased timeouts, memory, and resource linking. - Added new dependencies for image processing, caching, and AWS SDK clients. - Refined internal code structure and imports for clarity. - Removed Steam provider and related UI components from the frontend. - Disabled authentication providers and Steam-related routes in the frontend. - Updated API fetch handler to accept environment bindings. - **Refactor** - Simplified query result handling and renamed functions for better clarity. - Removed outdated event handler in favor of consolidated event subscriber. - Consolidated and simplified database relationships and permission queries. - **Tests** - No explicit test changes included in this release. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
46 lines
1.6 KiB
TypeScript
46 lines
1.6 KiB
TypeScript
import { z } from "zod";
|
|
import { timestamps } from "../drizzle/types";
|
|
import { baseGamesTable } from "../base-game/base-game.sql";
|
|
import { index, integer, json, pgEnum, pgTable, primaryKey, text, varchar } from "drizzle-orm/pg-core";
|
|
|
|
export const ImageTypeEnum = pgEnum("image_type", ["heroArt", "icon", "logo", "banner", "poster", "boxArt", "screenshot", "backdrop"])
|
|
|
|
export const ImageDimensions = z.object({
|
|
width: z.number().int(),
|
|
height: z.number().int(),
|
|
})
|
|
|
|
export const ImageColor = z.object({
|
|
hex: z.string(),
|
|
isDark: z.boolean()
|
|
})
|
|
|
|
export type ImageColor = z.infer<typeof ImageColor>;
|
|
export type ImageDimensions = z.infer<typeof ImageDimensions>;
|
|
|
|
export const imagesTable = pgTable(
|
|
"images",
|
|
{
|
|
...timestamps,
|
|
type: ImageTypeEnum("type").notNull(),
|
|
imageHash: varchar("image_hash", { length: 255 })
|
|
.notNull(),
|
|
baseGameID: varchar("base_game_id", { length: 255 })
|
|
.notNull()
|
|
.references(() => baseGamesTable.id, {
|
|
onDelete: "cascade"
|
|
}),
|
|
sourceUrl: text("source_url"), // The BoxArt is source Url will always be null;
|
|
position: integer("position").notNull().default(0),
|
|
fileSize: integer("file_size").notNull(),
|
|
dimensions: json("dimensions").$type<ImageDimensions>().notNull(),
|
|
extractedColor: json("extracted_color").$type<ImageColor>().notNull(),
|
|
},
|
|
(table) => [
|
|
primaryKey({
|
|
columns: [table.imageHash, table.type, table.baseGameID, table.position]
|
|
}),
|
|
index("idx_images_type").on(table.type),
|
|
index("idx_images_game_id").on(table.baseGameID),
|
|
]
|
|
) |