Commit 12563bb3 authored by Vladimir Shushlin's avatar Vladimir Shushlin

Fix saving domain without certificate for auto_ssl

parent 5ea899d3
...@@ -12,9 +12,11 @@ class PagesDomain < ApplicationRecord ...@@ -12,9 +12,11 @@ class PagesDomain < ApplicationRecord
validates :domain, hostname: { allow_numeric_hostname: true } validates :domain, hostname: { allow_numeric_hostname: true }
validates :domain, uniqueness: { case_sensitive: false } validates :domain, uniqueness: { case_sensitive: false }
validates :certificate, presence: { message: 'must be present if HTTPS-only is enabled' }, if: ->(domain) { domain.project&.pages_https_only? } validates :certificate, presence: { message: 'must be present if HTTPS-only is enabled' },
if: :certificate_should_be_present?
validates :certificate, certificate: true, if: ->(domain) { domain.certificate.present? } validates :certificate, certificate: true, if: ->(domain) { domain.certificate.present? }
validates :key, presence: { message: 'must be present if HTTPS-only is enabled' }, if: ->(domain) { domain.project&.pages_https_only? } validates :key, presence: { message: 'must be present if HTTPS-only is enabled' },
if: :certificate_should_be_present?
validates :key, certificate_key: true, if: ->(domain) { domain.key.present? } validates :key, certificate_key: true, if: ->(domain) { domain.key.present? }
validates :verification_code, presence: true, allow_blank: false validates :verification_code, presence: true, allow_blank: false
...@@ -249,4 +251,8 @@ class PagesDomain < ApplicationRecord ...@@ -249,4 +251,8 @@ class PagesDomain < ApplicationRecord
rescue OpenSSL::PKey::PKeyError, OpenSSL::Cipher::CipherError rescue OpenSSL::PKey::PKeyError, OpenSSL::Cipher::CipherError
nil nil
end end
def certificate_should_be_present?
!auto_ssl_enabled? && project&.pages_https_only?
end
end end
...@@ -53,24 +53,33 @@ describe PagesDomain do ...@@ -53,24 +53,33 @@ describe PagesDomain do
end end
let(:pages_domain) do let(:pages_domain) do
build(:pages_domain, certificate: certificate, key: key).tap do |pd| build(:pages_domain, certificate: certificate, key: key,
auto_ssl_enabled: auto_ssl_enabled).tap do |pd|
allow(pd).to receive(:project).and_return(project) allow(pd).to receive(:project).and_return(project)
pd.valid? pd.valid?
end end
end end
where(:pages_https_only, :certificate, :key, :errors_on) do where(:pages_https_only, :certificate, :key, :auto_ssl_enabled, :errors_on) do
attributes = attributes_for(:pages_domain) attributes = attributes_for(:pages_domain)
cert, key = attributes.fetch_values(:certificate, :key) cert, key = attributes.fetch_values(:certificate, :key)
true | nil | nil | %i(certificate key) true | nil | nil | false | %i(certificate key)
true | cert | nil | %i(key) true | nil | nil | true | []
true | nil | key | %i(certificate key) true | cert | nil | false | %i(key)
true | cert | key | [] true | cert | nil | true | %i(key)
false | nil | nil | [] true | nil | key | false | %i(certificate key)
false | cert | nil | %i(key) true | nil | key | true | %i(key)
false | nil | key | %i(key) true | cert | key | false | []
false | cert | key | [] true | cert | key | true | []
false | nil | nil | false | []
false | nil | nil | true | []
false | cert | nil | false | %i(key)
false | cert | nil | true | %i(key)
false | nil | key | false | %i(key)
false | nil | key | true | %i(key)
false | cert | key | false | []
false | cert | key | true | []
end end
with_them do with_them do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment