| 
									
										
										
										
											2018-05-27 04:58:08 +02:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require 'resolv' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class EmailMxValidator < ActiveModel::Validator | 
					
						
							|  |  |  |   def validate(user) | 
					
						
							| 
									
										
										
										
											2018-05-29 02:14:24 +09:00
										 |  |  |     return if Rails.env.test? || Rails.env.development? | 
					
						
							| 
									
										
										
										
											2018-05-27 04:58:08 +02:00
										 |  |  |     user.errors.add(:email, I18n.t('users.invalid_email')) if invalid_mx?(user.email) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def invalid_mx?(value) | 
					
						
							|  |  |  |     _, domain = value.split('@', 2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return true if domain.nil? | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     records = Resolv::DNS.new.getresources(domain, Resolv::DNS::Resource::IN::MX).to_a.map { |e| e.exchange.to_s } | 
					
						
							| 
									
										
										
										
											2018-07-26 11:49:28 +09:00
										 |  |  |     records = Resolv::DNS.new.getresources(domain, Resolv::DNS::Resource::IN::A).to_a.map { |e| e.address.to_s } if records.empty? | 
					
						
							| 
									
										
										
										
											2018-07-05 20:57:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-27 04:58:08 +02:00
										 |  |  |     records.empty? || on_blacklist?(records) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def on_blacklist?(values) | 
					
						
							|  |  |  |     EmailDomainBlock.where(domain: values).any? | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |