class PublicSuffix::Rule::Wildcard
Wildcard
represents a wildcard rule (e.g. *.co.uk).
Public Class Methods
build(content, private: false)
click to toggle source
Initializes a new rule from the content.
@param content [String] the content of the rule @param private [Boolean]
# File lib/public_suffix/rule.rb, line 222 def self.build(content, private: false) new(value: content.to_s[2..-1], private: private) end
new(value:, length: nil, private: false)
click to toggle source
Initializes a new rule.
@param value [String] @param private [Boolean]
Calls superclass method
PublicSuffix::Rule::Base::new
# File lib/public_suffix/rule.rb, line 230 def initialize(value:, length: nil, private: false) super(value: value, length: length, private: private) length or @length += 1 # * counts as 1 end
Public Instance Methods
decompose(domain)
click to toggle source
Decomposes the domain name according to rule properties.
@param [String, to_s] name The domain name to decompose @return [Array<String>] The array with [trd + sld, tld].
# File lib/public_suffix/rule.rb, line 246 def decompose(domain) suffix = ([".*?"] + parts).join('\.') matches = domain.to_s.match(/^(.*)\.(#{suffix})$/) matches ? matches[1..2] : [nil, nil] end
parts()
click to toggle source
dot-split rule value and returns all rule parts in the order they appear in the value.
@return [Array<String>]
# File lib/public_suffix/rule.rb, line 256 def parts @value.split(DOT) end
rule()
click to toggle source
Gets the original rule definition.
@return [String] The rule definition.
# File lib/public_suffix/rule.rb, line 238 def rule value == "" ? STAR : STAR + DOT + value end