Top Level Namespace

Defined Under Namespace

Modules: Douban, Strutils, Toputils

Instance Method Summary collapse

Instance Method Details

#comment(info) ⇒ Object



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 comment(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_streamObject



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)
      
      #TODO处理消息的代码,这里需要改成异步的,消息量大的时候,会产生消息积压
      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']
        comment(info) if info != nil and info['status'] == 'TradeRated'
        # TODO
        #TaobaoTrade.stream_trade_msg result_json["packet"]["msg"]
      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