F040ALT
PE apos alteracao de titulo a receber. Auditoria de mudancas, validacao de fluxo.
Assinatura: User Function F040ALT() --> NIL
Retorna: NIL
Modulo: SIGAFIN · Rotina: FINA040 · Momento: Pos-alteracao SE1
Parametros (PARAMIXB)
Este PE nao recebe parametros via PARAMIXB. A tabela alvo ja esta posicionada quando o PE dispara — opere via (ALIAS)->CAMPO.
Retorno
NIL
Pegadinhas
- Em base com banco bordero gerado, mudanca pode invalidar — checar E1_PORTADO.
Quando usar
- Auditoria detalhada de mudanca (campo X mudou de Y para Z)
- Re-sincronizar com sistema externo
- Invalidar caches relacionados
Exemplo (template)
User Function F040ALT()
// Registro ja alterado — auditar / sincronizar / propagar
Begin Sequence
U_GravaAuditoria(...)
U_SincronizaExterno(...)
Recover
FwLogger():Error("F040ALT falhou")
End Sequence
ReturnCuidados 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
- SE1 — titulo a receber (geralmente posicionada quando PE dispara)
- Relacionadas: SE5, SA1