tidying db functions

This commit is contained in:
Sam Hadow 2024-01-31 12:01:20 +01:00
parent 7b1bef3695
commit f2dd0e51e2
5 changed files with 62 additions and 47 deletions

View File

@ -78,10 +78,16 @@ def get_attributes(attributes_raw):
return attributes return attributes
def fill_db(db_settings, items_dict): def fill_db(items_dict):
'''add new history entries in database with data extracted in item_dict''' '''add new history entries in database with data extracted in item_dict'''
for key,value in items_dict.items(): for key,value in items_dict.items():
add_history_entry(db_settings, key[0], value["skuid"], value["choice_delivery"], list(key[1]), value["image"], value["price"], value["currency"], value["quantity"], value["discount_percentage"]) add_history_entry(key[0], value["skuid"], value["choice_delivery"], list(key[1]), value["image"], value["price"], value["currency"], value["quantity"], value["discount_percentage"])
def update_items():
'''add new history entries for items in database'''
in_db = get_item_keys()
new_entries = check_items(in_db)
fill_db(new_entries)

View File

@ -7,33 +7,16 @@ from aliexpress import *
app = Flask(__name__) app = Flask(__name__)
CORS(app) CORS(app)
def get_conf():
'''return settings in settings.yaml file'''
settings = dict()
with open(os.path.dirname(os.path.realpath(__file__))+"/settings.yaml", 'r') as conf_file:
settings = yaml.safe_load(conf_file)
settings["db"] = {
"host": os.environ.get('POSTGRES_HOST'),
"port": os.environ.get('POSTGRES_PORT'),
"database": os.environ.get('POSTGRES_DB'),
"user": os.environ.get('POSTGRES_USER'),
"password": os.environ.get('POSTGRES_PASSWORD')
}
return settings
@app.route('/init') @app.route('/init')
def init_db(): def init_db():
print("init") print("init")
settings = get_conf() initialize()
initialize(settings["db"])
return 'Hello, World!' return 'Hello, World!'
@app.route('/update') @app.route('/update')
def update_hist(): def update_hist():
print("update") print("update")
settings = get_conf() fill_db(check_items())
fill_db(settings["db"], check_items(settings["item"]))
return 'Hello, World!' return 'Hello, World!'
@app.route('/add', methods=['POST']) @app.route('/add', methods=['POST'])
@ -49,14 +32,13 @@ def add_item():
extr = check_items(new_item) extr = check_items(new_item)
if len(extr) > 0: if len(extr) > 0:
settings = get_conf()
skuid = list(extr.values())[0]["skuid"] skuid = list(extr.values())[0]["skuid"]
if check_exist(settings["db"], itemid, skuid): if check_exist(itemid, skuid):
# item already exists # item already exists
return jsonify({'status': 3}), 400 return jsonify({'status': 3}), 400
else: else:
# item is valid # item is valid
fill_db(settings["db"], extr) fill_db(extr)
return jsonify({'status': 0}), 200 return jsonify({'status': 0}), 200
else: else:
# item not valid or can't be parsed # item not valid or can't be parsed
@ -66,15 +48,13 @@ def add_item():
def data_history_request(): def data_history_request():
if request.method == 'GET': if request.method == 'GET':
print("fetching data history") print("fetching data history")
settings = get_conf() return jsonify(get_history())
return jsonify(get_history(settings["db"]))
@app.route('/dataitem',methods = ['POST', 'GET']) @app.route('/dataitem',methods = ['POST', 'GET'])
def data_item_request(): def data_item_request():
if request.method == 'GET': if request.method == 'GET':
print("fetching data item") print("fetching data item")
settings = get_conf() return jsonify(get_item())
return jsonify(get_item(settings["db"]))
if __name__ == '__main__': if __name__ == '__main__':
app.run(debug = True) app.run(debug = True)

5
src/background.py Normal file
View File

@ -0,0 +1,5 @@
#!/usr/bin/python
from aliexpress import *
if __name__ == '__main__':
print("ok")

View File

@ -3,9 +3,21 @@ import psycopg2
import csv import csv
import os import os
def connect_db(db_settings): def get_conf():
'''return db connection settings'''
settings = {
"host": os.environ.get('POSTGRES_HOST'),
"port": os.environ.get('POSTGRES_PORT'),
"database": os.environ.get('POSTGRES_DB'),
"user": os.environ.get('POSTGRES_USER'),
"password": os.environ.get('POSTGRES_PASSWORD')
}
return settings
def connect_db():
'''open and return a connection to the database''' '''open and return a connection to the database'''
conn = None conn = None
db_settings = get_conf()
print("Connecting to the PostgreSQL database...") print("Connecting to the PostgreSQL database...")
try: try:
conn = psycopg2.connect(**db_settings) conn = psycopg2.connect(**db_settings)
@ -14,9 +26,9 @@ def connect_db(db_settings):
print(error) print(error)
return conn return conn
def add_item(db_settings, itemid, skuid, choice, attributes, image): def add_item(itemid, skuid, choice, attributes, image):
'''insert a new item in the database''' '''insert a new item in the database'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
cursor.execute(""" cursor.execute("""
@ -26,13 +38,13 @@ def add_item(db_settings, itemid, skuid, choice, attributes, image):
connection.commit() connection.commit()
connection.close() connection.close()
def add_history_entry(db_settings, itemid, skuid, choice, attributes, image, price, currency, quantity, discount_percentage): def add_history_entry(itemid, skuid, choice, attributes, image, price, currency, quantity, discount_percentage):
'''Add a new history entry for an item in the database. If item isn't in database yet, add it.''' '''Add a new history entry for an item in the database. If item isn't in database yet, add it.'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
if not check_exist(db_settings, itemid, skuid): if not check_exist(itemid, skuid):
add_item(db_settings, itemid, skuid, choice, attributes, image) add_item(itemid, skuid, choice, attributes, image)
cursor.execute(""" cursor.execute("""
SELECT uuid SELECT uuid
FROM item FROM item
@ -49,9 +61,9 @@ def add_history_entry(db_settings, itemid, skuid, choice, attributes, image, pri
connection.commit() connection.commit()
connection.close() connection.close()
def get_history(db_settings): def get_history():
'''return history data from database''' '''return history data from database'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
cursor.execute(""" cursor.execute("""
SELECT uuid, quantity, discount_percentage, price, currency, h_timestamp SELECT uuid, quantity, discount_percentage, price, currency, h_timestamp
@ -62,9 +74,9 @@ def get_history(db_settings):
connection.close() connection.close()
return results return results
def get_item(db_settings): def get_item():
'''return items data from database''' '''return items data from database'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
cursor.execute(""" cursor.execute("""
SELECT uuid, itemid, skuid, choice, attributes, image SELECT uuid, itemid, skuid, choice, attributes, image
@ -75,9 +87,22 @@ def get_item(db_settings):
connection.close() connection.close()
return results return results
def check_exist(db_settings, itemid, skuid): def get_item_keys():
'''return items id and attributes from database'''
connection = connect_db()
cursor = connection.cursor()
cursor.execute("""
SELECT itemid, attributes
FROM item
""")
results = cursor.fetchall()
cursor.close()
connection.close()
return results
def check_exist(itemid, skuid):
'''check if an item is already in the database''' '''check if an item is already in the database'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
cursor.execute(""" cursor.execute("""
@ -96,9 +121,10 @@ def check_exist(db_settings, itemid, skuid):
else: else:
return True return True
def export_csv(db_settings):
def export_csv():
'''join item and history data from database and export it in ./output.csv''' '''join item and history data from database and export it in ./output.csv'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
cursor.execute(""" cursor.execute("""
@ -118,9 +144,9 @@ def export_csv(db_settings):
connection.close() connection.close()
def initialize(db_settings): def initialize():
'''Create tables and sequence in database. Drop them first if they already exist.''' '''Create tables and sequence in database. Drop them first if they already exist.'''
connection = connect_db(db_settings) connection = connect_db()
cursor = connection.cursor() cursor = connection.cursor()
cursor.execute(""" cursor.execute("""

View File

@ -24,7 +24,6 @@ async function fetch_history() {
const response = await fetch(`${currentUrl}app/datahistory`); const response = await fetch(`${currentUrl}app/datahistory`);
const rawData = await response.json(); const rawData = await response.json();
var dateFormat = d3.timeParse("%a, %d %b %Y %H:%M:%S GMT"); var dateFormat = d3.timeParse("%a, %d %b %Y %H:%M:%S GMT");
console.log(rawData)
// SELECT uuid, quantity, discount_percentage, price, currency, h_timestamp // SELECT uuid, quantity, discount_percentage, price, currency, h_timestamp
let historyData = rawData.map(d => ({ let historyData = rawData.map(d => ({
uuid: d[0], uuid: d[0],
@ -32,7 +31,6 @@ async function fetch_history() {
currency: d[4], currency: d[4],
date: dateFormat(d[5]), date: dateFormat(d[5]),
})); }));
console.log(historyData)
return historyData; return historyData;
} catch (error) { } catch (error) {
console.error('Error fetching data history: ', error); console.error('Error fetching data history: ', error);