Вход Регистрация
Файл: whmcs/modules/gateways/boleto/include/funcoes_nossacaixa.php
Строк: 407
<?php

if (!defined("WHMCS"))
    die(
"This file cannot be accessed directly");

// +----------------------------------------------------------------------+
// | BoletoPhp - Versгo Beta                                              |
// +----------------------------------------------------------------------+
// | Este arquivo estб disponнvel sob a Licenзa GPL disponнvel pela Web   |
// | em http://pt.wikipedia.org/wiki/GNU_General_Public_License           |
// | Vocк deve ter recebido uma cуpia da GNU Public License junto com     |
// | esse pacote; se nгo, escreva para:                                   |
// |                                                                      |
// | Free Software Foundation, Inc.                                       |
// | 59 Temple Place - Suite 330                                          |
// | Boston, MA 02111-1307, USA.                                          |
// +----------------------------------------------------------------------+

// +----------------------------------------------------------------------+
// | Originado do Projeto BBBoletoFree que tiveram colaboraзхes de Daniel |
// | William Schultz e Leandro Maniezo que por sua vez foi derivado do    |
// | PHPBoleto de Joгo Prado Maia e Pablo Martins F. Costa                 |
// |                                                                      |
// | Se vc quer colaborar, nos ajude a desenvolver p/ os demais bancos :-)|
// | Acesse o site do Projeto BoletoPhp: www.boletophp.com.br             |
// +----------------------------------------------------------------------+

// +----------------------------------------------------------------------+
// | Equipe Coordenaзгo Projeto BoletoPhp: <boletophp@boletophp.com.br>   |
// | Desenvolvimento Boleto NossaCaixa: Keitty Suйlen                      |
// +----------------------------------------------------------------------+

$codigobanco "151"//Cуdigo do banco de acordo com o banco central
$codigo_banco_com_dv geraCodigoBanco($codigobanco);
$nummoeda "9";
$fator_vencimento fator_vencimento($dadosboleto["data_vencimento"]);

//valor tem 10 digitos, sem virgula
$valor formata_numero($dadosboleto["valor_boleto"],10,0,"valor");
//agencia й 4 digitos
$agencia formata_numero($dadosboleto["agencia"],4,0);
//conta cedente (sem dv) й 6 digitos
$conta_cedente formata_numero($dadosboleto["conta_cedente"],6,0);
//dv da conta cedente
$conta_cedente_dv formata_numero($dadosboleto["conta_cedente_dv"],1,0);
//carteira 
$carteira $dadosboleto["carteira"];
//modalidade da conta
$modalidade formata_numero($dadosboleto["modalidade_conta"],2,0);

//Converte a modalidade de acordo com a tabela do banco
$modalidade == "01" $modalidade_c1 $modalidade_c1;
$modalidade == "04" $modalidade_c1 $modalidade_c1;
$modalidade == "09" $modalidade_c1 $modalidade_c1;
$modalidade == "13" $modalidade_c1 $modalidade_c1;
$modalidade == "16" $modalidade_c1 $modalidade_c1;
$modalidade == "17" $modalidade_c1 $modalidade_c1;
$modalidade == "18" $modalidade_c1 $modalidade_c1;


//nosso nъmero (sem dv) й 9 digitos
$nnum $dadosboleto["inicio_nosso_numero"] . formata_numero($dadosboleto["nosso_numero"],7,0);

//Agencia sem o digito + modalidade convertida e conta sem o dнgito
$ag_contacedente $agencia .$modalidade_c1$conta_cedente;

//
$carteira == $prefixo "9" $prefixo;
$carteira == $prefixo "0" $prefixo;

//Calcula o digito verificador do nosso nъmero
$dv_nosso_numero digitoVerificador_nossonumero($nnum,$conta_cedente,$conta_cedente_dv,$agencia,$modalidade);
$nossonumero_dv  "$nnum$dv_nosso_numero";

//pega o nosso numero a partir da 2є posiзгo
$nnum substr($nnum,1);

//numero para o calculo dos dнgitos verificadores da posiзгo 43 e 44
$calcdv1 $prefixo.$nnum.$ag_contacedente.$codigobanco;

//Gera os dнgitos verificadores da posiзгo 43 e 44
$dv1 geraDv43($calcdv1);
$dv2 geraDv44("$calcdv1$dv1");

//Se vier 2 caracteres significa que o dv2 deu 1 entгo o dv1 e o dv2 foi recalculado e retornado nesta string(Coisa do manual do banco =D !)
if (strlen($dv2) == 2){
    
$dv1substr($dv2,0,1);
    
$dv2substr($dv2,1,1);
}

// 43 numeros para o calculo do digito verificador do codigo de barras
$dv digitoVerificador_barra("$codigobanco$nummoeda$dv$fator_vencimento$valor$prefixo$nnum$ag_contacedente$codigobanco$dv1$dv2");

// Numero para o codigo de barras com 44 digitos
$linha "$codigobanco$nummoeda$dv$fator_vencimento$valor$prefixo$nnum$ag_contacedente$codigobanco$dv1$dv2";

$nossonumero substr($nossonumero_dv,0,9).'-'.substr($nossonumero_dv,9,1);
$agencia_codigo $agencia." / ".$modalidade." ".$conta_cedente ." "$conta_cedente_dv;

$dadosboleto["codigo_barras"]       = $linha;
$dadosboleto["linha_digitavel"]     = monta_linha_digitavel($linha);
$dadosboleto["agencia_codigo"]      = $agencia_codigo;
$dadosboleto["nosso_numero"]        = $nossonumero;
$dadosboleto["codigo_banco_com_dv"] = $codigo_banco_com_dv;

function 
digitoVerificador_nossonumero($numero$conta$dv$agencia$modalidade) {
    
$numext $agencia.$modalidade."0".$conta.$dv.$numero;
    
    for (
$i strlen($numext); $i 0$i--) {
        
$numeros[$i] = substr($numext,$i-1,1);
        if (
$i == 14){
            
$n 1;
        }
        else if(
$i == || $i == || $i == || $i == 13 || $i == 15 || $i == 19 || $i == 23){
            
$n 3;
        }
        else if(
$i == || $i == || $i == 10 || $i == 16 || $i == 20 ){
            
$n 1;
        }
        else if(
$i == || $i == || $i == 12 || $i == 18 || $i == 22 ){
            
$n 7;
        }
        else if(
$i == || $i == || $i == 11 || $i == 17 || $i == 21 ){
            
$n 9;
        }
        
$resul += $numeros[$i]*$n;
    }
        
    
$resto $resul 10;
    
$dv 10 $resto;
  if (
$resto == 0$dv=0;   
     return 
$dv;
}


function 
digitoVerificador_barra($numero) {
    
$resto2 modulo_11($numero91);
     if (
$resto2 == || $resto2 == || $resto2 == 10) {
        
$dv 1;
     } else {
        
$dv 11 $resto2;
     }
     return 
$dv;
}


// FUNЗХES
// Algumas foram retiradas do Projeto PhpBoleto e modificadas para atender as particularidades de cada banco

function formata_numero($numero,$loop,$insert,$tipo "geral") {
    if (
$tipo == "geral") {
        
$numero str_replace(",","",$numero);
        while(
strlen($numero)<$loop){
            
$numero $insert $numero;
        }
    }
    if (
$tipo == "valor") {
        
/*
        retira as virgulas
        formata o numero
        preenche com zeros
        */
        
$numero str_replace(",","",$numero);
        while(
strlen($numero)<$loop){
            
$numero $insert $numero;
        }
    }
    if (
$tipo "convenio") {
        while(
strlen($numero)<$loop){
            
$numero $numero $insert;
        }
    }
    return 
$numero;
}


function 
fbarcode($valor){

$fino ;
$largo ;
$altura 50 ;

  
$barcodes[0] = "00110" ;
  
$barcodes[1] = "10001" ;
  
$barcodes[2] = "01001" ;
  
$barcodes[3] = "11000" ;
  
$barcodes[4] = "00101" ;
  
$barcodes[5] = "10100" ;
  
$barcodes[6] = "01100" ;
  
$barcodes[7] = "00011" ;
  
$barcodes[8] = "10010" ;
  
$barcodes[9] = "01010" ;
  for(
$f1=9;$f1>=0;$f1--){ 
    for(
$f2=9;$f2>=0;$f2--){  
      
$f = ($f1 10) + $f2 ;
      
$texto "" ;
      for(
$i=1;$i<6;$i++){ 
        
$texto .=  substr($barcodes[$f1],($i-1),1) . substr($barcodes[$f2],($i-1),1);
      }
      
$barcodes[$f] = $texto;
    }
  }


//Desenho da barra


//Guarda inicial
?><img src=imagens/p.gif width=<?=$fino?> height=<?=$altura?> border=0><img
src=imagens/b.gif width=<?=$fino?> height=<?=$altura?> border=0><img
src=imagens/p.gif width=<?=$fino?> height=<?=$altura?> border=0><img
src=imagens/b.gif width=<?=$fino?> height=<?=$altura?> border=0><img
<?php
$texto 
$valor ;
if((
strlen($texto) % 2) <> 0){
    
$texto "0" $texto;
}

// Draw dos dados
while (strlen($texto) > 0) {
  
$i round(esquerda($texto,2));
  
$texto direita($texto,strlen($texto)-2);
  
$f $barcodes[$i];
  for(
$i=1;$i<11;$i+=2){
    if (
substr($f,($i-1),1) == "0") {
      
$f1 $fino ;
    }else{
      
$f1 $largo ;
    }
?>
    src=imagens/p.gif width=<?=$f1?> height=<?=$altura?> border=0><img
<?php
    
if (substr($f,$i,1) == "0") {
      
$f2 $fino ;
    }else{
      
$f2 $largo ;
    }
?>
    src=imagens/b.gif width=<?=$f2?> height=<?=$altura?> border=0><img
<?php
  
}
}

// Draw guarda final
?>
src=imagens/p.gif width=<?=$largo?> height=<?=$altura?> border=0><img
src=imagens/b.gif width=<?=$fino?> height=<?=$altura?> border=0><img
src=imagens/p.gif width=<?=1?> height=<?=$altura?> border=0>
  <?php
//Fim da funзгo

function esquerda($entra,$comp){
    return 
substr($entra,0,$comp);
}

function 
direita($entra,$comp){
    return 
substr($entra,strlen($entra)-$comp,$comp);
}

function 
fator_vencimento($data) {
    
$data split("/",$data);
    
$ano $data[2];
    
$mes $data[1];
    
$dia $data[0];
    return(
abs((_dateToDays("1997","10","07")) - (_dateToDays($ano$mes$dia))));
}

function 
_dateToDays($year,$month,$day) {
    
$century substr($year02);
    
$year substr($year22);
    if (
$month 2) {
        
$month -= 3;
    } else {
        
$month += 9;
        if (
$year) {
            
$year--;
        } else {
            
$year 99;
            
$century --;
        }
    }
    return ( 
floor((  146097 $century)    /  ) +
            
floor(( 1461 $year)        /  ) +
            
floor(( 153 $month +  2) /  ) +
                
$day +  1721119);
}

function 
modulo_10($num) { 
        
$numtotal10 0;
        
$fator 2;

        
// Separacao dos numeros
        
for ($i strlen($num); $i 0$i--) {
            
// pega cada numero isoladamente
            
$numeros[$i] = substr($num,$i-1,1);
            
// Efetua multiplicacao do numero pelo (falor 10)
            // 2002-07-07 01:33:34 Macete para adequar ao Mod10 do Itaъ
            
$temp $numeros[$i] * $fator
            
$temp0=0;
            foreach (
preg_split('//',$temp,-1,PREG_SPLIT_NO_EMPTY) as $k=>$v){ $temp0+=$v; }
            
$parcial10[$i] = $temp0//$numeros[$i] * $fator;
            // monta sequencia para soma dos digitos no (modulo 10)
            
$numtotal10 += $parcial10[$i];
            if (
$fator == 2) {
                
$fator 1;
            } else {
                
$fator 2// intercala fator de multiplicacao (modulo 10)
            
}
        }
        
        
// vбrias linhas removidas, vide funзгo original
        // Calculo do modulo 10
        
$resto $numtotal10 10;
        
$digito 10 $resto;
        if (
$resto == 0) {
            
$digito 0;
        }
        
        return 
$digito;
        
}

function 
modulo_11($num$base=9$r=0)  {
    
/**
     *   Autor:
     *           Pablo Costa <pablo@users.sourceforge.net>
     *
     *   Funзгo:
     *    Calculo do Modulo 11 para geracao do digito verificador 
     *    de boletos bancarios conforme documentos obtidos 
     *    da Febraban - www.febraban.org.br 
     *
     *   Entrada:
     *     $num: string numйrica para a qual se deseja calcularo digito verificador;
     *     $base: valor maximo de multiplicacao [2-$base]
     *     $r: quando especificado um devolve somente o resto
     *
     *   Saнda:
     *     Retorna o Digito verificador.
     *
     *   Observaзхes:
     *     - Script desenvolvido sem nenhum reaproveitamento de cуdigo prй existente.
     *     - Assume-se que a verificaзгo do formato das variбveis de entrada й feita antes da execuзгo deste script.
     */                                        

    
$soma 0;
    
$fator 2;

    
/* Separacao dos numeros */
    
for ($i strlen($num); $i 0$i--) {
        
// pega cada numero isoladamente
        
$numeros[$i] = substr($num,$i-1,1);
        
// Efetua multiplicacao do numero pelo falor
        
$parcial[$i] = $numeros[$i] * $fator;
        
// Soma dos digitos
        
$soma += $parcial[$i];
        if (
$fator == $base) {
            
// restaura fator de multiplicacao para 2 
            
$fator 1;
        }
        
$fator++;
    }

    
/* Calculo do modulo 11 */
    
if ($r == 0) {
        
$soma *= 10;
        
$digito $soma 11;
        if (
$digito == 10) {
            
$digito 0;
        }
        return 
$digito;
    } elseif (
$r == 1){
        
$resto $soma 11;
        return 
$resto;
    }
}

function 
monta_linha_digitavel($codigo) {
        
        
// Posiзгo    Conteъdo
        // 1 a 3    Nъmero do banco
        // 4        Cуdigo da Moeda - 9 para Real
        // 5        Digito verificador do Cуdigo de Barras
        // 6 a 9   Fator de Vencimento
        // 10 a 19 Valor (8 inteiros e 2 decimais)
        // 20 a 44 Campo Livre definido por cada banco (25 caracteres)

        // 1. Campo - composto pelo cуdigo do banco, cуdigo da moйda, as cinco primeiras posiзхes
        // do campo livre e DV (modulo10) deste campo
        
$p1 substr($codigo04);
        
$p2 substr($codigo195);
        
$p3 modulo_10("$p1$p2");
        
$p4 "$p1$p2$p3";
        
$p5 substr($p405);
        
$p6 substr($p45);
        
$campo1 "$p5.$p6";

        
// 2. Campo - composto pelas posiзoes 6 a 15 do campo livre
        // e livre e DV (modulo10) deste campo
        
$p1 substr($codigo2410);
        
$p2 modulo_10($p1);
        
$p3 "$p1$p2";
        
$p4 substr($p305);
        
$p5 substr($p35);
        
$campo2 "$p4.$p5";

        
// 3. Campo composto pelas posicoes 16 a 25 do campo livre
        // e livre e DV (modulo10) deste campo
        
$p1 substr($codigo3410);
        
$p2 modulo_10($p1);
        
$p3 "$p1$p2";
        
$p4 substr($p305);
        
$p5 substr($p35);
        
$campo3 "$p4.$p5";

        
// 4. Campo - digito verificador do codigo de barras
        
$campo4 substr($codigo41);

        
// 5. Campo composto pelo fator vencimento e valor nominal do documento, sem
        // indicacao de zeros a esquerda e sem edicao (sem ponto e virgula). Quando se
        // tratar de valor zerado, a representacao deve ser 000 (tres zeros).
        
$p1 substr($codigo54);
        
$p2 substr($codigo910);
        
$campo5 "$p1$p2";

        return 
"$campo1 $campo2 $campo3 $campo4 $campo5"
}

function 
geraCodigoBanco($numero) {
    
$parte1 substr($numero03);
    
$parte2 modulo_11($parte1);
    return 
$parte1 "-" $parte2;
}

function 
geraDv43($num) { 
        
$numtotal10 0;
        
$fator 2;

        
// Separacao dos numeros
        
for ($i strlen($num); $i 0$i--) {
            
// pega cada numero isoladamente
            
$numeros[$i] = substr($num,$i-1,1);
            
// Efetua multiplicacao do numero pelo (falor 10)
            // 2002-07-07 01:33:34 Macete para adequar ao Mod10 do Itaъ
            
$temp $numeros[$i] * $fator
            if (
$temp 9$temp=$temp-9// Regra do banco NossaCaixa
            
$temp0=0;
            foreach (
preg_split('//',$temp,-1,PREG_SPLIT_NO_EMPTY) as $k=>$v){ $temp0+=$v; }
            
$parcial10[$i] = $temp0//$numeros[$i] * $fator;
            // monta sequencia para soma dos digitos no (modulo 10)
            
$numtotal10 += $parcial10[$i];
            if (
$fator == 2) {
                
$fator 1;
            } else {
                
$fator 2// intercala fator de multiplicacao (modulo 10)
            
}
        }
        
        
// vбrias linhas removidas, vide funзгo original
        // Calculo do modulo 10
        
$resto $numtotal10 10;
        
        if (
$resto == 0) {
            
$dv 0;
        } else {
            
$dv 10 $resto;
        }

        return 
$dv;
        
}

function 
geraDv44($numero) {
    
$resto modulo_11($numero,7,1);
    if (
$resto == 0){
        
$dv 0;
    }
    elseif (
$resto 1){
        
$dv 11-$resto;
    }
    elseif (
$resto == 1){
        
$dv1 substr($numero,23,1);
        
$dv1 $dv1 1;
        
$dv1 == 10 $dv1=0$dv1;
        
$numero substr($numero,0,23).$dv1;
      
$dv44 geraDv44($numero);
        
$dv=$dv1.$dv44;
    }
        
    return 
$dv;
}


?>
Онлайн: 0
Реклама