-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcrud.py
205 lines (155 loc) · 5.65 KB
/
crud.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
import datetime
from sqlalchemy.orm import Session, joinedload
from model import Member
from model import Region, Scrap
from model import Room, MemberRoom, Chat
from model import Theme, RoomTheme
from model import Recommend
from model import Guide, GuideImage
import scheme
import bcrypt
def create_member(db: Session, member: scheme.MemberSignInfo):
hashed_password = bcrypt.hashpw(member.password.encode('utf-8'), bcrypt.gensalt())
db_member = Member(
email=member.email,
password=hashed_password.decode('utf-8')
)
db.add(db_member)
db.commit()
db.refresh(db_member)
return db_member
def find_member_by_email(db: Session, member: scheme.MemberSignInfo):
db_member = db.query(Member).filter(member.email == Member.email)
if db_member:
for m in db_member:
return m
def find_region_list(db: Session):
db_regions = db.query(Region).all()
return db_regions
def find_chats_by_room(db: Session, room_id: int):
chats = db.query(Chat).filter(Chat.room_id == room_id)
chat_list = []
for c in chats:
chat_list.append(c)
return chat_list
def create_chatroom(db: Session, req: scheme.ChatRoomInfo):
db_chatroom = Room(
gender=req.gender,
age=req.age,
begin_date=req.begin_date,
end_date=req.end_date,
region_id=req.region_id
)
db.add(db_chatroom)
db.commit()
db.refresh(db_chatroom)
return db_chatroom
def find_region(db: Session, id: int):
db_region = db.query(Region).get(id)
return db_region
def create_chat(db: Session, contents, isQuestion, room_id):
db_chat = Chat(
room_id=room_id,
isQuestion=isQuestion,
contents=str(contents),
createdAt=datetime.datetime.now()
)
db.add(db_chat)
db.commit()
db.refresh(db_chat)
return db_chat
def create_chat_question_answer(req: scheme.ChatReq, chat, db: Session):
db_question = Chat(
room_id=req.room_id,
isQuestion=True,
contents=req.prompt,
createdAt=datetime.datetime.now()
)
db_answer = Chat(
room_id=req.room_id,
isQuestion=False,
contents=chat,
createdAt=datetime.datetime.now()
)
db.add_all([db_question, db_answer])
db.commit()
db.refresh(db_question)
db.refresh(db_answer)
return db_question, db_answer
def create_chat_member(db: Session, room_id: int, member_id: int):
db_member_room = MemberRoom(
room_id=room_id,
member_id=member_id
)
db.add(db_member_room)
db.commit()
db.refresh(db_member_room)
return db_member_room
def find_member_by_pk(db: Session, id: int):
return db.query(Member).get(id)
def find_chatrooms_by_member(db: Session, id: int):
rooms = db.query(Room).options(joinedload(Room.region)) \
.join(MemberRoom.room).filter(MemberRoom.member_id == id).all()
room_list = []
for r in rooms:
t = find_chatroom_theme(db=db, room_id=r.room_id)
theme_list = []
for i in t:
theme_list.append(i.theme.keyword)
r.themes = theme_list
if isinstance(r.begin_date, datetime.date):
r.begin_date.strftime('%Y-%m-%d')
r.end_date.strftime('%Y-%m-%d')
room_list.append(r)
return room_list
def find_themes(db: Session, theme_list: list):
all_theme = db.query(Theme).all()
themes = []
for t in all_theme:
if t.theme_id in theme_list:
themes.append(t)
return themes
def create_chatroom_theme(db: Session, room_id: int, themes: int):
db_room_theme = []
for t in themes:
db_room_theme.append(RoomTheme(theme_id=t.theme_id, room_id=room_id))
db.add_all(db_room_theme)
db.commit()
for d in db_room_theme:
db.refresh(d)
return None
def find_chatroom_theme(db: Session, room_id: int):
return db.query(RoomTheme).options(joinedload(RoomTheme.room)).filter(RoomTheme.room_id == room_id)
def create_scrap(db: Session, member_id: int, region_id: int):
db_scrap = Scrap(member_id=member_id, region_id=region_id)
db.add(db_scrap)
db.commit()
db.refresh(db_scrap)
return db_scrap
def find_scrap_by_member_pk(db, member_id: int):
scrap = db.query(Scrap).options(joinedload(Scrap.region)).filter(Scrap.member_id == member_id).all()
return scrap
def create_recommend(db, member_id: int, region_id: int, tag):
db_recommend = Recommend(member_id=member_id, region_id=region_id, tag=tag)
print(db_recommend.region_id)
db.add(db_recommend)
db.commit()
db.refresh(db_recommend)
return db_recommend
def find_recommend_by_member_pk(db, member_id: int):
recommend = db.query(Recommend).options(joinedload(Recommend.region)).filter(Recommend.member_id == member_id).all()
return recommend
def find_guides(db: Session):
return db.query(Guide).options(joinedload(Guide.region)).all()
def find_guide(db: Session, guide_id: int):
return db.query(Guide).get(guide_id)
def find_guides_by_region(db: Session, region_id: int):
return db.query(Guide).options(joinedload(Guide.region)).filter(Guide.region_id == region_id).all()
def find_guides_info(db: Session, guide_id: int):
return db.query(GuideImage).options(joinedload(GuideImage.guide)).filter(GuideImage.guide_id == guide_id).all()
def find_recommend_by_pk(db: Session, recommend_id: int):
return db.query(Recommend).options(joinedload(Recommend.region)).get(recommend_id)
def find_scrap_by_member_and_region(db, member_id: int, region_id: int):
scrap = db.query(Scrap).options(joinedload(Scrap.region)).filter(Scrap.member_id == member_id, Scrap.region_id == region_id)
if len(list(scrap)) > 0:
return scrap[0]