Class: Slack::RealTime::Socket

Inherits:
Object
  • Object
show all
Defined in:
lib/slack/real_time/socket.rb

Direct Known Subclasses

Concurrency::Async::Socket

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(url, options = {}) ⇒ Socket

Returns a new instance of Socket.



9
10
11
12
13
14
15
# File 'lib/slack/real_time/socket.rb', line 9

def initialize(url, options = {})
  @url = url
  @options = options.dup
  @driver = nil
  @logger = @options.delete(:logger) || Slack::RealTime::Config.logger || Slack::Config.logger
  @last_message_at = nil
end

Instance Attribute Details

#driverObject (readonly)

Returns the value of attribute driver.



7
8
9
# File 'lib/slack/real_time/socket.rb', line 7

def driver
  @driver
end

#optionsObject

Returns the value of attribute options.



6
7
8
# File 'lib/slack/real_time/socket.rb', line 6

def options
  @options
end

#urlObject

Returns the value of attribute url.



5
6
7
# File 'lib/slack/real_time/socket.rb', line 5

def url
  @url
end

Instance Method Details

#closeObject



77
78
79
80
81
82
83
84
85
# File 'lib/slack/real_time/socket.rb', line 77

def close
  # When you call `driver.emit(:close)`, it will typically end up calling `client.close`
  # which will call `@socket.close` and end up back here. In order to break this infinite
  # recursion, we check and set `@driver = nil` before invoking `client.close`.
  return unless (driver = @driver)

  @driver = nil
  driver.emit(:close)
end

#connect! {|@driver| ... } ⇒ Object

Yields:



27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/slack/real_time/socket.rb', line 27

def connect!
  return if connected?

  connect
  logger.debug("#{self.class}##{__method__}") { @driver.class }

  @driver.on :message do
    @last_message_at = current_time
  end

  yield @driver if block_given?
end

#connected?Boolean

Returns:

  • (Boolean)


47
48
49
# File 'lib/slack/real_time/socket.rb', line 47

def connected?
  !@driver.nil?
end

#current_timeObject



73
74
75
# File 'lib/slack/real_time/socket.rb', line 73

def current_time
  Process.clock_gettime(Process::CLOCK_MONOTONIC)
end

#disconnect!Object

Gracefully shut down the connection.



41
42
43
44
45
# File 'lib/slack/real_time/socket.rb', line 41

def disconnect!
  @driver.close
ensure
  close
end

#restart_async(_client, _url) ⇒ Object

Raises:

  • (NotImplementedError)


63
64
65
# File 'lib/slack/real_time/socket.rb', line 63

def restart_async(_client, _url)
  raise NotImplementedError, "Expected #{self.class} to implement #{__method__}."
end

#send_data(message) ⇒ Object



17
18
19
20
21
22
23
24
25
# File 'lib/slack/real_time/socket.rb', line 17

def send_data(message)
  logger.debug("#{self.class}##{__method__}") { message }
  case message
  when Numeric then @driver.text(message.to_s)
  when String  then @driver.text(message)
  when Array   then @driver.binary(message)
  else false
  end
end

#start_async(_client) ⇒ #join

Returns:

  • (#join)

Raises:

  • (NotImplementedError)


59
60
61
# File 'lib/slack/real_time/socket.rb', line 59

def start_async(_client)
  raise NotImplementedError, "Expected #{self.class} to implement #{__method__}."
end

#start_sync(client) ⇒ Object



51
52
53
54
55
56
# File 'lib/slack/real_time/socket.rb', line 51

def start_sync(client)
  thread = start_async(client)
  thread&.join
rescue Interrupt
  thread&.exit
end

#time_since_last_messageObject



67
68
69
70
71
# File 'lib/slack/real_time/socket.rb', line 67

def time_since_last_message
  return 0 unless @last_message_at

  current_time - @last_message_at
end