Sha256: e087123f08deecd074aef65861b4abbad2331d669438eac55a2512ddf22a57e2

Contents?: true

Size: 1.99 KB

Versions: 10

Compression:

Stored size: 1.99 KB

Contents

# frozen_string_literal: true

require "base64"

module Mihari
  module Clients
    #
    # CIRCL passive DNS/SSL API client
    #
    class CIRCL < Base
      #
      # @param [String] base_url
      # @param [String, nil] username
      # @param [String, nil] password
      # @param [Hash] headers
      # @param [Integer, nil] timeout
      #
      def initialize(base_url = "https://www.circl.lu", username:, password:, headers: {}, timeout: nil)
        raise(ArgumentError, "username is required") if username.nil?
        raise(ArgumentError, "password is required") if password.nil?

        headers["authorization"] = "Basic #{Base64.strict_encode64("#{username}:#{password}")}"

        super(base_url, headers:, timeout:)
      end

      #
      # Passive DNS search
      #
      # @param [String] query
      #
      # @return [Array<String>]
      #
      def passive_dns_search(query)
        results = dns_query(query)
        results.filter_map do |result|
          type = result["rrtype"]
          (type == "A") ? result["rdata"] : nil
        end.uniq
      end

      #
      # Passive SSL search
      #
      # @param [String] query
      #
      # @return [Array<String>]
      #
      def passive_ssl_search(query)
        result = ssl_cquery(query)
        seen = result["seen"] || []
        seen.uniq
      end

      #
      # @param [String] query
      #
      # @return [Hash]
      #
      def dns_query(query)
        _get("/pdns/query/#{query}")
      end

      #
      # @param [String] query
      #
      # @return [Hash]
      #
      def ssl_cquery(query)
        _get("/v2pssl/cquery/#{query}")
      end

      private

      #
      # @param [String] path
      # @param [Hash] params
      #
      def _get(path, params: {})
        res = get(path, params:)
        body = res.body.to_s
        content_type = res["Content-Type"].to_s

        return JSON.parse(body) if content_type.include?("application/json")

        body.lines.map { |line| JSON.parse line }
      end
    end
  end
end

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
mihari-8.0.2 lib/mihari/clients/circl.rb
mihari-8.0.1 lib/mihari/clients/circl.rb
mihari-8.0.0 lib/mihari/clients/circl.rb
mihari-7.6.4 lib/mihari/clients/circl.rb
mihari-7.6.3 lib/mihari/clients/circl.rb
mihari-7.6.2 lib/mihari/clients/circl.rb
mihari-7.6.1 lib/mihari/clients/circl.rb
mihari-7.6.0 lib/mihari/clients/circl.rb
mihari-7.5.0 lib/mihari/clients/circl.rb
mihari-7.4.0 lib/mihari/clients/circl.rb