forked from BasedHardware/omi
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfacts.py
79 lines (60 loc) · 2.52 KB
/
facts.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
from typing import List
from google.cloud import firestore
from google.cloud.firestore_v1 import FieldFilter
from ._client import db
def get_facts(uid: str, limit: int = 100, offset: int = 0):
# TODO: cache this
facts_ref = db.collection('users').document(uid).collection('facts')
facts_ref = facts_ref.order_by('created_at', direction=firestore.Query.DESCENDING).where(
filter=FieldFilter('deleted', '==', False))
facts_ref = facts_ref.limit(limit).offset(offset)
return [doc.to_dict() for doc in facts_ref.stream()]
def save_facts(uid: str, data: List[dict]):
batch = db.batch()
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
for fact in data:
fact_ref = facts_ref.document(fact['id'])
batch.set(fact_ref, fact)
batch.commit()
def delete_facts(uid: str):
batch = db.batch()
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
for doc in facts_ref.stream():
batch.delete(doc.reference)
batch.commit()
def get_fact(uid: str, fact_id: str):
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
fact_ref = facts_ref.document(fact_id)
return fact_ref.get().to_dict()
def review_fact(uid: str, fact_id: str, value: bool):
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
fact_ref = facts_ref.document(fact_id)
fact_ref.update({'reviewed': True, 'user_review': value})
def edit_fact(uid: str, fact_id: str, value: str):
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
fact_ref = facts_ref.document(fact_id)
fact_ref.update({'content': value, 'edited': True})
def delete_fact(uid: str, fact_id: str):
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
fact_ref = facts_ref.document(fact_id)
fact_ref.update({'deleted': True})
def delete_facts_for_memory(uid: str, memory_id: str):
batch = db.batch()
user_ref = db.collection('users').document(uid)
facts_ref = user_ref.collection('facts')
query = (
facts_ref.where(filter=FieldFilter('memory_id', '==', memory_id))
.where(filter=FieldFilter('deleted', '==', False))
)
removed_ids = []
for doc in query.stream():
batch.update(doc.reference, {'deleted': True})
removed_ids.append(doc.id)
batch.commit()
print('delete_facts_for_memory', memory_id, len(removed_ids))