class ActiveModel::Validations::SshPrivateKeyValidator
Public Instance Methods
validate_each(record, attribute, value)
click to toggle source
# File lib/validators/validates_ssh_private_key.rb, line 6 def validate_each(record, attribute, value) return if value.blank? && options[:allow_blank] return if value.nil? && options[:allow_nil] sshkey = SSHKey.new(value.to_s) validate_type(record, attribute, sshkey) validate_bits(record, attribute, sshkey) rescue OpenSSL::PKey::DSAError, OpenSSL::PKey::RSAError record.errors.add( attribute, :invalid_ssh_private_key, message: options[:message], value: value ) end
Private Instance Methods
validate_bits(record, attribute, sshkey)
click to toggle source
# File lib/validators/validates_ssh_private_key.rb, line 37 def validate_bits(record, attribute, sshkey) return unless options[:bits] return if sshkey.bits >= options[:bits].to_i record.errors.add( attribute, :invalid_ssh_private_key_bits, message: options[:message], value: sshkey.bits, required: options[:bits] ) end
validate_type(record, attribute, sshkey)
click to toggle source
# File lib/validators/validates_ssh_private_key.rb, line 22 def validate_type(record, attribute, sshkey) return unless options[:type] valid = [options[:type]].flatten.compact.map(&:to_s).include?(sshkey.type) return if valid record.errors.add( attribute, :invalid_ssh_private_key_type, message: options[:message], value: (%w[rsa dsa] - [sshkey.type])[0].upcase ) end