Compare commits
	
		
			2 commits
		
	
	
		
			471f399176
			...
			9d98299264
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9d98299264 | |||
| 3b7f2006ef | 
					 2 changed files with 20 additions and 70 deletions
				
			
		|  | @ -47,13 +47,27 @@ def get_or_create_user(username): | ||||||
|     user_id = CURSOR.lastrowid |     user_id = CURSOR.lastrowid | ||||||
|     return user_id |     return user_id | ||||||
| 
 | 
 | ||||||
| def insert_character(name: str, rarity: int, weight: float, file_id: str) -> int: | def insert_character(name: str, rarity: int, weight: float, file_id: str, stats: dict) -> int: | ||||||
|     '''Inserts a character''' |     '''Inserts a character''' | ||||||
|     CURSOR.execute( |     CURSOR.execute( | ||||||
|         'INSERT INTO characters (name, rarity, weight, file_id) VALUES (?, ?, ?, ?)', |         'INSERT INTO characters (name, rarity, weight, file_id) VALUES (?, ?, ?, ?)', | ||||||
|         (name, rarity, weight, file_id) |         (name, rarity, weight, file_id) | ||||||
|     ) |     ) | ||||||
|     character_id = CURSOR.lastrowid |     character_id = CURSOR.lastrowid | ||||||
|  | 
 | ||||||
|  |     # Insert stats | ||||||
|  |     columns = ', '.join(stats.keys()) | ||||||
|  |     placeholders = ', '.join(['?'] * len(stats)) | ||||||
|  |     updates = ', '.join([f"{col}=excluded.{col}" for col in stats.keys()]) | ||||||
|  |     values = list(stats.values()) | ||||||
|  | 
 | ||||||
|  |     sql = f''' | ||||||
|  |         INSERT INTO character_stats (character_id, {columns}) | ||||||
|  |         VALUES (?, {placeholders}) | ||||||
|  |         ON CONFLICT(character_id) DO UPDATE SET {updates} | ||||||
|  |     ''' | ||||||
|  |     CURSOR.execute(sql, [character_id] + values) | ||||||
|  | 
 | ||||||
|     return character_id if character_id else 0 |     return character_id if character_id else 0 | ||||||
| 
 | 
 | ||||||
| def insert_pull(user_id, character_id): | def insert_pull(user_id, character_id): | ||||||
|  | @ -85,69 +99,7 @@ def set_config(key, value): | ||||||
| 
 | 
 | ||||||
| # Character stat functions | # Character stat functions | ||||||
| 
 | 
 | ||||||
| def add_character_stats(character_id, stats): | def get_characters(character_ids): | ||||||
|     ''' |  | ||||||
|     Adds or updates character stats in the character_stats table. |  | ||||||
|     `stats` should be a dictionary like {'power': 5, 'charm': 3} |  | ||||||
|     ''' |  | ||||||
|     if not stats: |  | ||||||
|         return |  | ||||||
| 
 |  | ||||||
|     conn = get_db_connection() |  | ||||||
|     cur = conn.cursor() |  | ||||||
| 
 |  | ||||||
|     columns = ', '.join(stats.keys()) |  | ||||||
|     placeholders = ', '.join(['?'] * len(stats)) |  | ||||||
|     updates = ', '.join([f"{col}=excluded.{col}" for col in stats.keys()]) |  | ||||||
|      |  | ||||||
|     values = list(stats.values()) |  | ||||||
| 
 |  | ||||||
|     sql = f''' |  | ||||||
|         INSERT INTO character_stats (character_id, {columns}) |  | ||||||
|         VALUES (?, {placeholders}) |  | ||||||
|         ON CONFLICT(character_id) DO UPDATE SET {updates} |  | ||||||
|     ''' |  | ||||||
|     cur.execute(sql, [character_id] + values) |  | ||||||
|     conn.commit() |  | ||||||
|     conn.close() |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| def update_character_stat(character_id, stat_name, value): |  | ||||||
|     '''Updates a single stat field for a character''' |  | ||||||
|     conn = get_db_connection() |  | ||||||
|     cur = conn.cursor() |  | ||||||
|     cur.execute(f''' |  | ||||||
|         UPDATE character_stats SET {stat_name} = ? WHERE character_id = ? |  | ||||||
|     ''', (value, character_id)) |  | ||||||
|     conn.commit() |  | ||||||
|     conn.close() |  | ||||||
| 
 |  | ||||||
| def get_character_stats(character_id): |  | ||||||
|     '''Retrieves all stats for a single character dynamically''' |  | ||||||
|     conn = get_db_connection() |  | ||||||
|     conn.row_factory = sqlite3.Row  # Enables dict-style access to rows |  | ||||||
|     cur = conn.cursor() |  | ||||||
|     cur.execute('SELECT * FROM character_stats WHERE character_id = ?', (character_id,)) |  | ||||||
|     row = cur.fetchone() |  | ||||||
|     conn.close() |  | ||||||
| 
 |  | ||||||
|     if row: |  | ||||||
|         return {key: row[key] for key in row.keys() if key != 'character_id'} |  | ||||||
|     else: |  | ||||||
|         return {} |  | ||||||
| 
 |  | ||||||
| def get_character_stat(character_id, stat_name): |  | ||||||
|     '''Retrieves a single stat value for a character''' |  | ||||||
|     if stat_name not in ('power', 'charm'): |  | ||||||
|         raise ValueError("Invalid stat name") |  | ||||||
|     conn = get_db_connection() |  | ||||||
|     cur = conn.cursor() |  | ||||||
|     cur.execute(f'SELECT {stat_name} FROM character_stats WHERE character_id = ?', (character_id,)) |  | ||||||
|     row = cur.fetchone() |  | ||||||
|     conn.close() |  | ||||||
|     return row[0] if row else 0 |  | ||||||
| 
 |  | ||||||
| def get_stats_for_multiple_characters(character_ids): |  | ||||||
|     ''' |     ''' | ||||||
|     Retrieves stats for a list of character IDs. |     Retrieves stats for a list of character IDs. | ||||||
|     Returns a dictionary of character_id -> {stat_name: value, ...} |     Returns a dictionary of character_id -> {stat_name: value, ...} | ||||||
|  | @ -162,12 +114,10 @@ def get_stats_for_multiple_characters(character_ids): | ||||||
|         WHERE character_id IN ({placeholders}) |         WHERE character_id IN ({placeholders}) | ||||||
|     ''' |     ''' | ||||||
| 
 | 
 | ||||||
|     conn = get_db_connection() | 
 | ||||||
|     cur = conn.cursor() |     CURSOR.execute(query, character_ids) | ||||||
|     cur.execute(query, character_ids) |  | ||||||
|     rows = cur.fetchall() |     rows = cur.fetchall() | ||||||
|     col_names = [desc[0] for desc in cur.description] |     col_names = [desc[0] for desc in cur.description] | ||||||
|     conn.close() |  | ||||||
| 
 | 
 | ||||||
|     result = {} |     result = {} | ||||||
|     for row in rows: |     for row in rows: | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								db.py
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								db.py
									
										
									
									
									
								
							|  | @ -44,8 +44,8 @@ cursor.execute(""" | ||||||
| cursor.execute(''' | cursor.execute(''' | ||||||
| CREATE TABLE IF NOT EXISTS character_stats ( | CREATE TABLE IF NOT EXISTS character_stats ( | ||||||
|     character_id INTEGER PRIMARY KEY, |     character_id INTEGER PRIMARY KEY, | ||||||
|     power INTEGER NOT NULL, |     power INTEGER NOT NULL DEFAULT abs(random() % 9999), | ||||||
|     charm INTEGER NOT NULL, |     charm INTEGER NOT NULL DEFAULT abs(random() % 9999),, | ||||||
|     FOREIGN KEY(character_id) REFERENCES characters(id) |     FOREIGN KEY(character_id) REFERENCES characters(id) | ||||||
| ) | ) | ||||||
| ''') | ''') | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue