fhferreira/sicoob-boleto

There is no license information available for the latest version (v1.3) of this package.

Projeto para criar arquivos de remessas e processar arquivos de retorno no formato CNAB

v1.3 2020-05-20 17:05 UTC

This package is auto-updated.

Last update: 2025-01-08 05:02:18 UTC


README

Build Status

##Proposta: ###Geração de Arquivos de Remessa CNAB 240/400 Sicoob/Cred-Acif

//Laravel
use File;
use Exception;
use Sicoob\Remessa\CNAB240\Arquivo;
use Sicoob\Remessa\CNAB240\Boleto;

class BoletoService {
   
   public function geraArquivo($boletos, $mes, $ano)
    {
        $directory = "remessa/$mes/$ano";

        $path = public_path($directory);

        if (!$boletos) {
          throw new Exception("Não há boletos para geração do arquivo.");
        }

        if (!File::isDirectory($path)) {
            $result = File::makeDirectory($path, 0775, true);
        }

        $emissao = date('dmY');
        $hora = date('Hsi');
        //Lote fixo ou realize o registro no banco de dados e torne-o incremental.
        $lote = 1;
        $inscricao = 2;
        //CNPJ do CEDENTE
        $numero_inscricao = '00000000000000';
        //RAZAO SOCIAL CEDENTE
        $nome_empresa = 'DA HADOUKEN RYU LTDA';
        $agencia_cooperativa = 1234;
        $dv_prefixo = 1;
        $conta_corrente = 123;
        $dv_conta_corrente = 4;

        $arquivo = new Arquivo();
        $arquivo->fill([
            'lote' => $lote,
            'header' => [
                'inscricao' => $inscricao,
                'numero_inscricao' => $numero_inscricao,
                'nome_empresa' => $nome_empresa,
                'agencia_cooperativa' => $agencia_cooperativa,
                'dv_prefixo' => $dv_prefixo,
                'conta_corrente' => $conta_corrente,
                'dv_conta_corrente' => $dv_conta_corrente,
                'data_geracao' => $emissao,
                'hora_geracao' => $hora,
            ],
            'header_lote' => [
                'inscricao' => $inscricao,
                'numero_inscricao' => $numero_inscricao,
                'nome_empresa' => $nome_empresa,
                'agencia_cooperativa' => $agencia_cooperativa,
                'dv_prefixo' => $dv_prefixo,
                'conta_corrente' => $conta_corrente,
                'dv_conta_corrente' => $dv_conta_corrente,
                'data_gravacao' => $emissao,
            ]
        ]);

        $countBoleto=0;
        foreach ($boletos as $countBoleto => $boletoArr) {

            $dtVencimento = date('dmY', strtotime($boletoArr->dtVencimento));
            $emissao = date('dmY');
            $hora = date('His');

            $valor_boleto = $boletoArr->totalAPagar;
            $nosso_numero = '000000000001011     ';
            $numero_documento = str_pad($boletoArr->registro . $boletoArr->nr_pessoa_fisica_id, 
            15, 
            '0', 
            STR_PAD_RIGHT);
            $message3 = "Mensagem 3";
            $message4 = "Mensagem 4";

            $tamanho = 40;
            $endereco = $boletoArr->endereco;
            /*
            Caso o endereço seja maior que o tamanho necessário, 
            localiza o "Número do endereço" na string e ajusta a string com o numero cortando
            Somente a parte descritiva
            para que o endereço caiba no espaço e seja localizável.
            */
            if (strlen($endereco) > $tamanho) {
                preg_match('/^([^\d]*[^\d\s]) *(\d.*)$/', $endereco, $match);
                $end1 = "";
                if(isset($match[1])) {
                    $end1 = substr($match[1], 0, 40 - (strlen($match[2]) + 1));
                    $endereco = sprintf("%s,%s", $end1, $match[2]);
                } else {
                    $endereco = substr($endereco, 0, 40);
                }
            }

            $Boleto = new Boleto();
            $Boleto->fill([
                'valor' => $valor_boleto,
                'lote' => $lote,
                'count' => ($countBoleto + 1),
                'segmentP' => [
                    'num_cc_agencia_codigo' => $agencia_cooperativa,
                    'digito_verificador' => $dv_prefixo,
                    'conta_corrente' => $conta_corrente,
                    'conta_corrente_dv' => $dv_conta_corrente,
                    'nosso_numero' => $nosso_numero,
                    'carteira' => '1',
                    'numero_documento' => $numero_documento,
                    'data_vencimento' => $dtVencimento,
                    'data_emissao' => $emissao,
                    'data_juros_mora' => $dtVencimento,
                ],
                'segmentQ' => [
                    'tipo_inscricao_pagador' => $boletoArr->tipo_inscricao_pagador,
                    'numero_inscricao' => $boletoArr->numero_inscricao,
                    'nome' =>  $boletoArr->nome,
                    'endereco' =>  $endereco,
                    'bairro' =>  $boletoArr->bairro,
                    'CEP' =>  $boletoArr->cep,
                    'sufixo_CEP' =>  $boletoArr->sufixo_cep,
                    'cidade' =>  $boletoArr->cidade,
                    'uf' =>  $boletoArr->uf,
                ],
                //É necessário verificar a ordem das mensagens e quais são as que sobrescrevem outras.
                'segmentR' => [
                    'informacao_3' => $message3,
                    'informacao_4' => $message4,
                ],
                'segmentS' => [
                    'informacao_5' => $message3,
                    'informacao_6' => $message4,
                    'informacao_7' => "Mensagem 7",
                    'informacao_8' => "Mensagem 8",
                    'informacao_9' => "Mensagem 9",
                ]
            ]);

            $arquivo->addBoleto($Boleto);
        }
        
        $filename = '/remessa.' . $mes . '-' . $ano . "-" . ($countBoleto + 1) . '-boletos.rem';
        $path = $path . $filename;
        $arquivo->render(false, $path, true);
        return $directory . $filename;
    }

}

###Leitura de Arquivos de Retorno CNAB 240/400 Sicoob/Cred-Acif

//Laravel
use Illuminate\Http\Request;
class BoletoService {

    public function postBaixar(Request $request)
    {

        if (!$request->hasFile('arquivo')) {
            return "Arquivo não importado/enviado.";
        }

        $files = $request->file('arquivo');

        $boletos = [];
        foreach ($files as $file):
            $path = public_path("/retorno");
            $filename = $file->getClientOriginalName();
            $file->move($path, $filename);
            $arquivoObj = new \Sicoob\Retorno\CNAB240\Arquivo($path . '/' . $filename);
            foreach($arquivoObj->boletos as $boleto) {
                $boleto->codigoMov = $boleto->segmentT->fields['codigo_movimento_retorno']->value;
                $boleto->numeroInscricao = $boleto->segmentT->fields['numero_inscricao']->value;
                $boleto->vencimento = $boleto->segmentT->fields['data_vencimento']->value;
                //Busca o boleto registrado no banco de dados
                $boletoDB = \App\Core\Helpers\Boleto::get($boleto->numeroInscricao, $boleto->vencimento);
                $boleto->boletoDB = $boletoDB;
                $verifica = null;
                if ($boletoDB) {
                    //Verifica e realiza a baixa/liquidação ou mudança de status
                    $verifica = \App\Core\Helpers\Boleto::verifica($boleto, $boleto->codigoMov);
                } else {
                    $verifica = [
                      'status' => false,
                      'status_msg' => "Boleto não encontrado"
                    ];
                }
                $boleto->verifica = $verifica;
                array_push($boletos, $boleto);
            }
        endforeach;

        return $boletos;
    }
}