Top Level Namespace
Defined Under Namespace
Modules: Douban, Strutils, Toputils
Instance Method Summary
collapse
Instance Method Details
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
# File 'lib/my_utils/dsysmas.rb', line 14
def (info)
ut = UserToken.where(:taobao_user_id => info['user_id'])[0]
=begin
comment:
seller_id
tid
comment
=end
resp = TopUtil.get_top_response(
:tid => info['tid'],
:result => "good",
:role => "seller",
:session => ut.access_token,
:method => 'taobao.traderate.add',
:content => "很好啊,你妹啊")
$local_log.info(resp)
end
|
#gen_sign(params) ⇒ Object
10
11
12
|
# File 'lib/my_utils/dsysmas.rb', line 10
def gen_sign(params)
Digest::MD5.hexdigest(Settings.app_secret + params.sort_by { |k,v| k.to_s }.flatten.join + Settings.app_secret).upcase
end
|
#taobao_stream ⇒ Object
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
|
# File 'lib/my_utils/dsysmas.rb', line 33
def taobao_stream
params={
"sign_method" => "md5",
"app_key" => Settings.app_key.to_s,
"timestamp" => Time.now.strftime("%Y-%m-%d %H:%M:%S")
}.sort_by{ |k| k.to_s }
post_params = {}
params.map { |key, value| post_params[key] = value }
post_params["sign"] = gen_sign(post_params)
c = HTTPClient.new
conn = c.post_async(Settings.stream_url, post_params)
res = conn.pop
msg = ""
while str = res.content.read(1)
unless(str == "\n")
msg = msg+str
next
end
result_json = JSON.parse(msg)
code=result_json["packet"]["code"]
case code
when 200
puts "服务器连接成功,连接的服务器为#{result_json["packet"]["msg"]}"
$msg_log.info("服务器连接成功,连接的服务器为#{result_json["packet"]["msg"]}")
when 201
puts "接收到心跳包"
$hb_log.info("接收到心跳包")
when 202
puts "有业务消息推送到,消息为#{result_json["packet"]["msg"]}"
$msg_log.info("有业务消息推送到,消息为#{result_json["packet"]["msg"]}")
info = result_json['packet']['msg']['notify_trade']
(info) if info != nil and info['status'] == 'TradeRated'
when 203
puts "有消息丢失,丢失的消息#{result_json["packet"]["msg"]}"
$msg_log.info("有消息丢失,丢失的消息#{result_json["packet"]["msg"]}")
when 101
puts "需要重新连接,已到达最长的服务器连接时间"
$msg_log.info("需要重新连接,已到达最长的服务器连接时间")
when 102
puts "服务器正在升级,需要#{result_json["packet"]["msg"]}秒后进行重连"
$msg_log.info("服务器正在升级,需要#{result_json["packet"]["msg"]}秒后进行重连")
when 103
puts "服务器主动断开连接,需要#{result_json["packet"]["msg"]}秒后进行重连"
$msg_log.info("服务器主动断开连接,需要#{result_json["packet"]["msg"]}秒后进行重连")
when 104
puts "发起了新连接,服务器将要断开此连接,以新连接处理消息请求"
$msg_log.info("发起了新连接,服务器将要断开此连接,以新连接处理消息请求")
when 105
puts "产生大量的消息积压,服务器需要断开连接"
else
puts "服务器返回了未知的应答码:code=#{result_json["packet"]["code"]},msg=#{result_json["packet"]["msg"]}"
$msg_log.info("服务器返回了未知的应答码:code=#{result_json["packet"]["code"]},msg=#{result_json["packet"]["msg"]}")
end
msg=""
end
end
|