2024-12-26 22:54:55 +08:00
|
|
|
import json
|
2024-12-30 16:35:57 +08:00
|
|
|
|
2024-12-26 22:54:55 +08:00
|
|
|
from .databaseController import DatabaseController
|
|
|
|
from .endpoints.query import Archive_Query
|
2025-01-02 19:05:25 +08:00
|
|
|
from .endpoints.get_post import Archive_GetPost
|
2024-12-30 16:35:57 +08:00
|
|
|
from .endpoints.get_posts import Archive_GetPosts
|
2025-01-02 19:05:25 +08:00
|
|
|
from .endpoints.set_action import Archive_SetAction
|
2024-12-26 22:54:55 +08:00
|
|
|
|
|
|
|
class Database:
|
|
|
|
db : DatabaseController = None
|
|
|
|
|
|
|
|
def __init__(self, api) -> None:
|
|
|
|
app = api.app
|
|
|
|
if "Archive" in app.databases:
|
|
|
|
del app.databases["Archive"]
|
|
|
|
|
|
|
|
self.reload_data()
|
|
|
|
|
|
|
|
app.databases["Archive"] = self
|
|
|
|
|
|
|
|
api.add_resource(Archive_Query, "/Archive/Query")
|
2025-01-02 19:05:25 +08:00
|
|
|
api.add_resource(Archive_GetPost, "/Archive/GetPost/<id>")
|
2024-12-30 16:35:57 +08:00
|
|
|
api.add_resource(Archive_GetPosts, "/Archive/GetPosts")
|
2025-01-02 19:05:25 +08:00
|
|
|
api.add_resource(Archive_SetAction, "/Archive/SetAction")
|
2024-12-26 22:54:55 +08:00
|
|
|
|
2025-01-02 19:05:25 +08:00
|
|
|
def get_post(self, id):
|
|
|
|
query = f'''SELECT x_posts.id, x_posts.error_id, x_posts.action_taken, x_post_details.text, x_post_details.files, x_post_details.date, accounts.x_handle, accounts.rating from x_posts
|
|
|
|
LEFT JOIN x_post_details
|
|
|
|
ON x_posts.id = x_post_details.id
|
|
|
|
LEFT JOIN accounts
|
|
|
|
ON x_posts.account_id = accounts.id WHERE x_posts.id = {id}'''
|
|
|
|
result = self.db.run_query(query)
|
|
|
|
if len(result) == 0:
|
|
|
|
return None
|
|
|
|
else:
|
|
|
|
#return most recent post
|
|
|
|
return result[-1]
|
|
|
|
|
2024-12-31 22:53:25 +08:00
|
|
|
def get_posts(self, num_posts, actions_taken = [0, 1, 2, 3], last_id = -1, offset = 0):
|
2024-12-30 16:35:57 +08:00
|
|
|
num_posts = max(1, min(num_posts, 30))
|
|
|
|
|
|
|
|
where_query = "WHERE x_post_details.id NOT NULL AND x_posts.error_id = 0"
|
|
|
|
if last_id != -1:
|
|
|
|
where_query += f" AND x_posts.id < {last_id}"
|
2024-12-31 22:53:25 +08:00
|
|
|
if actions_taken != [0, 1, 2, 3]:
|
2024-12-30 16:35:57 +08:00
|
|
|
where_query += " AND (" + " OR ".join([f"x_posts.action_taken = {action}" for action in actions_taken]) + ")"
|
|
|
|
|
|
|
|
query = f'''
|
2025-01-02 19:05:25 +08:00
|
|
|
SELECT x_posts.id, x_post_details.text, x_post_details.files, x_post_details.date, accounts.x_handle, accounts.rating FROM x_posts
|
2024-12-30 16:35:57 +08:00
|
|
|
LEFT JOIN x_post_details
|
|
|
|
ON x_posts.id = x_post_details.id
|
|
|
|
LEFT JOIN accounts
|
|
|
|
ON x_posts.account_id = accounts.id
|
|
|
|
{where_query}
|
|
|
|
ORDER BY x_posts.id DESC
|
|
|
|
LIMIT {num_posts} OFFSET {offset}'''
|
|
|
|
|
|
|
|
result = self.db.run_query(query)
|
|
|
|
posts = []
|
|
|
|
if result is not None:
|
|
|
|
for result in self.db.run_query(query):
|
2024-12-31 22:53:25 +08:00
|
|
|
posts.append({"id": result[0], "id_str": str(result[0]), "text": result[1], "files": result[2].split(','), "handle": result[3], "date": result[4]})
|
2024-12-30 16:35:57 +08:00
|
|
|
return posts
|
|
|
|
|
2024-12-26 22:54:55 +08:00
|
|
|
def reload_data(self):
|
|
|
|
self.db = DatabaseController("/home/pi/python/Katbots/JapariArchive/database.db")
|