M460FIM
PE apos liberacao do pedido (MATA460). Trigger para integracoes externas, notificacao de operador, gravacao de auditoria.
Assinatura: User Function M460FIM() --> NIL
Retorna: NIL
Modulo: SIGAFAT · Rotina: MATA460 · Momento: Apos confirmacao da liberacao do pedido na tela MATA460
Parametros (PARAMIXB)
// Sem PARAMIXB. SC9 do item liberado posicionadaRetorno esperado
NIL
Exemplo
User Function M460FIM()
// SC9 do item liberado ja posicionada
If !Empty(SC9->C9_BLCRED)
// Houve bloqueio - notifica
U_NotifBloqueio(SC9->C9_PEDIDO, SC9->C9_BLCRED)
Else
// Liberou OK - notifica logistica
U_NotifLib(SC9->C9_PEDIDO, SC9->C9_ITEM)
EndIf
ReturnPegadinhas
- SC9 ja gravada — qualquer rollback aqui nao desfaz.
- Em liberacao em massa, PE dispara N vezes (uma por item).
- Cuidado com performance — se PE leva 500ms, liberar 100 itens => 50s extra.
Quando usar
- Trigger pra acao subsequente automatica
- Geracao de relatorio/log
- Integracao assincrona via fila
Cuidados gerais
- Erro aqui nao reverte a operacao: o registro ja foi gravado. Falha do PE deve ser apenas logada — nao tentar rollback.
- Idempotencia: PEs podem disparar mais de uma vez em retry ou reprocessamento — codigo deve ser seguro pra rodar varias vezes sem efeito colateral.
- Performance critica: PE roda em fluxo do usuario. Operacoes pesadas (loop sobre milhares de registros, chamada HTTP sincrona) podem travar a tela. Use
StartJobpra background. - Em JOB sem AppServer ativo: PE chamado via RPC pode ter
cFilAnt/cEmpAntvazios — sempre garantaRpcSetEnv. - Begin Sequence + Recover: erros nao tratados em PE podem deixar transacao Protheus em estado inconsistente. Sempre envolver em
Begin Sequence ... End Sequence. - Logging com contexto: use
FwLoggercom identificacao do PE no log — facilita troubleshooting.
Tabelas afetadas
- SC9 — liberacao de pedido (geralmente posicionada quando PE dispara)
- Relacionadas: SF2, SD2, SE1