class Faker::IdNumber
Constants
- BRAZILIAN_ID_FORMAT
- BRAZILIAN_ID_FROM
- BRAZILIAN_ID_TO
- CHECKS
- CHILEAN_MODULO
- INVALID_SSN
- ZA_CITIZENSHIP_DIGITS
- ZA_RACE_DIGIT
Public Class Methods
Source
# File lib/faker/default/id_number.rb, line 163 def brazilian_citizen_number(formatted: false) digits = Faker::Number.leading_zero_number(digits: 9) until digits&.match(/(\d)((?!\1)\d)+/) first_digit = brazilian_citizen_number_checksum_digit(digits) second_digit = brazilian_citizen_number_checksum_digit(digits + first_digit) number = [digits, first_digit, second_digit].join formatted ? format('%s.%s.%s-%s', *number.scan(/\d{2,3}/).flatten) : number end
Produces a random Brazilian Citizen Number
(CPF).
@param formatted [Boolean] Specifies if the number is formatted with dividers. @return [String]
@example
Faker::IdNumber.brazilian_citizen_number #=> "53540542221" Faker::IdNumber.brazilian_citizen_number(formatted: true) #=> "535.405.422-21"
@faker.version 1.9.2
Source
# File lib/faker/default/id_number.rb, line 184 def brazilian_id(formatted: false) digits = Faker::Number.between(to: BRAZILIAN_ID_FROM, from: BRAZILIAN_ID_TO).to_s check_digit = brazilian_id_checksum_digit(digits) number = [digits, check_digit].join formatted ? format('%s.%s.%s-%s', *number.scan(BRAZILIAN_ID_FORMAT).flatten) : number end
Produces a random Brazilian ID Number
(RG).
@param formatted [Boolean] Specifies if the number is formatted with dividers. @return [String]
@example
Faker::IdNumber.brazilian_id #=> "493054029" Faker::IdNumber.brazilian_id(formatted: true) #=> "49.305.402-9"
@faker.version 2.1.2
Source
# File lib/faker/default/id_number.rb, line 202 def chilean_id digits = Faker::Number.number(digits: 8) verification_code = chilean_verification_code(digits) "#{digits}-#{verification_code}" end
Produces a random Chilean ID (Rut with 8 digits).
@return [String]
@example
Faker::IdNumber.chilean_id #=> "15620613-K"
@faker.version 2.1.2
Source
# File lib/faker/default/id_number.rb, line 220 def croatian_id(international: false) prefix = international ? 'HR' : '' digits = Faker::Number.number(digits: 10).to_s checksum_digit = croatian_id_checksum_digit(digits) "#{prefix}#{digits}#{checksum_digit}" end
Produces a random Croatian ID number (OIB).
@param international [Boolean] Specifies whether to add international prefix. @return [String]
@example
Faker::IdNumber.croatian_id #=> "88467617508" Faker::IdNumber.croatian_id(international: true) #=> "HR88467617508"
@faker.version next
Source
# File lib/faker/default/id_number.rb, line 247 def danish_id_number(formatted: false, birthday: Faker::Date.birthday, gender: nil) valid_control_digits = danish_control_digits(birthday) control_digit = sample(valid_control_digits) digits = (0..9).to_a gender = gender.to_sym if gender.respond_to?(:to_sym) gender_digit = case gender when nil sample(digits) when :male sample(digits.select(&:odd?)) when :female sample(digits.select(&:even?)) else raise ArgumentError, "Invalid gender #{gender}. Must be one of male, female, or be omitted." end [ birthday.strftime('%d%m%y'), formatted ? '-' : '', control_digit, Faker::Number.number(digits: 2), gender_digit ].join end
Produces a random Danish ID Number
(CPR number). CPR number is 10 digits. Digit 1-6 is the birthdate (format “DDMMYY”). Digit 7-10 is a sequence number. Digit 7 digit is a control digit that determines the century of birth. Digit 10 reveals the gender: # even is female, odd is male.
@param formatted [Boolean] Specifies if the number is formatted with dividers. @param birthday [Date] Specifies the birthday for the id number. @param gender [Symbol] Specifies the gender for the id number. Must be one :male or :female if present. @return [String]
@example
Faker::IdNumber.danish_id_number #=> "0503909980" Faker::IdNumber.danish_id_number(formatted: true) #=> "050390-9980" Faker::IdNumber.danish_id_number(birthday: Date.new(1990, 3, 5)) #=> "0503909980" Faker::IdNumber.danish_id_number(gender: :female) #=> "0503909980"
@faker.version next
Source
# File lib/faker/default/id_number.rb, line 281 def french_insee_number num = [ [1, 2].sample(random: Faker::Config.random), # gender Faker::Number.between(from: 0, to: 99).to_s.rjust(2, '0'), # year of birth Faker::Number.between(from: 1, to: 12).to_s.rjust(2, '0'), # month of birth Faker::Number.number(digits: 5), # place of birth Faker::Number.number(digits: 3) # order number ].join mod = num.to_i % 97 check = (97 - mod).to_s.rjust(2, '0') "#{num}#{check}" end
Produces a random French social security number (INSEE number).
@return [String]
@example
Faker::IdNumber.french_insee_number #=> "53290236-H"
@faker.version next
Source
# File lib/faker/default/id_number.rb, line 44 def invalid _translate('invalid') end
Produces a random invalid US Social Security number.
@return [String]
@example
Faker::IdNumber.invalid #=> "311-72-0000"
@faker.version 1.6.0
Source
# File lib/faker/default/id_number.rb, line 135 def invalid_south_african_id_number invalid_date_of_birth = [ Faker::Number.number(digits: 2), Faker::Number.between(from: 13, to: 99), Faker::Number.between(from: 32, to: 99) ].map(&:to_s).join id_number = [ invalid_date_of_birth, Faker::Number.number(digits: 4), ZA_CITIZENSHIP_DIGITS.sample(random: Faker::Config.random), ZA_RACE_DIGIT ].join [id_number, south_african_id_checksum_digit(id_number)].join end
Produces a random invalid South African ID Number
.
@return [String]
@example
Faker::IdNumber.invalid_south_african_id_number #=> "1642972065088"
@faker.version 1.9.2
Source
# File lib/faker/default/id_number.rb, line 77 def spanish_citizen_number num = Faker::Number.number(digits: 8) mod = num.to_i % 23 check = CHECKS[mod] "#{num}-#{check}" end
Produces a random Spanish citizen identifier (DNI).
@return [String]
@example
Faker::IdNumber.spanish_citizen_number #=> "53290236-H"
@faker.version 1.9.0
Source
# File lib/faker/default/id_number.rb, line 93 def spanish_foreign_citizen_number code = 'XYZ' digits = Faker::Number.number(digits: 7) prefix = code[rand(code.length)] prefix_val = 'XYZ'.index(prefix).to_s mod = "#{prefix_val}#{digits}".to_i % 23 check = CHECKS[mod] "#{prefix}-#{digits}-#{check}" end
Produces a random Spanish foreign born citizen identifier (NIE).
@return [String]
@example
Faker::IdNumber.spanish_foreign_citizen_number #=> "Z-1600870-Y"
@faker.version 1.9.0
Source
# File lib/faker/default/id_number.rb, line 48 def ssn_valid generate(:string) do |g| g.computed(name: :first) do range = [1..665, 667..899].sample(random: Faker::Config.random) n = Faker::Base.rand(range) format('%03d', n) end g.lit('-') g.computed(name: :second) do n = Faker::Base.rand(1..99) format('%02d', n) end g.lit('-') g.computed(name: :third) do n = Faker::Base.rand(1..9999) format('%04d', n) end end end
Source
# File lib/faker/default/id_number.rb, line 31 def valid _translate('valid') end
Produces a random valid US Social Security number.
@return [String]
@example
Faker::IdNumber.valid #=> "552-56-3593"
@faker.version 1.6.0
Source
# File lib/faker/default/id_number.rb, line 113 def valid_south_african_id_number id_number = [ Faker::Date.birthday.strftime('%y%m%d'), Faker::Number.number(digits: 4), ZA_CITIZENSHIP_DIGITS.sample(random: Faker::Config.random), ZA_RACE_DIGIT ].join [id_number, south_african_id_checksum_digit(id_number)].join end
Produces a random valid South African ID Number
.
@return [String]
@example
Faker::IdNumber.south_african_id_number #=> "8105128870184" Faker::IdNumber.valid_south_african_id_number #=> "8105128870184"
@faker.version 1.9.2
Private Class Methods
Source
# File lib/faker/default/id_number.rb, line 419 def _translate(key) parse("id_number.#{key}") end
Source
# File lib/faker/default/id_number.rb, line 349 def brazilian_citizen_number_checksum_digit(digits) checksum = brazilian_document_checksum(digits) brazilian_document_digit(checksum) end
Source
# File lib/faker/default/id_number.rb, line 370 def brazilian_citizen_number_digit(remainder) remainder == 10 ? '0' : remainder.to_s end
Source
# File lib/faker/default/id_number.rb, line 359 def brazilian_document_checksum(digits) digits.chars.each_with_index.inject(0) do |acc, (digit, i)| acc + digit.to_i * (digits.size + 1 - i) end * 10 end
Source
# File lib/faker/default/id_number.rb, line 365 def brazilian_document_digit(checksum, id: false) remainder = checksum % 11 id ? brazilian_id_digit(remainder) : brazilian_citizen_number_digit(remainder) end
Source
# File lib/faker/default/id_number.rb, line 354 def brazilian_id_checksum_digit(digits) checksum = brazilian_document_checksum(digits) brazilian_document_digit(checksum, id: true) end
Source
# File lib/faker/default/id_number.rb, line 374 def brazilian_id_digit(remainder) subtraction = 11 - remainder.to_i digits = { 10 => 'X', 11 => '0' } digits.include?(subtraction) ? digits[subtraction] : subtraction.to_s end
Source
# File lib/faker/default/id_number.rb, line 311 def chilean_verification_code(digits) # First digit is multiplied by 3, second by 2, and so on multiplication_rule = [3, 2, 7, 6, 5, 4, 3, 2] digits_splitted = digits.to_s.chars.map(&:to_i) sum = digits_splitted.map.with_index { |digit, index| digit * multiplication_rule[index] }.reduce(:+) modulo = sum.modulo(CHILEAN_MODULO) difference = CHILEAN_MODULO - modulo case difference when 0..9 difference when 10 'K' when 11 0 end end
Source
# File lib/faker/default/id_number.rb, line 296 def croatian_id_checksum_digit(digits) control_sum = 10 digits.chars.map(&:to_i).each do |digit| control_sum += digit control_sum %= 10 control_sum = 10 if control_sum.zero? control_sum *= 2 control_sum %= 11 end control_sum = 11 - control_sum control_sum % 10 end
Source
# File lib/faker/default/id_number.rb, line 380 def danish_control_digits(birthday) year = birthday.year century = year.to_s.slice(0, 2).to_i year_digits = year.to_s.slice(2, 2).to_i error_message = "Invalid birthday: #{birthday}. Danish CPR numbers are only distributed to persons born between 1858 and 2057." case century when 18 # If 5, 6, 7 or 8 and the year numbers are greater than or equal to 58, you were born in 18XX. case year_digits when 58..99 [5, 6, 7, 8] else raise ArgumentError, error_message end when 19 # If 0, 1, 2 or 3, you are always born in 19XX. # If 4 or 9, you are born in 19XX if the year digits are greater than 36. case year_digits when 0..36 [0, 1, 2, 3] else # 37..99 [0, 1, 2, 3, 4, 9] end else # If 4, 5, 6, 7, 8 or 9 and the year digits are less than or equal to 36, you were born in 20XX. # 5, 6, 7 and 8 are not distributed to persons, with year digits from and including 37 to and including 57. case year_digits when 0..36 [4, 5, 6, 7, 8, 9] when 37..57 [5, 6, 7, 8] else raise ArgumentError, error_message end end end
Source
# File lib/faker/default/id_number.rb, line 331 def south_african_id_checksum_digit(id_number) value_parts = id_number.chars even_digits = value_parts .select .with_index { |_, i| (i + 1).even? } odd_digits_without_last_character = value_parts[0...-1] .select .with_index { |_, i| (i + 1).odd? } sum_of_odd_digits = odd_digits_without_last_character.map(&:to_i).reduce(:+) even_digits_times_two = (even_digits.join.to_i * 2).to_s sum_of_even_digits = even_digits_times_two.chars.map(&:to_i).reduce(:+) total_sum = sum_of_odd_digits + sum_of_even_digits ((10 - (total_sum % 10)) % 10).to_s end