ruby RubotyのChatWork Adapterの未来实施

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ruby RubotyのChatWork Adapterの未来实施相关的知识,希望对你有一定的参考价值。

require 'json'
require 'net/http'
require 'open-uri'
require 'pp'

module Ruboty
  module Adapters
    class Chatwork < Base
      include Mem

      env :CHATWORK_API_TOKEN,        "ChatWork API Token"
      env :CHATWORK_ROOM,             "ChatWork Room ID"
      env :CHATWORK_API_RATE,         "ChatWork API Rate(Request per Hour)"

      def run
        listen
      end

      def say(message)
        pp message

        req = Net::HTTP::Post.new(chatwork_messages_url_for_saying(message).path, headers)
        req.form_data = { 'body' => message[:body] }

        https = Net::HTTP.new(chatwork_messages_url_for_saying(message).host, chatwork_messages_url_for_saying(message).port)
        https.use_ssl = true
        https.start {|https| https.request(req) }
      end

      def chatwork_url
        URI.parse(ENV["CHATWORK_URL"] || "https://api.chatwork.com/")
      end
      memoize :chatwork_url

      def chatwork_api_token
        ENV["CHATWORK_API_TOKEN"]
      end
      memoize :chatwork_api_token

      def chatwork_room
        ENV["CHATWORK_ROOM"]
      end
      memoize :chatwork_room

      def chatwork_messages_url
        URI.join(chatwork_url, "/v2/rooms/#{chatwork_room}/messages")
      end
      memoize :chatwork_messages_url

      def chatwork_room_for_saying(message)
        message[:room_id] || message[:original][:room_id] || ENV["CHATWORK_ROOM_FOR_SAYING"] || ENV["CHATWORK_ROOM"]
      end

      def chatwork_messages_url_for_saying(message)
        URI.join(chatwork_url, "/v2/rooms/#{chatwork_room_for_saying(message)}/messages")
      end

      def chatwork_api_rate
        ENV["CHATWORK_API_RATE"].to_i
      end
      memoize :chatwork_api_rate

      def headers
        {
          'X-ChatWorkToken' => chatwork_api_token,
        }
      end
      memoize :headers

      def listen
        loop do
          req = Net::HTTP::Get.new(chatwork_messages_url.path, headers)
          https = Net::HTTP.new(chatwork_messages_url.host, chatwork_messages_url.port)
          https.use_ssl = true
          res = https.start {|https| https.request(req) }
          pp res.body
          unless res.body.nil?
            message       = JSON.parse(res.body)
            original_body = message[0]['body']
            room_id       = extract_room_id(original_body)

            robot.receive(
              body: normalize_original_body(original_body),
              from_name: message[0]['account']['name'],
              room_id: room_id,
            )
          end

          sleep (60 * 60) / chatwork_api_rate
        end
      end

      def specify_room_id_for_saying(original_body)
        original_body[/(.*)( room_id:([0-9]+))\z/, 3]

        # future implementation...
        # @room_name  = original_body[/(.*)( room_name:(.*))\z/, 3]
      end

      def normalize_original_body(original_body)
        if !(original_body[/(.*)( room_id:([0-9]+)\z)/, 1].nil?)
          return original_body[/(.*)( room_id:([0-9]+)\z)/, 1].rstrip
        elsif !(original_body[/(.*)( room_name:(.*)\z)/, 1].nil?)
          return original_body[/(.*)( room_name:(.*)\z)/, 1].rstrip
        else
          original_body
        end
      end

      def extract_room_id(original_body)
        original_body[/(.*)( room_id:([0-9]+))\z/, 3]
      end

      # future implementation...
      def extract_room_name(original_body)
        @room_name  = original_body[/(.*)(room_name:(.*))\z/, 3]
      end

      # future implementation...
      def load_room_id_yaml
        # YAMLの場所はドットエンブで
        # yaml.load
      end

      # future implementation...
      def exchange_room_id_from_room_name(room_name)
        93879522 if room_name == 'for gem test'
      end
    end
  end
end

以上是关于ruby RubotyのChatWork Adapterの未来实施的主要内容,如果未能解决你的问题,请参考以下文章

ruby 红宝石の例外处理の基本

ruby 写真/动画の作成日/更新日情报を的Exifの情报に置换する

Rubyの糖果店

ruby 吉斯特のテスト

ruby Capybara + Poltergeistの雏形

ruby ロードパスの追加