videofolxtv/server/storage.ts
sebastjanartic edf1e36795 Set up video streaming website with Bunny.net CDN integration
Initialize project structure with UI components, CDN video display, and configurations.

Replit-Commit-Author: Agent
Replit-Commit-Session-Id: 50814a1e-92e4-4968-856f-7bc7eedf5e8f
Replit-Commit-Checkpoint-Type: full_checkpoint
Replit-Commit-Screenshot-Url: https://storage.googleapis.com/screenshot-production-us-central1/8cc42625-c1f5-4e43-99bd-77f2c4dedee2/50814a1e-92e4-4968-856f-7bc7eedf5e8f/uoltFyL
2025-08-04 18:24:29 +00:00

150 lines
5.8 KiB
TypeScript

import { type Video, type InsertVideo } from "@shared/schema";
import { randomUUID } from "crypto";
export interface IStorage {
getVideos(limit?: number, offset?: number, search?: string, category?: string): Promise<Video[]>;
getVideo(id: string): Promise<Video | undefined>;
createVideo(video: InsertVideo): Promise<Video>;
updateVideoViews(id: string): Promise<void>;
getVideoCount(search?: string, category?: string): Promise<number>;
}
export class MemStorage implements IStorage {
private videos: Map<string, Video>;
constructor() {
this.videos = new Map();
// Initialize with some sample videos for demonstration
// In production, these would be fetched from bunny.net API
this.initializeSampleVideos();
}
private initializeSampleVideos() {
const sampleVideos: InsertVideo[] = [
{
title: "Advanced Web Development Techniques and Best Practices",
description: "Learn modern web development techniques including React, TypeScript, and performance optimization strategies.",
thumbnailUrl: "https://images.unsplash.com/photo-1560472355-536de3962603?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&h=450",
videoUrl: "https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4",
duration: 754, // 12:34
views: 2100,
category: "Tutorial"
},
{
title: "Team Collaboration Strategies for Remote Work",
description: "Effective strategies for managing remote teams and improving collaboration in distributed environments.",
thumbnailUrl: "https://images.unsplash.com/photo-1552664730-d307ca884978?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&h=450",
videoUrl: "https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ElephantsDream.mp4",
duration: 495, // 8:15
views: 856,
category: "Business"
},
{
title: "Modern UI/UX Design Principles and Workflows",
description: "Comprehensive guide to modern design principles, user experience optimization, and design system creation.",
thumbnailUrl: "https://images.unsplash.com/photo-1581291518857-4e27b48ff24e?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&h=450",
videoUrl: "https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ForBiggerBlazes.mp4",
duration: 942, // 15:42
views: 3700,
category: "Design"
},
{
title: "Data Analytics and Business Intelligence Tutorial",
description: "Learn how to analyze data effectively using modern tools and create meaningful business insights.",
thumbnailUrl: "https://images.unsplash.com/photo-1551288049-bebda4e38f71?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&h=450",
videoUrl: "https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ForBiggerEscapes.mp4",
duration: 1328, // 22:08
views: 1400,
category: "Analytics"
},
{
title: "Mobile App Development: From Concept to Launch",
description: "Complete guide to mobile app development covering design, development, testing, and deployment strategies.",
thumbnailUrl: "https://images.unsplash.com/photo-1512941937669-90a1b58e7e9c?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&h=450",
videoUrl: "https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ForBiggerFun.mp4",
duration: 1113, // 18:33
views: 4200,
category: "Mobile"
},
{
title: "Cloud Infrastructure and DevOps Fundamentals",
description: "Understanding cloud computing, infrastructure as code, and DevOps practices for modern applications.",
thumbnailUrl: "https://images.unsplash.com/photo-1558494949-ef010cbdcc31?ixlib=rb-4.0.3&auto=format&fit=crop&w=800&h=450",
videoUrl: "https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/ForBiggerJoyrides.mp4",
duration: 1517, // 25:17
views: 987,
category: "DevOps"
}
];
sampleVideos.forEach(video => {
const id = randomUUID();
const fullVideo: Video = {
...video,
id,
views: video.views || 0,
description: video.description || null,
category: video.category || null,
createdAt: new Date()
};
this.videos.set(id, fullVideo);
});
}
async getVideos(limit = 20, offset = 0, search?: string, category?: string): Promise<Video[]> {
let videos = Array.from(this.videos.values());
// Filter by search
if (search) {
const searchLower = search.toLowerCase();
videos = videos.filter(video =>
video.title.toLowerCase().includes(searchLower) ||
video.description?.toLowerCase().includes(searchLower)
);
}
// Filter by category
if (category && category !== "All Categories") {
videos = videos.filter(video => video.category === category);
}
// Sort by created date (newest first)
videos.sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime());
return videos.slice(offset, offset + limit);
}
async getVideo(id: string): Promise<Video | undefined> {
return this.videos.get(id);
}
async createVideo(video: InsertVideo): Promise<Video> {
const id = randomUUID();
const fullVideo: Video = {
...video,
id,
views: video.views || 0,
description: video.description || null,
category: video.category || null,
createdAt: new Date()
};
this.videos.set(id, fullVideo);
return fullVideo;
}
async updateVideoViews(id: string): Promise<void> {
const video = this.videos.get(id);
if (video) {
video.views += 1;
this.videos.set(id, video);
}
}
async getVideoCount(search?: string, category?: string): Promise<number> {
const videos = await this.getVideos(1000, 0, search, category);
return videos.length;
}
}
export const storage = new MemStorage();