# -*- encoding: utf-8 -*- # module Bbrcobranca module Boleto class Hsbc < Base # Banco HSBC validates_inclusion_of :carteira, in: %w(CNR CSB), message: 'não existente para este banco.' validates_length_of :agencia, maximum: 4, message: 'deve ser menor ou igual a 4 dígitos.' validates_length_of :nosso_numero, maximum: 13, message: 'deve ser menor ou igual a 13 dígitos.' validates_length_of :conta_corrente, maximum: 7, message: 'deve ser menor ou igual a 7 dígitos.' # Nova instancia do Hsbc # @param (see Bbrcobranca::Boleto::Base#initialize) def initialize(campos = {}) campos = { carteira: 'CNR' }.merge!(campos) super(campos) end # Codigo do banco emissor (3 dígitos sempre) # # @return [String] 3 caracteres numéricos. def banco '399' end # Número seqüencial utilizado para identificar o boleto. # @return [String] 13 caracteres numéricos. def nosso_numero=(valor) @nosso_numero = valor.to_s.rjust(13, '0') if valor end # Nosso número para exibir no boleto. # @return [String] # @example # boleto.nosso_numero_boleto #=> "0000000004042847" def nosso_numero_boleto case carteira when 'CNR' then if data_vencimento.is_a?(Date) self.codigo_servico = '4' dia = data_vencimento.day.to_s.rjust(2, '0') mes = data_vencimento.month.to_s.rjust(2, '0') ano = data_vencimento.year.to_s[2..3] data = "#{dia}#{mes}#{ano}" parte_1 = "#{nosso_numero}#{nosso_numero.modulo11(mapeamento: { 10 => 0 })}#{codigo_servico}" soma = parte_1.to_i + conta_corrente.to_i + data.to_i "#{parte_1}#{soma.to_s.modulo11(mapeamento: { 10 => 0 })}" else errors.add(:data_vencimento, 'não é uma data.') raise Bbrcobranca::BoletoInvalido, self end when 'CSB' @nosso_numero else raise Bbrcobranca::NaoImplementado, 'Tipo de carteira não implementado.' # TODO - Verificar outras carteiras. # self.codigo_servico = "5" # parte_1 = "#{self.nosso_numero}#{self.nosso_numero.modulo11(mapeamento: { 10 => 0 })}#{self.codigo_servico}" # soma = parte_1.to_i + self.conta_corrente.to_i # numero = "#{parte_1}#{soma.to_s.modulo11(mapeamento: { 10 => 0 })}" # numero end end # Número do convênio/contrato do cliente para exibir no boleto. # @return [String] # @example # boleto.agencia_conta_boleto #=> "0061900" def agencia_conta_boleto conta_corrente end # Segunda parte do código de barras. # # Montagem é baseada no tipo de carteira e na presença da data de vencimento
# OBS: Somente as carteiras CNR/CSB estão implementadas.
# # @return [String] 25 caracteres numéricos. # @raise [Bbrcobranca::NaoImplementado] Caso a carteira informada não for CNR/CSB. def codigo_barras_segunda_parte case carteira when 'CNR' dias_julianos = data_vencimento.to_juliano "#{conta_corrente}#{nosso_numero}#{dias_julianos}2" when 'CSB' raise Bbrcobranca::NaoImplementado, 'Nosso número não definido.' unless @nosso_numero "#{nosso_numero}#{agencia}#{conta_corrente}001" else raise Bbrcobranca::NaoImplementado, 'Tipo de carteira não implementado.' end end end end end