| 
									
										
										
										
											2021-11-30 14:13:57 +02:00
										 |  |  | import sqlite3 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from flask import current_app, g | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 13:54:25 +02:00
										 |  |  | import os | 
					
						
							|  |  |  | DB_FILE = os.environ('DB_FILE', './data/db.sqlite') | 
					
						
							| 
									
										
										
										
											2021-11-30 14:13:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-06 01:34:00 +02:00
										 |  |  | get_return = sqlite3.Connection | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get() -> get_return: | 
					
						
							| 
									
										
										
										
											2021-11-30 14:13:57 +02:00
										 |  |  |     if 'db' not in g: | 
					
						
							|  |  |  |         g.db = sqlite3.connect( | 
					
						
							|  |  |  |             DB_FILE, | 
					
						
							|  |  |  |             detect_types=sqlite3.PARSE_DECLTYPES, | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         g.db.row_factory = sqlite3.Row | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return g.db | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def close(e=None): | 
					
						
							|  |  |  |     db = g.pop('db', None) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if db: | 
					
						
							|  |  |  |         db.close() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def init(): | 
					
						
							|  |  |  |     db = get() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     with current_app.open_resource('init.sql') as f: | 
					
						
							|  |  |  |         db.executescript(f.read().decode('utf8')) | 
					
						
							|  |  |  |         db.commit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def init_app(app): | 
					
						
							|  |  |  |     app.teardown_appcontext(close) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     import os.path | 
					
						
							|  |  |  |     if not os.path.exists(DB_FILE): | 
					
						
							|  |  |  |         with app.app_context(): | 
					
						
							|  |  |  |             init() |