21
1
Fork 0
mirror of https://github.com/Evolix/chexpire.git synced 2024-06-06 17:44:29 +02:00
chexpire/app/services/whois.rb

64 lines
1.6 KiB
Ruby
Raw Normal View History

# Copyright (C) 2018 Colin Darie <colin@darie.eu>, 2018 Evolix <info@evolix.fr>
# License: GNU AGPL-3+ (see full text in LICENSE file)
# require "null_logger"
# require "domain_helper"
# require "system_command"
# require_relative "whois/parser"
# require_relative "whois/response"
# require_relative "whois/errors"
2018-05-30 12:04:07 +02:00
module Whois
class Error < StandardError; end
2019-03-03 22:47:05 +01:00
class CommandError < Error; end
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)
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