M100FIM
PE apos gravacao confirmada da NF de entrada. SF1/SD1 ja persistidas, ideal pra integracao fiscal externa.
Assinatura: User Function M100FIM() --> NIL
Retorna: NIL
Modulo: SIGACOM · Rotina: MATA103 · Momento: Pos-gravacao da NF de Entrada
Parametros (PARAMIXB)
// Sem PARAMIXB. SF1 posicionadaRetorno esperado
NIL
Pegadinhas
- Integracoes pesadas devem ser ENFILEIRADAS (gravar registro em tabela Z + processar em JOB) — nao bloquear o usuario.
- Em MATA103 com XML, valide se o XML ja foi anexado antes de enviar.
Quando usar
- Trigger pra acao subsequente automatica
- Geracao de relatorio/log
- Integracao assincrona via fila
Exemplo (template)
User Function M100FIM()
// Operacao ja gravada — trigger pra acoes pos-evento
Begin Sequence
// Logica custom apos gravacao
// Exemplos: notificar, sincronizar, gerar log
FwLogger():Info("M100FIM disparado", {;
"filial": cFilAnt, ;
"user": RetCodUsr() ;
})
Recover
FwLogger():Error("Falha em M100FIM: " + ErrorBlock())
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
- SF1 — NF de entrada (geralmente posicionada quando PE dispara)
- Relacionadas: SD1, SE2, SF6