Class: Rubycord::Voice::VoiceUDP
- Inherits:
-
Object
- Object
- Rubycord::Voice::VoiceUDP
- Defined in:
- lib/rubycord/voice/network.rb
Overview
Represents a UDP connection to a voice server. This connection is used to send the actual audio data.
Instance Attribute Summary collapse
-
#encrypted ⇒ true, false
(also: #encrypted?)
deprecated
Deprecated.
Discord no longer supports unencrypted voice communication.
-
#mode ⇒ Object
readonly
The UDP encryption mode.
-
#secret_key ⇒ Object
writeonly
Sets the secret key used for encryption.
Instance Method Summary collapse
-
#connect(ip, port, ssrc) ⇒ Object
Initializes the UDP socket with data obtained from opcode 2.
-
#initialize ⇒ VoiceUDP
constructor
Creates a new UDP connection.
-
#receive_discovery_reply ⇒ Array(String, Integer)
Waits for a UDP discovery reply, and returns the sent data.
-
#send_audio(buf, sequence, time) ⇒ Object
Makes an audio packet from a buffer and sends it to Discord.
-
#send_discovery ⇒ Object
Sends the UDP discovery packet with the internally stored SSRC.
Constructor Details
#initialize ⇒ VoiceUDP
Creates a new UDP connection. Only creates a socket as the discovery reply may come before the data is initialized.
50 51 52 53 |
# File 'lib/rubycord/voice/network.rb', line 50 def initialize @socket = UDPSocket.new @encrypted = true end |
Instance Attribute Details
#encrypted ⇒ true, false Also known as: encrypted?
Discord no longer supports unencrypted voice communication.
Returns whether or not UDP communications are encrypted.
36 37 38 |
# File 'lib/rubycord/voice/network.rb', line 36 def encrypted @encrypted end |
#mode ⇒ Object
The UDP encryption mode
43 44 45 |
# File 'lib/rubycord/voice/network.rb', line 43 def mode @mode end |
#secret_key=(value) ⇒ Object (writeonly)
Sets the secret key used for encryption
40 41 42 |
# File 'lib/rubycord/voice/network.rb', line 40 def secret_key=(value) @secret_key = value end |
Instance Method Details
#connect(ip, port, ssrc) ⇒ Object
Initializes the UDP socket with data obtained from opcode 2.
60 61 62 63 64 |
# File 'lib/rubycord/voice/network.rb', line 60 def connect(ip, port, ssrc) @ip = ip @port = port @ssrc = ssrc end |
#receive_discovery_reply ⇒ Array(String, Integer)
Waits for a UDP discovery reply, and returns the sent data.
68 69 70 71 72 73 74 |
# File 'lib/rubycord/voice/network.rb', line 68 def receive_discovery_reply # Wait for a UDP message = @socket.recv(74) ip = [8..-3].delete("\0") port = [-2..].unpack1("n") [ip, port] end |
#send_audio(buf, sequence, time) ⇒ Object
Makes an audio packet from a buffer and sends it to Discord.
81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/rubycord/voice/network.rb', line 81 def send_audio(buf, sequence, time) # Header of the audio packet header = [0x80, 0x78, sequence, time, @ssrc].pack("CCnNN") nonce = generate_nonce(header) buf = encrypt_audio(buf, nonce) data = header + buf # xsalsa20_poly1305 does not require an appended nonce data += nonce unless @mode == "xsalsa20_poly1305" send_packet(data) end |
#send_discovery ⇒ Object
Sends the UDP discovery packet with the internally stored SSRC. Discord will send a reply afterwards which can be received using #receive_discovery_reply
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/rubycord/voice/network.rb', line 98 def send_discovery # Create empty packet discovery_packet = "" # Add Type request (0x1 = request, 0x2 = response) discovery_packet += [0x1].pack("n") # Add Length (excluding Type and itself = 70) discovery_packet += [70].pack("n") # Add SSRC discovery_packet += [@ssrc].pack("N") # Add 66 zeroes so the packet is 74 bytes long discovery_packet += "\0" * 66 send_packet(discovery_packet) end |