forked from hkg36/websockframework
-
Notifications
You must be signed in to change notification settings - Fork 0
/
PostTransServer.py
60 lines (55 loc) · 2.08 KB
/
PostTransServer.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
#coding:utf-8
import getopt
import importlib
import sys
import json
import QueueWork
from datamodel.connection_info import ConnectionInfo
from datamodel.friendlist import FriendList
from datamodel.group import Group
from datamodel.group_member import GroupMember
import dbconfig
def RequestWork(params,body,reply_queue):
post=json.loads(body)
gid=post['gid']
uid=post['uid']
uids=set()
with dbconfig.Session() as session:
group=session.query(Group).filter(Group.gid==gid).first()
if group is None:
return
gwus=session.query(GroupMember).filter(GroupMember.gid==gid).all()
#gwus=session.query(GroupWatchUpdate).filter(GroupWatchUpdate.gid==gid).all()
for gwu in gwus:
uids.add(gwu.uid)
if group.only_member_watch==0:
fds=session.query(FriendList).filter(FriendList.friendid==uid).all()
for fd in fds:
uids.add(fd.uid)
allconn=session.query(ConnectionInfo).filter(ConnectionInfo.uid.in_(list(uids))).all()
to_push=json.dumps({"push":True,
"type":"newpost",
"data":{
"post":post
}
},ensure_ascii=False)
for conn in allconn:
QueueWork.producer.publish(body=to_push,delivery_mode=2,headers={"connid":conn.connection_id},
routing_key=conn.queue_id,
compression='gzip')
if __name__ == '__main__':
config_model='configs.frontend'
opts, args=getopt.getopt(sys.argv[1:],'c:',
['config='])
for k,v in opts:
if k in ('-c','--config'):
config_model=v
try:
configs=importlib.import_module(config_model)
except Exception,e:
print str(e)
exit(0)
QueueWork.WorkFunction=RequestWork
QueueWork.init(configs.Queue_Server,configs.Queue_Port,configs.Queue_Path,
configs.Queue_User,configs.Queue_PassWord,'sys.post_to_notify')
QueueWork.run()