Class: LogStash::Outputs::DatadogLogs::DatadogTCPClient
- Inherits:
-
DatadogClient
- Object
- DatadogClient
- LogStash::Outputs::DatadogLogs::DatadogTCPClient
- Defined in:
- lib/logstash/outputs/datadog_logs.rb
Instance Method Summary collapse
- #close ⇒ Object
- #connect ⇒ Object
-
#initialize(logger, use_ssl, no_ssl_validation, host, port) ⇒ DatadogTCPClient
constructor
A new instance of DatadogTCPClient.
- #send(payload) ⇒ Object
Methods inherited from DatadogClient
Constructor Details
#initialize(logger, use_ssl, no_ssl_validation, host, port) ⇒ DatadogTCPClient
Returns a new instance of DatadogTCPClient.
260 261 262 263 264 265 266 |
# File 'lib/logstash/outputs/datadog_logs.rb', line 260 def initialize(logger, use_ssl, no_ssl_validation, host, port) @logger = logger @use_ssl = use_ssl @no_ssl_validation = no_ssl_validation @host = host @port = port end |
Instance Method Details
#close ⇒ Object
296 297 298 |
# File 'lib/logstash/outputs/datadog_logs.rb', line 296 def close @socket.close rescue nil end |
#connect ⇒ Object
268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 |
# File 'lib/logstash/outputs/datadog_logs.rb', line 268 def connect if @use_ssl @logger.info("Starting SSL connection #{@host} #{@port}") socket = TCPSocket.new @host, @port ssl_context = OpenSSL::SSL::SSLContext.new if @no_ssl_validation ssl_context.set_params({:verify_mode => OpenSSL::SSL::VERIFY_NONE}) end ssl_context = OpenSSL::SSL::SSLSocket.new socket, ssl_context ssl_context.connect ssl_context else @logger.info("Starting plaintext connection #{@host} #{@port}") TCPSocket.new @host, @port end end |
#send(payload) ⇒ Object
285 286 287 288 289 290 291 292 293 294 |
# File 'lib/logstash/outputs/datadog_logs.rb', line 285 def send(payload) begin @socket ||= connect @socket.puts(payload) rescue => e @socket.close rescue nil @socket = nil raise RetryableError.new "Unable to send payload: #{e.}." end end |