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

org.jrimum.domkee.banco.Agencia 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: 30/03/2008 - 18:57:33
 * 
 * ================================================================================
 * 
 * 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: 30/03/2008 - 18:57:33
 * 
 */
package org.jrimum.domkee.banco;

import static org.apache.commons.lang3.StringUtils.EMPTY;

import org.apache.commons.lang3.StringUtils;
import org.jrimum.utilix.Exceptions;
import org.jrimum.utilix.Objects;

/**
 * 

* Esta classe segue o padrão especificado pela FEBRABAN: *
* Invariantes: *

    *
  • Código: deve ser um inteiro natural (incluindo zero) entre 1 e 5 * dígitos
  • *
  • Dígito Verificador: alpha-numérico sendo um inteiro natural (incluindo * zero) ou caracter não vazio (' ') com um dígito.
  • *
*

* * @author Gilmar P.S.L. * @author Rômulo Augusto * @author Misael Barreto * @author Samuel Valério * * @since 0.2 * * @version 0.2 */ public class Agencia implements org.jrimum.domkee.banco.IAgencia { private final Integer codigo; private final String digitoVerificador; public Agencia(Integer codigo) { this.codigo = codigo; verifyCodigo(); this.digitoVerificador = EMPTY; } public Agencia(Integer codigo, String digito) { this.codigo = codigo; verifyCodigo(); this.digitoVerificador = digito; verifyDv(); } public void verifyCodigo() { if (codigo < 0) { Exceptions.throwIllegalArgumentException("O código da agência deve ser um inteiro natural (incluindo zero)"); } if (String.valueOf(codigo).length() > 5) { Exceptions.throwIllegalArgumentException("O código da agência deve possuir de 1 a 5 dígitos"); } } public void verifyDv() { if (StringUtils.isBlank(digitoVerificador)) { Exceptions.throwIllegalArgumentException("O dígito verificador da agência não pode ser null ou apenas espaços em branco"); } if (digitoVerificador.length() > 1) { Exceptions.throwIllegalArgumentException("O dígito verificador da agência deve possuir apenas um dígito"); } if (!StringUtils.isAlphanumeric(digitoVerificador)) { Exceptions.throwIllegalArgumentException("O dígito verificador da agência deve ser letra ou dígito"); } } public Integer getCodigo() { return codigo; } public String getDigitoVerificador() { return digitoVerificador; } @Override public String toString() { return Objects.toString(this); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy