All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jrimum.bopepo.campolivre.CLItauPadrao Maven / Gradle / Ivy

Go to download

This is a fork and merge from JRimum ( http://www.jrimum.org ), - Bopepo: https://github.com/jrimum/bopepo - Texgit: https://github.com/jrimum/texgit - Valia: https://github.com/jrimum/vallia - Utilix: https://github.com/jrimum/utilix - Domkee: https://github.com/jrimum/domkee For Brazillian Boleto Payment Method. So much thanks for original authors: Gilmar P. S. L, Misael Barreto and Rômulo Augusto.

The newest version!
/* 
 * Copyright 2008 JRimum Project
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at http://www.apache.org/licenses/LICENSE-2.0
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 * 
 * Created at: 16/04/2008 - 23:09:08
 *
 * ================================================================================
 *
 * Direitos autorais 2008 JRimum Project
 *
 * Licenciado sob a Licença Apache, Versão 2.0 ("LICENÇA"); você não pode 
 * usar esse arquivo exceto em conformidade com a esta LICENÇA. Você pode obter uma 
 * cópia desta LICENÇA em http://www.apache.org/licenses/LICENSE-2.0 A menos que 
 * haja exigência legal ou acordo por escrito, a distribuição de software sob esta 
 * LICENÇA se dará “COMO ESTÁ”, SEM GARANTIAS OU CONDIÇÕES DE QUALQUER TIPO, sejam 
 * expressas ou tácitas. Veja a LICENÇA para a redação específica a reger permissões 
 * e limitações sob esta LICENÇA.
 * 
 * Criado em: 16/04/2008 - 23:09:08
 * 
 */

package org.jrimum.bopepo.campolivre;

import java.util.Arrays;

import org.jrimum.domkee.banco.ContaBancaria;
import org.jrimum.domkee.banco.Titulo;
import org.jrimum.texgit.Fillers;
import org.jrimum.texgit.FixedField;
import org.jrimum.utilix.Exceptions;

/**
 * 
 * 
 * 

* Campo livre padrão do Banco Itaú *

* *

*

Layout do Banco Itaú para o campo livre PADRÃO

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
PosiçãoTamanhoPictureConteúdo
20 a 2239(03)Carteira
23 a 3089(08)Nosso número
31 a 3119(01)DAC [Agência /Conta/Carteira/Nosso Número]
32 a 3549(04)N.º da Agência cedente
36 a 4059(05)N.º da Conta Corrente
41 a 4119(01)DAC [Agência/Conta Corrente]
42 a 4439(03)Zeros
*

* * @author Rômulo Augusto * @author Misael Barreto * @author Fernando Martin * * @since 0.2 * * @version 0.2 */ class CLItauPadrao extends AbstractCLItau { /** * */ private static final long serialVersionUID = 1544486299245786533L; /** * Tamanho deste campo. Em outras palavras, é a quantidade de partes que * compõem este campo livre. */ private static final Integer FIELDS_LENGTH = 7; /** *

* Dado um título, cria o campo livre padrão do Banco Itaú. *

* @param titulo título com as informações para geração do campo livre */ public CLItauPadrao(Titulo titulo) { super(FIELDS_LENGTH); ContaBancaria conta = titulo.getContaBancaria(); this.add(new FixedField(conta.getCarteira().getCodigo(), 3, Fillers.ZERO_LEFT)); this.add(new FixedField(titulo.getNossoNumero(), 8, Fillers.ZERO_LEFT)); this.add(new FixedField(calculeDigitoDaPosicao31( conta.getAgencia().getCodigo(), conta.getNumeroDaConta().getCodigoDaConta(), conta.getCarteira().getCodigo(), titulo.getNossoNumero()), 1)); this.add(new FixedField(conta.getAgencia().getCodigo(), 4, Fillers.ZERO_LEFT)); this.add(new FixedField(conta.getNumeroDaConta().getCodigoDaConta(), 5, Fillers.ZERO_LEFT)); this.add(new FixedField(calculeDigitoDaPosicao41( conta.getAgencia().getCodigo(), conta.getNumeroDaConta().getCodigoDaConta()), 1)); this.add(new FixedField("000", 3)); } /** *

* Calcula o dígito verificador do campo 31 a partir do código da agência, * do código da conta, do código da carteira e do nosso número. *

*

* À exceção, estão as carteiras escriturais 104, 105, 112, 113, 114, 147, * 166 e 212 e na modalidade direta as carteiras 126, 131, 146, 150 * e 168, cuja obtenção está baseada apenas nos dados "CARTEIRA/NOSSO NÚMERO" * da operação. Fonte: * Manual ITAÚ, mais especificamente nas páginas 19 e 30. *

*

* Exemplo do cálculo: * *

	 * AG / CONTA = 0057 / 12345-7 CART / NNº = 110 / 12345678-?
	 * 
	 * Sequência para Cálculo 	0 0 5 7 1 2 3 4 5 1 1 0 1 2 3 4 5 6 7 8
	 * Módulo 10 		1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2
	 * 			| | | | | | | | | | | | | | | | | | | |___________8 x 2 = 16 (1+6)
	 * 			| | | | | | | | | | | | | | | | | | | ____________7 x 1 = 7
	 *			| | | | | | | | | | | | | | | | | | ______________6 x 2 = 12 (1+2)
	 * 			| | | | | | | | | | | | | | | | | ________________5 x 1 = 5
	 * 			| | | | | | | | | | | | | | | | | ________________4 x 2 = 8
	 *			| | | | | | | | | | | | | | | ____________________3 x 1 = 3
	 * 			| | | | | | | | | | | | | | ______________________2 x 2 = 4
	 * 			| | | | | | | | | | | | | ________________________1 x 1 = 1
	 * 			| | | | | | | | | | | | __________________________0 x 2 = 0
	 * 			| | | | | | | | | | | ____________________________1 x 1 = 1
	 * 			| | | | | | | | | | ______________________________1 x 2 = 2
	 * 			| | | | | | | | | ________________________________5 x 1 = 5
	 * 			| | | | | | | | __________________________________4 x 2 = 8
	 * 			| | | | | | | ____________________________________3 x 1 = 3
	 * 			| | | | | | ______________________________________2 x 2 = 4
	 * 			| | | | | ________________________________________1 x 1 = 1
	 * 			| | | | __________________________________________7 x 2 = 14 (1+4)
	 * 			| | | ____________________________________________5 x 1 = 5
	 * 			| | ______________________________________________0 x 2 = 0
	 * 			| ________________________________________________0 x 1 = 0
	 * 
	 * Total 								            72
	 * 
	 * Dividir o resultado da soma por 10 => 72 / 10 = 7, resto = 2
	 *  
	 * DAC = 10 - 2 = 8
	 * Portanto DAC = 8
	 * 
*

* * @param codigoDaAgencia * @param codigoDaConta * @param codigoDaCarteira * @param nossoNumero * @return Integer dígito * * @since 0.2 */ private Integer calculeDigitoDaPosicao31(Integer codigoDaAgencia, Integer codigoDaConta, Integer codigoDaCarteira, String nossoNumero) { // Carteiras "exceção". Integer[] carteirasEscriturais = {104, 105, 112, 113, 114, 147, 166, 212}; Integer[] carteirasModalidadeDireta = {126, 131, 146, 150, 168}; StringBuilder campo = new StringBuilder(); campo.append(Fillers.ZERO_LEFT.fill(codigoDaCarteira.intValue(), 3)); campo.append(Fillers.ZERO_LEFT.fill(nossoNumero, 8)); /* * Se a carteira em questão não estiver nas lista de exceções então * acrescenta-se a agência e a conta para compor a base para o cálculo * do DAC. */ if (Arrays.binarySearch(carteirasModalidadeDireta, codigoDaCarteira) < 0 && Arrays.binarySearch(carteirasEscriturais, codigoDaCarteira) < 0) { campo.insert(0, Fillers.ZERO_LEFT.fill(codigoDaConta.intValue(), 5)); campo.insert(0, Fillers.ZERO_LEFT.fill(codigoDaAgencia.intValue(), 4)); } return calculeDigitoVerificador(campo.toString()); } /** *

* Calcula o dígito verificador do campo 41 a partir do código da agência e * do código da conta. *

*

* O cálculo é feito da seguinte forma: *

    *
  1. * Multiplica-se cada algarismo do campo pela sequência de multiplicadores * 2, 1, 2, 1, 2, 1..., posicionados da direita para a esquerda; *
  2. *
  3. * Some individualmente, os algarismos dos resultados dos produtos, obtendo-se o total (N); *
  4. *
  5. * Divida o total encontrado (N) por 10, e determine o resto da divisão como MOD 10 (N); *
  6. *
  7. * Encontre o DAC através da seguinte expressão: DAC = 10 – Mod 10 (N) * * OBS.: Se o resultado da etapa d for 10, considere o DAC = 0. *
  8. *
* *

* * @param codigoDaAgencia * @param codigoDaConta * @return Integer digito * * @since 0.2 */ private Integer calculeDigitoDaPosicao41(Integer codigoDaAgencia, Integer codigoDaConta) { StringBuilder campo = new StringBuilder(); campo.append(Fillers.ZERO_LEFT.fill(codigoDaAgencia.intValue(), 4)); campo.append(Fillers.ZERO_LEFT.fill(codigoDaConta.intValue(), 5)); return calculeDigitoVerificador(campo.toString()); } @Override protected void addFields(Titulo titulo) { // TODO IMPLEMENTAR Exceptions.throwUnsupportedOperationException("AINDA NÃO IMPLEMENTADO!"); } @Override protected void checkValues(Titulo titulo) { // TODO IMPLEMENTAR Exceptions.throwUnsupportedOperationException("AINDA NÃO IMPLEMENTADO!"); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy