aboutsummaryrefslogtreecommitdiff
path: root/app/func/link/records.py
diff options
context:
space:
mode:
Diffstat (limited to 'app/func/link/records.py')
-rw-r--r--app/func/link/records.py23
1 files changed, 23 insertions, 0 deletions
diff --git a/app/func/link/records.py b/app/func/link/records.py
new file mode 100644
index 0000000..56bb6d2
--- /dev/null
+++ b/app/func/link/records.py
@@ -0,0 +1,23 @@
+import sqlalchemy
+
+from db import engine
+
+"""
+Retrieve all records associated with a specific link
+"""
+def get_link_records(link, owner):
+ with engine.begin() as conn:
+ try:
+ link_owner = conn.execute(sqlalchemy.text('SELECT owner FROM links WHERE link = :link'), [{'link': link}]).fetchone()[0]
+ except TypeError:
+ return 404
+
+ if owner == link_owner:
+ with engine.begin() as conn:
+ records = conn.execute(sqlalchemy.text('SELECT timestamp, ip, location, browser, os, user_agent, isp FROM records WHERE owner = :owner and link = :link'), [{'owner': owner, 'link': link}]).fetchall()
+ if not records:
+ return 204
+ else:
+ return 401
+
+ return records \ No newline at end of file