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

org.jrimum.bopepo.campolivre.CLSicredi 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 2010 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: 15/01/2010 - 20:40:59
 *
 * ================================================================================
 *
 * Direitos autorais 2010 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: 15/01/2010 - 20:40:59
 * 
 */

package org.jrimum.bopepo.campolivre;

import static java.lang.String.format;
import static java.math.BigDecimal.ZERO;
import static org.jrimum.bopepo.parametro.ParametroBancoSicredi.POSTO_DA_AGENCIA;

import org.jrimum.domkee.banco.Titulo;
import org.jrimum.texgit.Fillers;
import org.jrimum.texgit.FixedField;
import org.jrimum.utilix.Objects;
import org.jrimum.vallia.Modulo;
import org.jrimum.vallia.TipoDeModulo;

/**
 * 

* O campo livre do banco Sicredi deve seguir esta forma: *

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
PosiçãoTamanhoPictureConteúdo (terminologia padrão)Conteúdo (terminologia do banco)
20-201tipo de cobrança: "1" ou "3"Código numérico correspondente ao tipo de cobrança: "1"- Com Registro ou "3"- Sem Registro
21-211Constante correspondente ao tipo de carteira: "1"- carteira simples. Embora no código fonte do manual mencione outras duas possibilidades "2"-Caucionada ou "3"-Descontada.Código númerico correspondente ao tipo de carteira: "1" - carteira simples
22-298Nosso Número (8)Nosso Número
30-301DV do Nosso Número (1)Dígito Verificador do Nosso Número
31-344Cooperativa de crédito / agência cedenteCooperativa de crédito / agência cedente
35-362Unidade de atendimento / posto da agênica cedenteUnidade de atendimento / posto da agênica cedente
37-415Código do CedenteCódigo do Cedente
42-421Filler: 1 (um) quando o campo "valor do documento" diferente de 0 (zero), caso contrário zero.1 (um) quando o campo "valor do documento" diferente de 0 (zero), caso contrário zero.
43-431Constante "0"- ZeroZero Fixo
44-441Dígito verificador do campo livre calculado por módulo 11 com aproveitamento total (resto igual a (0) zero ou (1) um o Dígito será (0) zero)Dígito verificador do campo livre calculado por módulo 11 com aproveitamento total (resto igual a (0) zero ou (1) um o Dígito será (0) zero)
* * @see org.jrimum.bopepo.campolivre.AbstractCampoLivre * * @author Gilmar P.S.L * * @since 0.2 * * @version 0.2 */ class CLSicredi extends AbstractCLSicredi { /** * {@code serialVersionUID = 7697120719706717353L} */ private static final long serialVersionUID = 7697120719706717353L; /** * Número de campos = 10. */ private static final Integer FIELDS_LENGTH = 10; /** * Código númerico correspondente ao tipo de cobrança: "1" - Com Registro. */ private static final String COBRANCA_COM_REGISTRO = "1"; /** * Código númerico correspondente ao tipo de cobrança: "3" - Sem Registro. */ private static final String COBRANCA_SEM_REGISTRO = "3"; /** * Valor constante do campo "Tipo da Carteira": "1" - carteira simples. */ private static final Integer CARTEIRA_SIMPLES_VALUE = Integer.valueOf(1); /** * Segunda posição do campo livre. */ private static final FixedField FIELD_CARTEIRA = new FixedField(CARTEIRA_SIMPLES_VALUE, 1); /** * Instância de módulo 11 para cálculo do DV do campo livre. */ private static final Modulo modulo11 = new Modulo(TipoDeModulo.MODULO11); /** * Cria um campo livre instanciando o número de fields ({@code FIELDS_LENGTH}) deste campo. * * @since 0.2 */ protected CLSicredi() { super(FIELDS_LENGTH); } /** * {@inheritDoc} * * @see org.jrimum.bopepo.campolivre.AbstractCampoLivre#checkValues(org.jrimum.domkee.financeiro.banco.febraban.Titulo) */ @Override protected void checkValues(Titulo titulo){ checkCarteiraNotNull(titulo); checkCodigoDaCarteira(titulo); checkCarteiraSimples(titulo); checkRegistroDaCarteiraNotNull(titulo); checkNossoNumero(titulo); checkTamanhoDoNossoNumero(titulo, NN8); checkDigitoDoNossoNumero(titulo); checkTamanhoDigitoDoNossoNumero(titulo, 1); checkCodigoDaAgencia(titulo); checkCodigoDaAgenciaMenorOuIgualQue(titulo, 99999); checkParametroBancario(titulo, POSTO_DA_AGENCIA); checkNumeroDaContaNotNull(titulo); checkCodigoDoNumeroDaConta(titulo); checkCodigoDoNumeroDaContaMenorOuIgualQue(titulo, 99999); checkValor(titulo); } /** * {@inheritDoc} * * @see org.jrimum.bopepo.campolivre.AbstractCampoLivre#addFields(org.jrimum.domkee.financeiro.banco.febraban.Titulo) */ @Override protected void addFields(Titulo titulo) { if(titulo.getContaBancaria().getCarteira().isComRegistro()){ this.add(new FixedField(COBRANCA_COM_REGISTRO, 1)); }else{ this.add(new FixedField(COBRANCA_SEM_REGISTRO, 1)); } this.add(FIELD_CARTEIRA); this.add(new FixedField(titulo.getNossoNumero(), 8, Fillers.ZERO_LEFT)); this.add(new FixedField(titulo.getDigitoDoNossoNumero(), 1, Fillers.ZERO_LEFT)); this.add(new FixedField(titulo.getContaBancaria().getAgencia().getCodigo(), 4, Fillers.ZERO_LEFT)); this.add(new FixedField(titulo.getParametrosBancarios().getValor(POSTO_DA_AGENCIA), 2, Fillers.ZERO_LEFT)); this.add(new FixedField(titulo.getContaBancaria().getNumeroDaConta().getCodigoDaConta(), 5, Fillers.ZERO_LEFT)); if (titulo.getValor().compareTo(ZERO) == 1) { this.add(new FixedField("1", 1)); } else { this.add(new FixedField("0", 1)); } this.add(new FixedField("0", 1)); this.add(new FixedField(calculeDigitoVerificador(), 1)); } /** * Verifica se o código da carteira da conta bancária do título é igual 1 * (carteira simples), caso contrário lança uma {@code * IllegalArgumentException}. * * @param titulo */ private void checkCarteiraSimples(Titulo titulo) { Objects.checkArgument( titulo.getContaBancaria().getCarteira().getCodigo().equals(CARTEIRA_SIMPLES_VALUE), format("Apenas a carteira de código [1] \"carteira simples\" é permitida e não o código [%s]!", titulo.getContaBancaria().getCarteira().getCodigo()) ); } /** * Calcula o dígito verificador deste campo livre (posição 25 do campo livre * 44 do código de barras) com módulo 11 a partir das 24 posições deste * campo livre. * * @return dígito verificador * * @since 0.2 */ private Integer calculeDigitoVerificador() { final int resto = modulo11.calcule(writeFields()); if (resto == 0 || resto == 1) { return Integer.valueOf(0); } else{ return Integer.valueOf(modulo11.valor() - resto); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy