mirror of
https://github.com/discourse/discourse.git
synced 2025-02-22 20:42:10 +08:00

This splits off the logic between SSO keys used incoming vs outgoing, it allows to far better restrict who is allowed to log in using a site. This allows for better auditing of the SSO provider feature
11 lines
293 B
Ruby
11 lines
293 B
Ruby
module WildcardDomainChecker
|
|
|
|
def self.check_domain(domain, external_domain)
|
|
escaped_domain = domain[0] == "*" ? Regexp.escape(domain).sub("\\*", '\S*') : Regexp.escape(domain)
|
|
domain_regex = Regexp.new("^#{escaped_domain}$", 'i')
|
|
|
|
external_domain.match(domain_regex)
|
|
end
|
|
|
|
end
|