Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion app/domain/authentication/authn_k8s/web_socket_client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ def connect(url, options = {})
when Resolv::IPv4::Regex, Resolv::IPv6::Regex
# don't set SNI, as IP addresses in SNI is not valid
# per RFC 6066, section 3.

# Avoid openssl warning
ctx.verify_hostname = false
else
Expand Down Expand Up @@ -106,13 +106,16 @@ def connect(url, options = {})
end

def send(data, opt = { type: :text })
puts("Websocket Send: attempting to send: #{data.inspect}")
return if !@handshaked || @closed

type = opt[:type]
frame = ::WebSocket::Frame::Outgoing::Client.new(data: data, type: type, version: @handshake.version)
begin
@socket.write(frame.to_s)
rescue Errno::EPIPE => e
Rails.logger.error("Websocket failed to send: '#{data}'")

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Authentication::AuthnK8s::WebSocketClient#send calls 'Rails.logger' 2 times

Rails.logger.error("error: #{e}")
@pipe_broken = true
emit(:__close, e)
end
Expand Down
14 changes: 7 additions & 7 deletions spec/controllers/authenticate_controller_authn_k8s_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@

# Turn on logs to debug
#
# Rails.logger.extend(ActiveSupport::Logger.broadcast(ActiveSupport::TaggedLogging.new(Logger.new(STDOUT))))
# Rails.logger.level = :info
# Audit.logger = Audit::Log::SyslogAdapter.new(
# Logger.new(STDOUT).tap do |logger|
# logger.formatter = Logger::Formatter::RFC5424Formatter
# end
# )
Rails.logger.extend(ActiveSupport::Logger.broadcast(ActiveSupport::TaggedLogging.new(Logger.new(STDOUT))))
Rails.logger.level = :info
Audit.logger = Audit::Log::SyslogAdapter.new(
Logger.new(STDOUT).tap do |logger|
logger.formatter = Logger::Formatter::RFC5424Formatter
end
)

def set_variable_value(account, resource_id, value)
post("/secrets/#{account}/variable/#{resource_id}", env: admin_request_env.merge({ 'RAW_POST_DATA' => value }))
Expand Down