2018-08-02 00:09:29 +02:00
|
|
|
# Copyright (C) 2018 Colin Darie <colin@darie.eu>, 2018 Evolix <info@evolix.fr>
|
|
|
|
# License: GNU AGPL-3+ (see full text in LICENSE file)
|
|
|
|
|
2018-05-30 12:04:07 +02:00
|
|
|
module Whois
|
2019-03-03 10:42:19 +01:00
|
|
|
class Error < StandardError; end
|
|
|
|
|
2019-03-03 22:47:05 +01:00
|
|
|
class CommandError < Error; end
|
2019-03-03 10:42:19 +01:00
|
|
|
class UnsupportedDomainError < Error; end
|
|
|
|
class DomainNotFoundError < Error; end
|
|
|
|
class ParserError < Error; end
|
|
|
|
|
|
|
|
class FieldNotFoundError < ParserError; end
|
|
|
|
class InvalidDateError < ParserError; end
|
|
|
|
|
2018-05-30 12:04:07 +02:00
|
|
|
class << self
|
2018-05-30 13:23:15 +02:00
|
|
|
def ask(domain, system_klass: SystemCommand, logger: NullLogger.new)
|
2018-05-30 18:16:43 +02:00
|
|
|
Service.new(domain, system_klass: system_klass, logger: logger).call
|
2018-05-30 12:04:07 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class Service
|
|
|
|
attr_reader :domain
|
|
|
|
attr_reader :logger
|
2018-05-30 13:23:15 +02:00
|
|
|
attr_reader :system_klass
|
2018-05-30 12:04:07 +02:00
|
|
|
|
2018-05-30 13:23:15 +02:00
|
|
|
def initialize(domain, system_klass: SystemCommand, logger: NullLogger.new)
|
2018-05-30 12:04:07 +02:00
|
|
|
@domain = domain
|
|
|
|
@logger = logger
|
2018-05-30 13:23:15 +02:00
|
|
|
@system_klass = system_klass
|
2018-05-30 12:04:07 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def call
|
2018-05-30 13:23:15 +02:00
|
|
|
result = run_command
|
|
|
|
parse(result)
|
2018-05-30 16:51:24 +02:00
|
|
|
rescue StandardError => ex
|
|
|
|
logger.log :service_error, ex
|
|
|
|
raise
|
2018-05-30 13:23:15 +02:00
|
|
|
end
|
2018-05-30 12:04:07 +02:00
|
|
|
|
2018-05-30 13:23:15 +02:00
|
|
|
def run_command
|
|
|
|
command = system_klass.new("whois", domain, logger: logger)
|
|
|
|
result = command.execute
|
|
|
|
|
|
|
|
unless result.exit_status.zero?
|
2019-03-03 22:47:05 +01:00
|
|
|
fail Whois::CommandError, "Whois command failed with status #{result.exit_status}"
|
2018-05-30 13:23:15 +02:00
|
|
|
end
|
2018-05-30 12:04:07 +02:00
|
|
|
|
2018-05-30 13:23:15 +02:00
|
|
|
result
|
|
|
|
end
|
|
|
|
|
|
|
|
def parse(result)
|
|
|
|
parser = Parser.for(domain, logger: logger)
|
|
|
|
parser.parse(result.stdout)
|
2018-05-30 12:04:07 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|