M050EXC
PE apos exclusao de SC1.
Assinatura: User Function M050EXC() --> NIL
Retorna: NIL
Modulo: SIGACOM · Rotina: MATA050 · Momento: Pos-exclusao SC
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
- SC ja autorizada nao deve poder ser excluida — bloqueio padrao.
Quando usar
- Limpar registros vinculados em outras tabelas
- Notificar sistema externo do delete
- Auditar com motivo + usuario que excluiu (LGPD)
Exemplo (template)
User Function M050EXC()
// Registro ja excluido — limpar dependencias
// Use PARAMIXB[1] se disponivel pra identificar registro excluido
Local cChave := IIf(ValType(PARAMIXB) == "A", PARAMIXB[1], "")
FwLogger():Warn("M050EXC - exclusao", {;
"chave": cChave, ;
"user": RetCodUsr() ;
})
ReturnCuidados gerais
- Registro nao existe mais:
DBSeekem tabela origem nao retorna nada. UsePARAMIXBpra info. - 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
- SC1 — solicitacao de compra / contrato (geralmente posicionada quando PE dispara)
- Relacionadas: SCT, SH9