d119d3d1b2
Renamed UrlValidator to AddressableUrlValidator to avoid 'url:' naming collision with ActiveModel::Validations::UrlValidator in 'validates' statement. Make use of the options attribute of the parent class ActiveModel::EachValidator. Add more options: allow_nil, allow_blank, message. Renamed 'protocols' option to 'schemes' to match the option naming from UrlValidator.
39 lines
1.1 KiB
Ruby
39 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Ci
|
|
# The purpose of this class is to store Build related runner session.
|
|
# Data will be removed after transitioning from running to any state.
|
|
class BuildRunnerSession < ApplicationRecord
|
|
extend Gitlab::Ci::Model
|
|
|
|
TERMINAL_SUBPROTOCOL = 'terminal.gitlab.com'.freeze
|
|
|
|
self.table_name = 'ci_builds_runner_session'
|
|
|
|
belongs_to :build, class_name: 'Ci::Build', inverse_of: :runner_session
|
|
|
|
validates :build, presence: true
|
|
validates :url, addressable_url: { schemes: %w(https) }
|
|
|
|
def terminal_specification
|
|
wss_url = Gitlab::UrlHelpers.as_wss(self.url)
|
|
return {} unless wss_url.present?
|
|
|
|
wss_url = "#{wss_url}/exec"
|
|
channel_specification(wss_url, TERMINAL_SUBPROTOCOL)
|
|
end
|
|
|
|
private
|
|
|
|
def channel_specification(url, subprotocol)
|
|
return {} if subprotocol.blank? || url.blank?
|
|
|
|
{
|
|
subprotocols: Array(subprotocol),
|
|
url: url,
|
|
headers: { Authorization: [authorization.presence] }.compact,
|
|
ca_pem: certificate.presence
|
|
}
|
|
end
|
|
end
|
|
end
|