-
Notifications
You must be signed in to change notification settings - Fork 200
Criando um arquivo de remessa
Vitor de Oliveira Carvalho edited this page Apr 26, 2017
·
7 revisions
Um detalhe é um boleto, mas você pode ter diversas ações para este boleto, por exemplo:
- Entrada de Título (Envia o boleto para o banco)
- Pedido de Baixa (Significa que o cliente pagou a dívida diretamente a você, portanto o banco pode descartar o registro deste boleto)
- Protestar (Protesta o boleto manualmente)
- Diversas outras opções estão disponíveis na documentação que o banco oferece.
Esta opção não é necessária para boletos sem registros, porém enviando para o banco você pode:
- Disponibilizar o pagamento do boleto atráves do DDA (Débito Direto Autorizado)
- Solicitar a impressão e envio do mesmo para o cliente pelo banco
- Protestar o boleto vencido
- Outras opções de acordo com o seu banco.
composer require andersondanilo/cnab_php
Para instalar a biblioteca você vai ter que ter instalado no seu computador o composer, o que é o composer? consulte em: https://getcomposer.org/doc/00-intro.md
Agora você vai ter que usar, após instalar segundo as instruções no site, execute o seguinte comando:
Obs: dependendo da sua instalação você vai ter que chamar "composer.phar" ao invés de "composer".
Se você não usava composer, você vai observar que foram criados os seguintes arquivos.
- vendor (guarda todas as suas bibliotecas do composer)
- composer.json (especifica quais bibliotecas o seu sistema usa)
Você terá que incluir o autoload no seu projeto, como no exemplo abaixo
criar_remessa.php
include 'vendor/autoload.php';
$codigo_banco = Cnab\Banco::ITAU;
$arquivo = new Cnab\Remessa\Cnab400\Arquivo($codigo_banco);
$arquivo->configure(array(
'data_geracao' => new DateTime(),
'data_gravacao' => new DateTime(),
'nome_fantasia' => 'Nome Fantasia da sua empresa', // seu nome de empresa
'razao_social' => 'Razão social da sua empresa', // sua razão social
'cnpj' => '111', // seu cnpj completo
'banco' => $codigo_banco, //código do banco
'logradouro' => 'Logradouro da Sua empresa',
'numero' => 'Número do endereço',
'bairro' => 'Bairro da sua empresa',
'cidade' => 'Cidade da sua empresa',
'uf' => 'Sigla da cidade, ex SP',
'cep' => 'CEP do endereço da sua cidade',
'agencia' => '1111',
'conta' => '22222', // número da conta
'conta_dac' => '2', // digito da conta
));
// você pode adicionar vários boletos em uma remessa
$arquivo->insertDetalhe(array(
'codigo_de_ocorrencia' => 1, // 1 = Entrada de título, futuramente poderemos ter uma constante
'nosso_numero' => '1234567',
'numero_documento' => '1234567',
'carteira' => '109',
'especie' => Cnab\Especie::ITAU_DUPLICATA_DE_SERVICO, // Você pode consultar as especies Cnab\Especie
'valor' => 100.39, // Valor do boleto
'instrucao1' => 2, // 1 = Protestar com (Prazo) dias, 2 = Devolver após (Prazo) dias, futuramente poderemos ter uma constante
'instrucao2' => 0, // preenchido com zeros
'sacado_nome' => 'Nome do cliente', // O Sacado é o cliente, preste atenção nos campos abaixo
'sacado_tipo' => 'cpf', //campo fixo, escreva 'cpf' (sim as letras cpf) se for pessoa fisica, cnpj se for pessoa juridica
'sacado_cpf' => '111.111.111-11',
'sacado_logradouro' => 'Logradouro do cliente',
'sacado_bairro' => 'Bairro do cliente',
'sacado_cep' => '11111222', // sem hífem
'sacado_cidade' => 'Cidade do cliente',
'sacado_uf' => 'SP',
'data_vencimento' => new DateTime('2014-06-08'),
'data_cadastro' => new DateTime('2014-06-01'),
'juros_de_um_dia' => 0.10, // Valor do juros de 1 dia'
'data_desconto' => new DateTime('2014-06-01'),
'valor_desconto' => 10.0, // Valor do desconto
'prazo' => 10, // prazo de dias para o cliente pagar após o vencimento
'taxa_de_permanencia' => '0', //00 = Acata Comissão por Dia (recomendável), 51 Acata Condições de Cadastramento na CAIXA
'mensagem' => 'Descrição do boleto',
'data_multa' => new DateTime('2014-06-09'), // data da multa
'valor_multa' => 10.0, // valor da multa
));
// para salvar
$arquivo->save('meunomedearquivo.txt');