Sha256: ba5b4a1a5cee18698a25737932c791e0d81f9b97639123c07284d1fe0471ab0d
Contents?: true
Size: 1.68 KB
Versions: 2
Compression:
Stored size: 1.68 KB
Contents
require 'edacpfbr/version' module EdaCPFbr def self.validar(cpf) return false if cpf.length < 11 @cpf = cpf return false if not digito_correto(primeiro_bloco,dig1) return false if not digito_correto(segundo_bloco,dig2) true end def self.primeiro_bloco @cpf[0..8] end def self.segundo_bloco @cpf[1..9] end def self.dig1 @cpf[9] end def self.dig2 @cpf[10] end def self.validar_lote(lote) retorno_lote = Hash.new lote.each{ |cpf| retorno_lote[cpf] = validar(cpf) } retorno_lote end def self.digito_correto(bloco,dig) digito(bloco) == dig.to_i end def self.digito(bloco) total = 0 (1..9).each do |i| ind = i - 1 d = bloco[ind].to_i total += d*i end r = total % 11 (r>9) ? 0 : r end def self.digito_contextual(bloco) dig = digito(bloco) return dig if valids dig = dig + 1 dig > 9 ? 0 : dig end def self.gerar_lote_valido(qnt) set_valids(true) gerar_lote(qnt) end def self.gerar_lote_invalido(qnt) set_valids(false) gerar_lote(qnt) end def self.gerar_lote(qnt) lote = Array.new lote_blocos(qnt).each do |bloco1| dig1 = digito_contextual(bloco1) bloco2 = "#{bloco1}#{dig1}"[1..9] dig2 = digito(bloco2) @cpf = "#{bloco1}#{dig1}#{dig2}" lote.push(@cpf) end lote end def self.lote_blocos(qnt) blocos = Array.new while (blocos.length < qnt) do @cpf = "" (1..9).each do |n| @cpf = "#{@cpf}#{rand(10)}" end blocos.push(@cpf) if not blocos.include?(@cpf) end blocos end def self.valids @valids end def self.set_valids(v) @valids = v end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
edacpfbr-0.2.1 | lib/edacpfbr.rb |
edacpfbr-0.2.0 | lib/edacpfbr.rb |