class SiteCert include Mongoid::Document include Mongoid::Timestamps mount_uploader :cert_file, AssetUploader #Public key mount_uploader :ca_bundle, AssetUploader mount_uploader :private_key, AssetUploader field :is_certbot, type: Boolean ,default: false field :is_valid , type: Boolean ,default: false field :domain_names , type: Array ,default: [] field :source_paths , type: Array ,default: [] field :start_date , type: DateTime field :end_date , type: DateTime field :invalid_message, type: String has_many :site_constructs, :autosave => true after_save :change_data def upload_date self.created_at.strftime("%Y/%m/%d %H:%M") rescue "" end def display_domain_names self.domain_names.join("
").html_safe rescue "" end def generate_file_link(field_name) f = self.send(field_name) file_name = self[field_name] "#{file_name}".html_safe end def display_start_date self.start_date.strftime("%Y-%m-%d") rescue "" end def display_end_date self.end_date.strftime("%Y-%m-%d") rescue "" end def change_data if !@skip_callback cert_file_md5 = `openssl x509 -noout -modulus -in #{self.cert_file.file.file} | openssl md5` private_key_md5 = `openssl rsa -noout -modulus -in #{self.private_key.file.file} | openssl md5` is_valid = (cert_file_md5 == private_key_md5) domain_names = `openssl x509 -text < #{self.cert_file.file.file} | grep 'DNS:' | sed 's/\s*DNS:\([a-z0-9.\-]*\)[,\s]\?/\1 /g'`.split('DNS:').map{|s| s.sub(',','').strip}.select{|s| s.present?} rescue [] if domain_names.length == 0 domain_names = [`openssl x509 -text < #{self.cert_file.file.file} | grep 'Subject' | grep 'CN =' | grep 'Subject' | grep 'CN =' |sed 's/\s*Subject: //g'`[0...-1].split(/, | = /).each_slice(2).to_h['CN']] rescue [] end sign_algo_valid = `openssl x509 -text < #{self.cert_file.file.file} | grep 'Signature Algorithm: sha1'`[0...-1].blank? rescue false invalid_messages = [] if !is_valid invalid_messages << 'cert and key not match' end if !sign_algo_valid invalid_messages << 'Signature Algorithm cannot use sha1, please use sha256' end if domain_names.blank? invalid_messages << 'Domain Names(alt_names) is empty.' end self.invalid_message = invalid_messages.join(', ') if is_valid is_valid = sign_algo_valid end if domain_names.blank? self.is_valid = false @skip_callback = true self.save(:validate=>false) else start_date_text = `openssl x509 -text < #{self.cert_file.file.file} -startdate -noout`.split('=').last.strip end_date_text = `openssl x509 -text < #{self.cert_file.file.file} -enddate -noout`.split('=').last.strip self.start_date = DateTime.parse(start_date_text) rescue nil self.end_date = DateTime.parse(end_date_text) rescue nil self.is_valid = is_valid self.domain_names = domain_names @skip_callback = true self.save(:validate=>false) end @skip_callback = false false end end def valid_domain_names(site_names) site_names = site_names.split(" ").map{|s| s.strip} valid_site_names = [] self.domain_names.each do |d| regx = ::Regexp.new("\\A"+d.gsub('.',"\\.").gsub('*','[^\\.]+').sub(',','').strip) valid_site_names += site_names.select{|s| !(s.match(regx).nil?)} end return valid_site_names end end