-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdatabase.py
40 lines (31 loc) · 850 Bytes
/
database.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
from replit import db
def getDB(q=None):
if (db and q):
filtered_db_copy = {}
for k,info in db.items():
# every metadata in a book info
for md in info.values():
q = q.lower()
md = md.lower()
# mentioned at least once in any field
if (q in md) or (md in q):
filtered_db_copy[k] = info
# skip the rest of md, move to next book
break
return filtered_db_copy
else:
return db
def delete(item:'str'):
bid_deleted = db.pop(str(item))
return bid_deleted
def insert(isbn, metadata) -> 'bool':
# separate isbn and metadata
try:
# TODO separate UPDATE and INSERT logic
# if (db[isbn]):
# raise Exception("Book ISBN already exists in DB")
db[isbn] = metadata
except Exception as e:
return False
else:
return True