Class: Telegram::Bot::Client

Inherits:
Object
  • Object
show all
Defined in:
lib/telegram/bot/client.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(token, hash = {}) ⇒ Client

Returns a new instance of Client.



11
12
13
14
15
# File 'lib/telegram/bot/client.rb', line 11

def initialize(token, hash = {})
  @options = default_options.merge(hash)
  @api = Api.new(token, url: options.delete(:url))
  @logger = options.delete(:logger)
end

Instance Attribute Details

#apiObject (readonly)

Returns the value of attribute api.



4
5
6
# File 'lib/telegram/bot/client.rb', line 4

def api
  @api
end

#loggerObject

Returns the value of attribute logger.



5
6
7
# File 'lib/telegram/bot/client.rb', line 5

def logger
  @logger
end

#optionsObject (readonly)

Returns the value of attribute options.



4
5
6
# File 'lib/telegram/bot/client.rb', line 4

def options
  @options
end

Class Method Details

.run(*args, &block) ⇒ Object



7
8
9
# File 'lib/telegram/bot/client.rb', line 7

def self.run(*args, &block)
  new(*args).run(&block)
end

Instance Method Details

#fetch_updatesObject



29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/telegram/bot/client.rb', line 29

def fetch_updates
  response = api.getUpdates(options)
  return unless response['ok']

  response['result'].each do |data|
    update = Types::Update.new(data)
    @options[:offset] = update.update_id.next
    message = update.current_message
    log_incoming_message(message)
    yield message
  end
rescue Faraday::TimeoutError
  retry
end

#listen(&block) ⇒ Object



21
22
23
24
25
26
27
# File 'lib/telegram/bot/client.rb', line 21

def listen(&block)
  logger.info('Starting bot')
  running = true
  Signal.trap('INT') { running = false }
  fetch_updates(&block) while running
  exit
end

#run {|_self| ... } ⇒ Object

Yields:

  • (_self)

Yield Parameters:



17
18
19
# File 'lib/telegram/bot/client.rb', line 17

def run
  yield self
end