# frozen_string_literal: true require 'ipaddr' module Dyndnsd class Helper # @param hostname [String] # @param domain [String] # @return [Boolean] def self.fqdn_valid?(hostname, domain) return false if hostname.length < domain.length + 2 return false if !hostname.end_with?(domain) name = hostname.chomp(domain) return false if !name.match(/^[a-zA-Z0-9_-]+\.$/) true end # @param ip [String] # @return [Boolean] def self.ip_valid?(ip) IPAddr.new(ip) true rescue ArgumentError false end # @param username [String] # @param password [String] # @param users [Hash] # @return [Boolean] def self.user_allowed?(username, password, users) (users.key? username) && (users[username]['password'] == password) end # @param hostname [String] # @param myips [Array] # @param hosts [Hash] # @return [Boolean] def self.changed?(hostname, myips, hosts) # myips order is always deterministic ((!hosts.include? hostname) || (hosts[hostname] != myips)) && !myips.empty? end # @param operation [String] # @param block [Proc] # @return [void] def self.span(operation, &block) tracer = OpenTelemetry.tracer_provider.tracer(Dyndnsd.name, Dyndnsd::VERSION) tracer.in_span( operation, attributes: {'component' => 'dyndnsd'}, kind: :server ) do |span| Dyndnsd.logger.debug "Creating span ID #{span.context.hex_span_id} for trace ID #{span.context.hex_trace_id}" block.call(span) rescue StandardError => e span.record_exception(e) raise e end end end end