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

br.com.caelum.stella.boleto.bancos.CodigoDeBarrasBuilder Maven / Gradle / Ivy

package br.com.caelum.stella.boleto.bancos;

import br.com.caelum.stella.boleto.Banco;
import br.com.caelum.stella.boleto.Boleto;
import br.com.caelum.stella.boleto.exception.CriacaoBoletoException;

/**
 * Um Builder para construção do código de barra dos boletos. 
 * 
 * @author Rodrigo Turini
 */
class CodigoDeBarrasBuilder {
	
	private StringBuilder codigoDeBarras;
	private Banco banco;

	/**
	 * Cria um CodigoDeBarrasBuilder com os primeiros 18 digitos 
	 * preenchidos de acordo com as normas da carta circular 2926 
	 * do banco central do Brasil. O documento está disponível 
	 * para consulta em br.com.caelum.stella.boleto.doc.
	 * 
	 * @param boleto para o qual será gerado o código de barras.
	 */
	CodigoDeBarrasBuilder(Boleto boleto) {
		this.banco = boleto.getBanco();
		this.codigoDeBarras = new StringBuilder(44);
		this.codigoDeBarras.append(banco.getNumeroFormatado());		
		int codigoEspecieMoeda = boleto.getCodigoEspecieMoeda();
		this.codigoDeBarras.append(String.valueOf(codigoEspecieMoeda));
		this.codigoDeBarras.append(boleto.getFatorVencimento());
		this.codigoDeBarras.append(boleto.getValorFormatado());
	}

	/**
	 * @param campoLivre preparado pelo banco de acordo com suas regras
	 * @return o código de barras já com o digito verificador geral.
	 * @throws CriacaoBoletoException se código tenha mais de 44 digitos.
	 */
	public String comCampoLivre(StringBuilder campoLivre) {
		this.codigoDeBarras.append(campoLivre);
		String trecho = this.codigoDeBarras.toString();
		int digito = banco.getGeradorDeDigito().geraDigitoMod11(trecho);
		this.codigoDeBarras.insert(4, digito);
		validaTamahoDoCodigoDeBarrasCompletoGerado();
		return this.codigoDeBarras.toString();
	}

	/**
	 * Já valida neste ponto para não ter que repetir esse código sempre
	 */
	private void validaTamahoDoCodigoDeBarrasCompletoGerado() {
		if (this.codigoDeBarras.toString().length() != 44) {
			throw new CriacaoBoletoException("Erro na geração do código " +
				"de barras. Número de digitos diferente de 44. Verifique " +
				"se todos os dados foram preenchidos corretamente.");
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy