unifying character and stats insertion, generalize get_character
This commit is contained in:
		
							parent
							
								
									471f399176
								
							
						
					
					
						commit
						3b7f2006ef
					
				
					 1 changed files with 18 additions and 68 deletions
				
			
		|  | @ -47,13 +47,27 @@ def get_or_create_user(username): | |||
|     user_id = CURSOR.lastrowid | ||||
|     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''' | ||||
|     CURSOR.execute( | ||||
|         'INSERT INTO characters (name, rarity, weight, file_id) VALUES (?, ?, ?, ?)', | ||||
|         (name, rarity, weight, file_id) | ||||
|     ) | ||||
|     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 | ||||
| 
 | ||||
| def insert_pull(user_id, character_id): | ||||
|  | @ -85,69 +99,7 @@ def set_config(key, value): | |||
| 
 | ||||
| # Character stat functions | ||||
| 
 | ||||
| def add_character_stats(character_id, stats): | ||||
|     ''' | ||||
|     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): | ||||
| def get_characters(character_ids): | ||||
|     ''' | ||||
|     Retrieves stats for a list of character IDs. | ||||
|     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}) | ||||
|     ''' | ||||
| 
 | ||||
|     conn = get_db_connection() | ||||
|     cur = conn.cursor() | ||||
|     cur.execute(query, character_ids) | ||||
| 
 | ||||
|     CURSOR.execute(query, character_ids) | ||||
|     rows = cur.fetchall() | ||||
|     col_names = [desc[0] for desc in cur.description] | ||||
|     conn.close() | ||||
| 
 | ||||
|     result = {} | ||||
|     for row in rows: | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue