mirror of
https://github.com/discourse/discourse.git
synced 2024-11-26 02:40:53 -06:00
8a26ea23f6
Clears out a long-standing TODO I added back in
3d2cace94f
, this way we are only
validating these settings using one central class.
52 lines
1.5 KiB
Ruby
52 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "net/pop"
|
|
|
|
class POP3PollingEnabledSettingValidator
|
|
|
|
def initialize(opts = {})
|
|
@opts = opts
|
|
end
|
|
|
|
def valid_value?(val)
|
|
# only validate when enabling polling
|
|
return true if val == "f"
|
|
# ensure we can authenticate
|
|
SiteSetting.pop3_polling_host.present? &&
|
|
SiteSetting.pop3_polling_username.present? &&
|
|
SiteSetting.pop3_polling_password.present? &&
|
|
authentication_works?
|
|
end
|
|
|
|
def error_message
|
|
if SiteSetting.pop3_polling_host.blank?
|
|
I18n.t("site_settings.errors.pop3_polling_host_is_empty")
|
|
elsif SiteSetting.pop3_polling_username.blank?
|
|
I18n.t("site_settings.errors.pop3_polling_username_is_empty")
|
|
elsif SiteSetting.pop3_polling_password.blank?
|
|
I18n.t("site_settings.errors.pop3_polling_password_is_empty")
|
|
elsif !authentication_works?
|
|
I18n.t("site_settings.errors.pop3_polling_authentication_failed")
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def authentication_works?
|
|
@authentication_works ||= begin
|
|
EmailSettingsValidator.validate_pop3(
|
|
host: SiteSetting.pop3_polling_host,
|
|
port: SiteSetting.pop3_polling_port,
|
|
ssl: SiteSetting.pop3_polling_ssl,
|
|
username: SiteSetting.pop3_polling_username,
|
|
password: SiteSetting.pop3_polling_password,
|
|
openssl_verify: SiteSetting.pop3_polling_openssl_verify
|
|
)
|
|
rescue *EmailSettingsExceptionHandler::EXPECTED_EXCEPTIONS => err
|
|
false
|
|
else
|
|
true
|
|
end
|
|
end
|
|
end
|