Árvore de páginas

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

...

  • Alterar via Tools opção 3, a tabela PEDIDOPAGAMENTO:

    Bloco de código
    languagesql
    titleAlter Table PEDIDOPAGAMENTO
    alter table pedidopagamento add column dataexpiracao timestamp;
  • Adicionar na tela do plugin de Pagamento PIX, os campos conforme protótipo abaixo:



    Bloco de código
    titleNovos Campos
    Campo "Duração máxima transação PIX antes de expirar"
    	idpluginintegracao: select idpluginintegracao from pluginintegracao where codigo = 'TPI',
    	codigoelemento: TPI,
    	agrupador: 0,
    	sglcampo: TPI_EXPIRATIONDATE
    	valor: {padrão 1440}
    Campo "Ação automática sobre o pedido quando o serviço de atualização de status identificar que a transação expirou"
    	idpluginintegracao: select idpluginintegracao from pluginintegracao where codigo = 'TPI',
    	codigoelemento: TPI,
    	agrupador: 0,
    	sglcampo: TPI_OPEN
    	valor: {O ou 1, padrão 1}
    
    Campo "Ação automática sobre o pedido quando o serviço de atualização de status identificar que a transação expirou"
    	idpluginintegracao: select idpluginintegracao from pluginintegracao where codigo = 'TPI',
    	codigoelemento: TPI,
    	agrupador: 0,
    	sglcampo: TPI_CANCEL
    	valor: {0 ou 1, padrão 0}


    • Para o campo referente a ação que deve ser executada, somente uma opção pode estar selecionada pelo usuário.

  • O valor retornado na tag DATAEXPIRACAO deve ser persistido em PEDIDOPAGAMENTO.DATAEXPIRACAO;

  • Alterar a tela Pagamentos do Pedido, para incluir a nota coluna referente a data para expirar da transação:



    • A informação para essa nova coluna virá de PEDIDOPAGAMENTO.DATAEXPIRACAO.

...

  • Alterar o Job TPIGENERATEPAYMENT para calcular a data e hora para obter a data para expirar da transação PIX;
     
    • Utilizar o script abaixo para obter a data e hora para expirar da transação:

      Bloco de código
      languagesql
      titleBusca Tempo
      SELECT current_timestamp +(SELECT cast(valor as integer) FROM pluginintconfig WHERE sglcampo = 'TPI_EXPIRATIONDATE' AND codigoelemento = 'TPI') * interval '1 minute' AS data_expirar;
    • Somar a data e hora do momento em que a transação é gerada com o tempo cadastrado pelo cliente, e incluir dentro do JSON de requisição:

      "expirationDate": "YYYY-MM-DD HH:MM:SS"

    • O retorno se a data e hora foi aceita pela TPI estará na tag "expiresAt" no JSON de RESPONSE;
      O valor retornado na tag "expiresAt" deve ser persistido em PEDIDOPAGAMENTO.DATAEXPIRACAO.

  • Adicionar no Job TPIUPDATESTATUS, a validação da ação que deve ser tomada automaticamente quando a transação PIX ter expirado sem a confirmação do pagamento;

    • Usar o script abaixo para obter qual ação foi cadastrada pelo usuário:

      Bloco de código
      languagesql
      titleBusca Ação
      select case when sglcampo ='TPI_OPEN' then valor end as REABRIR, case when sglcampo ='TPI_CANCEL' then valor end as CANCELAR from pluginintconfig p where sglcampo in('TPI_OPEN','TPI_CANCEL')


      • Se o plugin estiver configurado para REABRIR, pedido cuja transação tenha expirado devem ter a situação alterada para NÃO FINALIZADO - NF;

      • Se o plugin estiver configurado para CANCELAR, pedido cuja transação tenha expirado devem ter a situação alterada para CANCELADO - PC;

        • Utilizar a consulta abaixo para identificar os pedidos que devem ter a situação atualizada:

          Bloco de código
          languagesql
          titleBusca Ação
          SELECT p.idpedido
          FROM   pedido p
                 INNER JOIN pedidopagamento pp
                         ON p.idpedido = pp.idpedido
                 INNER JOIN tiposituacaopagamento t
                         ON t.idtiposituacaopagamento = pp.idtiposituacaopagamento
                 INNER JOIN tiposituacaopedido tp
                         ON tp.idtiposituacaopedido = p.idtiposituacaopedido
          WHERE  t.sgltiposituacaopagamento = 'EXP'
                 AND (SELECT Count(idpedido)
                      FROM   pedidopagamento p2
                             INNER JOIN tiposituacaopagamento t2
                                     ON
                             t2.idtiposituacaopagamento = p2.idtiposituacaopagamento
                      WHERE  t2.sgltiposituacaopagamento in ('PEND', 'APR')
                             AND p2.idpedido = p.idpedido) = 0
                 AND p.idnexportadoerp = 0
                 AND tp.sgltiposituacaopedido = 'PP';
    • Se não houver uma configuração definida, o comportamento atual deve ser mantido e a situação do pedido não deve ser alterada.
      Após atualizar a situação dos pedidos, se eles tiverem aprovações vinculadas, estas também devem ser atualizadas;
      Utilizar a consulta abaixo para atualizar a situação das aprovações:
      Bloco de código
      languagesql
      titleBusca Ação
      update pedidoaprovacao set idtiposituacaoaprovacao = (select idtiposituacaoaprovacao from tiposituacaoaprovacao where sgltiposituacaoaprovacao = 'CA') where idpedido = ? update pedidoaprovacao set observacao = 'Aprovação de pedido cancelada automaticamente, pois a situação do pedido foi alterada para NÃO FINALIZADO / CANCELADO, devido à transação PIX vinculada a este pedido ter expirado.' where idpedido = ?