This repository has been archived by the owner on Jun 8, 2022. It is now read-only.
forked from manoelcampos/retorno-boletophp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRetornoCNAB400Conv7.php
95 lines (87 loc) · 5.02 KB
/
RetornoCNAB400Conv7.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
require_once("RetornoCNAB400Base.php");
/**Classe para leitura de arquivos de retorno de cobranças no padrão CNAB400/CBR643 com convênio de 7 posições.<br/>
* Layout Padrão CNAB/Febraban 400 posições<br/>.
* Baseado na documentação para "Layout de Arquivo Retorno para convênios na
faixa numérica entre 1.000.000 a 9.999.999 (Convênios de 7 posições). Versão Set/09"
* do Banco do Brasil (arquivo Doc2628CBR643Pos7.pdf),
* disponível em http://www.bb.com.br/docs/pub/emp/empl/dwn/Doc2628CBR643Pos7.pdf
* @copyright GPLv2
* @package ArquivoRetornoTitulosBancarios
* @author Manoel Campos da Silva Filho. http://manoelcampos.com/contato
* @version 0.4
*/
class RetornoCNAB400Conv7 extends RetornoCNAB400Base {
/**@property int DETALHE Define o valor que identifica uma coluna do tipo DETALHE*/
const DETALHE = 7;
public function __construct($nomeArquivo=NULL, $aoProcessarLinhaFunctionName=""){
parent::__construct($nomeArquivo, $aoProcessarLinhaFunctionName);
}
/**Processa a linha header do arquivo
* @param string $linha Linha do header de arquivo processado
* @return array<mixed> Retorna um vetor contendo os dados dos campos do header do arquivo.*/
protected function processarHeaderArquivo($linha) {
$vlinha = parent::processarHeaderArquivo($linha);
//X = ALFANUMÉRICO 9 = NUMÉRICO V = VÍRGULA DECIMAL ASSUMIDA
//$vlinha["zeros"] = substr($linha, 41, 6); //Zeros
$vlinha["complemento2"] = substr($linha, 108, 42); //Complemento do Registro: “Brancos”
$vlinha["convenio"] = substr($linha, 150, 7); //9 Número do convênio
$vlinha["complemento3"] = substr($linha, 157, 238); //X Complemento do Registro: “Brancos”
return $vlinha;
}
/**Processa uma linha detalhe do arquivo.
* @param string $linha Linha detalhe do arquivo processado
* @return array<mixed> Retorna um vetor contendo os dados dos campos da linha detalhe.*/
protected function processarDetalhe($linha) {
$vlinha = parent::processarDetalhe($linha);
//X = ALFANUMÉRICO 9 = NUMÉRICO V = VÍRGULA DECIMAL ASSUMIDA
$vlinha["convenio"] = substr($linha, 32, 7); //9 Número do Convênio de Cobrança do Cedente
$vlinha["controle"] = substr($linha, 39, 25); //X Número de Controle do Participante
$vlinha["nosso_numero"] = substr($linha, 64, 17); //9 Nosso-Número
$vlinha["tipo_cobranca"] = substr($linha, 81, 1); //9 Tipo de cobrança - nota 02
$vlinha["tipo_cobranca_cmd72"] = substr($linha, 82, 1); //9 Tipo de cobrança específico p/ comando 72 - nota 03
$vlinha["dias_calculo"] = substr($linha, 83, 4); //9 Dias para cálculo - nota 04
$vlinha["natureza"] = substr($linha, 87, 2); //9 Natureza do recebimento - nota 05
$vlinha["prefixo_titulo"] = substr($linha, 89, 3); //X Prefixo do título
$vlinha["variacao_carteira"] = substr($linha, 92, 3); //9 Variação da Carteira
$vlinha["conta_caucao"] = substr($linha, 95, 1); //9 Conta Caução - nota 06
/*
$vlinha["brancos"] = substr($linha, 127, 20); //X Brancos
$vlinha["zeros3"] = substr($linha, 343, 7); //9 Zeros - nota 14
$vlinha["zeros4"] = substr($linha, 350, 9); //9 Zeros - nota 14
$vlinha["zeros5"] = substr($linha, 359, 7); //9 Zeros - nota 14
$vlinha["zeros6"] = substr($linha, 366, 9); //9 Zeros - nota 14
$vlinha["zeros7"] = substr($linha, 375, 7); //9 Zeros - nota 14
$vlinha["zeros8"] = substr($linha, 382, 9); //9 Zeros - nota 14
$vlinha["brancos3"] = substr($linha, 391, 2); //X Brancos
*/
return $vlinha;
}
/**Processa uma linha do arquivo de retorno.
* @param int $numLn Número_linha a ser processada
* @param string $linha String contendo a linha a ser processada
* @return array Retorna um vetor associativo contendo os valores_linha processada.*/
public function processarLinha($numLn, $linha) {
$tamLinha = 400; //total de caracteres das linhas do arquivo
//o +2 é utilizado para contar o \r\n no final da linha
if(strlen($linha)!=$tamLinha and strlen($linha)!=$tamLinha+2)
die("A linha $numLn não tem $tamLinha posições. Possui " . strlen($linha));
if(trim($linha)=="")
die("A linha $numLn está vazia.");
//é adicionado um espaço vazio no início_linha para que
//possamos trabalhar com índices iniciando_1, no lugar_zero,
//e assim, ter os valores_posição_campos exatamente
//como no manual CNAB400
$linha = " $linha";
$tipoLn = substr($linha, 1, 1);
if($tipoLn == RetornoCNAB400Conv7::HEADER_ARQUIVO)
$vlinha = $this->processarHeaderArquivo($linha);
else if($tipoLn == RetornoCNAB400Conv7::DETALHE)
$vlinha = $this->processarDetalhe($linha);
else if($tipoLn == RetornoCNAB400Conv7::TRAILER_ARQUIVO)
$vlinha = $this->processarTrailerArquivo($linha);
else $vlinha = NULL;
return $vlinha;
}
}
?>