fix: Replace the bunch of db functions with a Db class
This commit is contained in:
		
							parent
							
								
									fd8b8cdfd3
								
							
						
					
					
						commit
						95108ab9eb
					
				| @ -1,8 +1,16 @@ | |||||||
| import cassandra from 'cassandra-driver'; | import cassandra from 'cassandra-driver'; | ||||||
| 
 | 
 | ||||||
| async function createChannel(client: cassandra.Client, channelName: string) { | class Db { | ||||||
|  |   private client: cassandra.Client; | ||||||
|  | 
 | ||||||
|  |   constructor(client: cassandra.Client) { | ||||||
|  |     this.client = client; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   // Create Channel Method
 | ||||||
|  |   async createChannel(channelName: string) { | ||||||
|     try { |     try { | ||||||
|     await client.execute(` |       await this.client.execute(` | ||||||
|       CREATE TABLE IF NOT EXISTS channels.channel_${channelName} ( |       CREATE TABLE IF NOT EXISTS channels.channel_${channelName} ( | ||||||
|           id UUID, |           id UUID, | ||||||
|           message_content TEXT, |           message_content TEXT, | ||||||
| @ -15,33 +23,36 @@ async function createChannel(client: cassandra.Client, channelName: string) { | |||||||
|       // @ts-expect-error I don't like this thing yelling at me
 |       // @ts-expect-error I don't like this thing yelling at me
 | ||||||
|       console.log(`Error creating new channel: ${e.message}`); |       console.log(`Error creating new channel: ${e.message}`); | ||||||
|     } |     } | ||||||
| } |   } | ||||||
| 
 | 
 | ||||||
| async function storeMessage(client: cassandra.Client, channelName: string, content: string, sender: string, id: string) { |   // Send message method
 | ||||||
|  |   async sendMessage(channelName: string, content: string, sender: string, id: string) { | ||||||
|     try { |     try { | ||||||
|       const now = new Date(); |       const now = new Date(); | ||||||
|     await client.execute(`INSERT INTO channels.channel_${channelName} (id, message_content, channel_name, timestamp, sender)
 |       await this.client.execute(`INSERT INTO channels.channel_${channelName} (id, message_content, channel_name, timestamp, sender)
 | ||||||
|                    VALUES (${id}, '${content}', '${channelName}', ${now.getTime()}, ${sender})`);
 |                    VALUES (${id}, '${content}', '${channelName}', ${now.getTime()}, ${sender})`);
 | ||||||
|     } catch (e) { |     } catch (e) { | ||||||
|       // @ts-expect-error I don't like this thing yelling at me
 |       // @ts-expect-error I don't like this thing yelling at me
 | ||||||
|       console.log(`Error storing messages: ${e.message}`); |       console.log(`Error storing messages: ${e.message}`); | ||||||
|     } |     } | ||||||
| } |   } | ||||||
| 
 | 
 | ||||||
| async function getChannels(client: cassandra.Client): Promise<cassandra.types.Row[] | undefined> { |   // Get Channels method
 | ||||||
|  |   async getChannels(): Promise<cassandra.types.Row[] | undefined> { | ||||||
|     try { |     try { | ||||||
|     const res = await client.execute(`SELECT table_name FROM system_schema.tables WHERE keyspace_name = 'channels'`); |       const res = await this.client.execute(`SELECT table_name FROM system_schema.tables WHERE keyspace_name = 'channels'`); | ||||||
|       return res.rows; |       return res.rows; | ||||||
|     } catch (e) { |     } catch (e) { | ||||||
|       // @ts-expect-error I don't like this thing yelling at me
 |       // @ts-expect-error I don't like this thing yelling at me
 | ||||||
|       console.log(`Error fetching channels: ${e.message}`); |       console.log(`Error fetching channels: ${e.message}`); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
| } |   } | ||||||
| 
 | 
 | ||||||
| async function getMessages(client: cassandra.Client, channelName: string, limit: number): Promise<cassandra.types.Row[] | undefined> { |   // Get messages method
 | ||||||
|  |   async getMessages(channelName: string, limit: number): Promise<cassandra.types.Row[] | undefined> { | ||||||
|     try { |     try { | ||||||
|     const res = await client.execute( |       const res = await this.client.execute( | ||||||
|         `SELECT * FROM channels.channel_${channelName} WHERE channel_name = '${channelName}' ORDER BY timestamp DESC LIMIT ${limit}`, |         `SELECT * FROM channels.channel_${channelName} WHERE channel_name = '${channelName}' ORDER BY timestamp DESC LIMIT ${limit}`, | ||||||
|       ); |       ); | ||||||
|       return res.rows; |       return res.rows; | ||||||
| @ -50,6 +61,7 @@ async function getMessages(client: cassandra.Client, channelName: string, limit: | |||||||
|       console.log(`Error fetching messages: ${e.message}`); |       console.log(`Error fetching messages: ${e.message}`); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const client = new cassandra.Client({ | const client = new cassandra.Client({ | ||||||
| @ -76,4 +88,6 @@ try { | |||||||
|   process.exit(1); |   process.exit(1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export { client, createChannel, getChannels, getMessages, storeMessage }; | const db = new Db(client); | ||||||
|  | 
 | ||||||
|  | export { db }; | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ import { Server as SocketIOServer } from 'socket.io'; | |||||||
| import type { HttpServer } from 'vite'; | import type { HttpServer } from 'vite'; | ||||||
| // Don't try to replace with $lib alias. Since this
 | // Don't try to replace with $lib alias. Since this
 | ||||||
| // file gets loaded as a vite plugin, it will crash
 | // file gets loaded as a vite plugin, it will crash
 | ||||||
| import { client, createChannel, storeMessage } from './server/db/'; | import { db } from './server/db/'; | ||||||
| import { v4 as uuidv4 } from 'uuid'; | import { v4 as uuidv4 } from 'uuid'; | ||||||
| 
 | 
 | ||||||
| let io: SocketIOServer | undefined; | let io: SocketIOServer | undefined; | ||||||
| @ -21,8 +21,8 @@ export function startupSocketIOServer(httpServer: HttpServer | null) { | |||||||
|       if (msg.content !== '') { |       if (msg.content !== '') { | ||||||
|         console.log(`[ws:kit] message from ${socket.id}: ${msg.content}`); |         console.log(`[ws:kit] message from ${socket.id}: ${msg.content}`); | ||||||
|         // Store the message in the database
 |         // Store the message in the database
 | ||||||
|         await createChannel(client, '000'); |         await db.createChannel('000'); | ||||||
|         await storeMessage(client, '000', msg.content, msg.id, uuidv4()); |         await db.sendMessage('000', msg.content, msg.id, uuidv4()); | ||||||
|         io!.emit('message', { |         io!.emit('message', { | ||||||
|           user: msg.id, |           user: msg.id, | ||||||
|           message: msg.content, |           message: msg.content, | ||||||
|  | |||||||
| @ -1,8 +1,8 @@ | |||||||
| import { getChannels, client } from '$lib/server/db'; | import { db } from '$lib/server/db'; | ||||||
| import type { LayoutServerLoad } from './$types'; | import type { LayoutServerLoad } from './$types'; | ||||||
| 
 | 
 | ||||||
| export const load: LayoutServerLoad = async () => { | export const load: LayoutServerLoad = async () => { | ||||||
|   const rows = await getChannels(client); |   const rows = await db.getChannels(); | ||||||
|   const channels: string[] = rows |   const channels: string[] = rows | ||||||
|     ? rows.map((value) => { |     ? rows.map((value) => { | ||||||
|         return value.table_name; |         return value.table_name; | ||||||
|  | |||||||
| @ -1,8 +1,8 @@ | |||||||
| import type { TypeMessage } from '$lib'; | import type { TypeMessage } from '$lib'; | ||||||
| import { getMessages, client } from '$lib/server/db'; | import { db } from '$lib/server/db'; | ||||||
| 
 | 
 | ||||||
| export async function load(): Promise<{ messages: TypeMessage[] }> { | export async function load(): Promise<{ messages: TypeMessage[] }> { | ||||||
|   const rows = await getMessages(client, '000', 50); |   const rows = await db.getMessages('000', 50); | ||||||
|   const messages: TypeMessage[] = rows |   const messages: TypeMessage[] = rows | ||||||
|     ? rows.map((value) => { |     ? rows.map((value) => { | ||||||
|         return { |         return { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user