forked from FrederikBaerentsen/BrickTracker
Added database scripts and updated rebrickable downloader. Fixed #1
This commit is contained in:
parent
c25dab304c
commit
2c0e3f49d0
46
app.py
46
app.py
@ -12,7 +12,8 @@ import rebrick #rebrickable api
|
|||||||
import requests # request img from web
|
import requests # request img from web
|
||||||
import shutil # save img locally
|
import shutil # save img locally
|
||||||
import eventlet
|
import eventlet
|
||||||
from downloadRB import download_and_unzip
|
from downloadRB import download_and_unzip,get_nil_images
|
||||||
|
from db import initialize_database,get_rows,delete_tables
|
||||||
|
|
||||||
app = Flask(__name__)
|
app = Flask(__name__)
|
||||||
socketio = SocketIO(app)
|
socketio = SocketIO(app)
|
||||||
@ -368,20 +369,47 @@ def new_set(set_num):
|
|||||||
count = 0
|
count = 0
|
||||||
socketio.emit('task_completed', namespace='/progress')
|
socketio.emit('task_completed', namespace='/progress')
|
||||||
|
|
||||||
|
def get_file_creation_dates(file_list):
|
||||||
|
creation_dates = {}
|
||||||
|
for file_name in file_list:
|
||||||
|
file_path = f"{file_name}"
|
||||||
|
if os.path.exists(file_path):
|
||||||
|
creation_time = os.path.getctime(file_path)
|
||||||
|
creation_dates[file_name] = time.ctime(creation_time)
|
||||||
|
else:
|
||||||
|
creation_dates[file_name] = "File not found"
|
||||||
|
return creation_dates
|
||||||
|
|
||||||
@app.route('/config',methods=['POST','GET'])
|
@app.route('/config',methods=['POST','GET'])
|
||||||
def config():
|
def config():
|
||||||
print(request.method)
|
|
||||||
|
file_list = ['themes.csv', 'colors.csv', 'sets.csv','static/nil.png','static/nil_mf.jpg']
|
||||||
|
creation_dates = get_file_creation_dates(file_list)
|
||||||
|
|
||||||
|
row_counts = [0]
|
||||||
|
db_exists = Path("app.db")
|
||||||
|
if db_exists.is_file():
|
||||||
|
db_is_there = True
|
||||||
|
row_counts = get_rows()
|
||||||
|
else:
|
||||||
|
db_is_there = False
|
||||||
|
|
||||||
if request.method == 'POST':
|
if request.method == 'POST':
|
||||||
|
|
||||||
if request.form.get('CreateDB') == 'createDB':
|
if request.form.get('CreateDB') == 'Create Database':
|
||||||
# pass
|
initialize_database()
|
||||||
print("Encrypted")
|
row_counts = get_rows()
|
||||||
elif request.form.get('Get Rebrickable data') == 'rebrickUpdate':
|
return redirect(url_for('config'))
|
||||||
# pass # do something else
|
elif request.form.get('Update local data') == 'Update local data':
|
||||||
urls = ["themes","sets","colors"]
|
urls = ["themes","sets","colors"]
|
||||||
|
|
||||||
for i in urls:
|
for i in urls:
|
||||||
download_and_unzip("https://cdn.rebrickable.com/media/downloads/"+i+".csv.gz")
|
download_and_unzip("https://cdn.rebrickable.com/media/downloads/"+i+".csv.gz")
|
||||||
|
get_nil_images()
|
||||||
|
return redirect(url_for('config'))
|
||||||
|
|
||||||
|
elif request.form.get('deletedb') == 'Delete Database':
|
||||||
|
delete_tables()
|
||||||
|
initialize_database()
|
||||||
|
|
||||||
else:
|
else:
|
||||||
# pass # unknown
|
# pass # unknown
|
||||||
@ -389,7 +417,7 @@ def config():
|
|||||||
elif request.method == 'GET':
|
elif request.method == 'GET':
|
||||||
# return render_template("index.html")
|
# return render_template("index.html")
|
||||||
print("No Post Back Call")
|
print("No Post Back Call")
|
||||||
return render_template("config.html")
|
return render_template("config.html",db_is_there=db_is_there,creation_dates = creation_dates,row_counts=row_counts)
|
||||||
|
|
||||||
@app.route('/missing',methods=['POST','GET'])
|
@app.route('/missing',methods=['POST','GET'])
|
||||||
def missing():
|
def missing():
|
||||||
|
105
db.py
Normal file
105
db.py
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
import os
|
||||||
|
import sqlite3
|
||||||
|
|
||||||
|
def initialize_database():
|
||||||
|
db_path = 'app.db'
|
||||||
|
tables = ['sets', 'inventory', 'minifigures', 'missing']
|
||||||
|
row_counts = {}
|
||||||
|
|
||||||
|
# Connect to the database (this will create the file if it doesn't exist)
|
||||||
|
conn = sqlite3.connect(db_path)
|
||||||
|
cursor = conn.cursor()
|
||||||
|
|
||||||
|
# Create the required tables if they do not exist
|
||||||
|
cursor.execute('''CREATE TABLE IF NOT EXISTS sets (
|
||||||
|
set_num TEXT,
|
||||||
|
name TEXT,
|
||||||
|
year INTEGER,
|
||||||
|
theme_id INTEGER,
|
||||||
|
num_parts INTEGER,
|
||||||
|
set_img_url TEXT,
|
||||||
|
set_url TEXT,
|
||||||
|
last_modified_dt TEXT,
|
||||||
|
mini_col BOOLEAN,
|
||||||
|
set_check BOOLEAN,
|
||||||
|
set_col BOOLEAN,
|
||||||
|
u_id TEXT
|
||||||
|
)''')
|
||||||
|
|
||||||
|
cursor.execute('''CREATE TABLE IF NOT EXISTS inventory (
|
||||||
|
set_num TEXT,
|
||||||
|
id INTEGER,
|
||||||
|
part_num INTEGER,
|
||||||
|
name TEXT,
|
||||||
|
part_img_url TEXT,
|
||||||
|
part_img_url_id TEXT,
|
||||||
|
color_id INTEGER,
|
||||||
|
color_name TEXT,
|
||||||
|
quantity INTEGER,
|
||||||
|
is_spare BOOLEAN,
|
||||||
|
element_id INTEGER,
|
||||||
|
u_id TEXT
|
||||||
|
)''')
|
||||||
|
|
||||||
|
cursor.execute('''CREATE TABLE IF NOT EXISTS minifigures (
|
||||||
|
fig_num TEXT,
|
||||||
|
set_num TEXT,
|
||||||
|
name TEXT,
|
||||||
|
quantity INTEGER,
|
||||||
|
set_img_url TEXT,
|
||||||
|
u_id TEXT
|
||||||
|
)''')
|
||||||
|
|
||||||
|
cursor.execute('''CREATE TABLE IF NOT EXISTS missing (
|
||||||
|
set_num TEXT,
|
||||||
|
id INTEGER,
|
||||||
|
part_num TEXT,
|
||||||
|
part_img_url_id TEXT,
|
||||||
|
color_id INTEGER,
|
||||||
|
quantity INTEGER,
|
||||||
|
element_id INTEGER,
|
||||||
|
u_id TEXT
|
||||||
|
)''')
|
||||||
|
|
||||||
|
# Commit the changes
|
||||||
|
conn.commit()
|
||||||
|
conn.close()
|
||||||
|
|
||||||
|
def get_rows():
|
||||||
|
db_path = 'app.db'
|
||||||
|
tables = ['sets', 'inventory', 'minifigures', 'missing']
|
||||||
|
row_counts = {}
|
||||||
|
|
||||||
|
# Connect to the database (this will create the file if it doesn't exist)
|
||||||
|
conn = sqlite3.connect(db_path)
|
||||||
|
cursor = conn.cursor()
|
||||||
|
|
||||||
|
# Get the row count for each table
|
||||||
|
for table in tables:
|
||||||
|
cursor.execute(f"SELECT COUNT(*) FROM {table}")
|
||||||
|
row_count = cursor.fetchone()[0]
|
||||||
|
row_counts[table] = row_count
|
||||||
|
|
||||||
|
# Close the connection
|
||||||
|
conn.close()
|
||||||
|
|
||||||
|
return row_counts
|
||||||
|
|
||||||
|
|
||||||
|
def delete_tables():
|
||||||
|
db_path = 'app.db'
|
||||||
|
tables = ['sets', 'inventory', 'minifigures', 'missing']
|
||||||
|
row_counts = {}
|
||||||
|
|
||||||
|
# Connect to the database (this will create the file if it doesn't exist)
|
||||||
|
conn = sqlite3.connect(db_path)
|
||||||
|
cursor = conn.cursor()
|
||||||
|
|
||||||
|
cursor.execute('''DROP TABLE sets''')
|
||||||
|
cursor.execute('''DROP TABLE inventory''')
|
||||||
|
cursor.execute('''DROP TABLE minifigures''')
|
||||||
|
cursor.execute('''DROP TABLE missing''')
|
||||||
|
|
||||||
|
# Close the connection
|
||||||
|
conn.close()
|
||||||
|
|
@ -5,6 +5,33 @@ import os
|
|||||||
import sys
|
import sys
|
||||||
from urllib.parse import urlparse
|
from urllib.parse import urlparse
|
||||||
|
|
||||||
|
def get_nil_images():
|
||||||
|
image_urls = [
|
||||||
|
"https://rebrickable.com/static/img/nil_mf.jpg",
|
||||||
|
"https://rebrickable.com/static/img/nil.png"
|
||||||
|
]
|
||||||
|
static_folder = "static"
|
||||||
|
|
||||||
|
# Create the static folder if it does not exist
|
||||||
|
if not os.path.exists(static_folder):
|
||||||
|
os.makedirs(static_folder)
|
||||||
|
|
||||||
|
for url in image_urls:
|
||||||
|
# Extract the output filename from the URL
|
||||||
|
parsed_url = urlparse(url)
|
||||||
|
output_file = os.path.join(static_folder, os.path.basename(parsed_url.path))
|
||||||
|
|
||||||
|
# Download the image
|
||||||
|
response = requests.get(url, stream=True)
|
||||||
|
response.raise_for_status() # Check for any request errors
|
||||||
|
|
||||||
|
# Save the image to the static folder
|
||||||
|
with open(output_file, 'wb') as f:
|
||||||
|
f.write(response.content)
|
||||||
|
|
||||||
|
print(f"Downloaded {output_file}")
|
||||||
|
|
||||||
|
|
||||||
def download_and_unzip(url: str):
|
def download_and_unzip(url: str):
|
||||||
# Extract the output filename from the URL
|
# Extract the output filename from the URL
|
||||||
parsed_url = urlparse(url)
|
parsed_url = urlparse(url)
|
||||||
|
Loading…
Reference in New Issue
Block a user