MsRewards/modules/db.py

68 lines
2.6 KiB
Python
Raw Normal View History

2023-08-22 11:21:42 +02:00
import sqlite3
2022-09-30 14:45:53 +02:00
2023-08-22 11:21:42 +02:00
#Create a new row, for the account [compte] whith [points] points
2022-09-30 14:45:53 +02:00
def add_row(compte, points, mycursor, mydb):
2023-08-22 11:21:42 +02:00
sql = "INSERT INTO daily (compte, points, date) VALUES (?, ?, date())"
2022-09-30 14:45:53 +02:00
val = (compte, points)
mycursor.execute(sql, val)
mydb.commit()
2022-09-30 15:17:29 +02:00
#printf(mycursor.rowcount, "record created.")
2022-09-30 14:45:53 +02:00
2023-08-22 11:21:42 +02:00
#update the ammount of points for the account [compte]
2022-09-30 14:45:53 +02:00
def update_row(compte, points, mycursor, mydb):
2023-08-22 11:21:42 +02:00
sql = f"UPDATE daily SET points = {points} WHERE compte = '{compte}' AND date = date() ;"
2022-09-30 14:45:53 +02:00
mycursor.execute(sql)
mydb.commit()
2022-09-30 15:17:29 +02:00
#printf(mycursor.rowcount, "record(s) updated")
2022-09-30 14:45:53 +02:00
2023-08-22 11:21:42 +02:00
# update the value of last_pts for the table comptes
2022-09-30 14:45:53 +02:00
def update_last(compte, points, mycursor, mydb):
sql1 = f"UPDATE comptes SET last_pts = {points} WHERE compte = '{compte}';"
2023-08-25 20:43:37 +02:00
sql2 = f"select * from comptes where compte = '{compte}'"
2023-08-26 09:11:26 +02:00
sql3 = f"INSERT INTO comptes (compte, last_pts,banned) VALUES ('{compte}', {points}, 0)"
cmd = mycursor.execute(sql2)
if len(list(cmd)) == 0:
mycursor.execute(sql3)
else :
mycursor.execute(sql1)
2022-09-30 14:45:53 +02:00
mydb.commit()
2022-09-30 15:17:29 +02:00
#printf(mycursor.rowcount, "record(s) updated")
2022-09-30 14:45:53 +02:00
2023-08-22 11:21:42 +02:00
# if return if there already is a line in the database for the account [compte]. if same_point is enabled, the line must also have the same number of points
# SQLITE
def get_row(compte, points, mycursor, same_points = True):
2022-09-30 14:45:53 +02:00
if same_points :
2023-08-22 11:21:42 +02:00
mycursor.execute(f"SELECT * FROM daily WHERE points = {points} AND compte = '{compte}' AND date = date() ;")
2022-09-30 14:45:53 +02:00
else :
2023-08-22 11:21:42 +02:00
mycursor.execute(f"SELECT * FROM daily WHERE compte = '{compte}' AND date = date() ;")
2022-09-30 14:45:53 +02:00
myresult = mycursor.fetchall()
return(len(myresult) == 1)
2023-08-22 11:21:42 +02:00
def add_to_database(compte, points, save_if_fail=True):
if points is None:
pass
else:
mydb = sqlite3.connect("/app/MsRewards-Reborn/MsRewards.db")
2023-08-22 11:21:42 +02:00
mycursor = mydb.cursor()
if get_row(compte, points,mycursor, True): #check if the row exist with the same ammount of points and do nothind if it does
#printf("les points sont deja bon")
#return(0)
pass
elif get_row(compte, points,mycursor, False) : #check if the row exist, but without the same ammount of points and update the point account then
update_row(compte, points,mycursor,mydb)
#printf("row updated")
#return(1)
else : # if the row don't exist, create it with the good ammount of points
add_row(compte, points,mycursor,mydb)
#return(2) #printf("row added")
if int(points) > 10 :
update_last(compte, points, mycursor, mydb)
mycursor.close()
mydb.close()
2022-09-30 14:45:53 +02:00
2022-11-16 18:13:36 +01:00
2022-09-30 14:45:53 +02:00