CN100INC
PE apos inclusao de Contrato (CN9). Trigger pra workflow de aprovacao, cadastro de medicoes futuras.
Assinatura: User Function CN100INC() --> NIL
Retorna: NIL
Modulo: SIGAGCT (Gestao Contratos) · Rotina: CNTA100 · Momento: Apos inclusao do contrato
Parametros (PARAMIXB)
// CN9 (contrato) posicionadaRetorno
NIL
Contexto
GCT controla contratos de fornecimento — com pagamento por medicao/vigencia. Util em servicos terceirizados, manutencao predial, telefonia.
Exemplo
User Function CN100INC()
// Contrato inicia workflow de aprovacao
If CN9->CN9_VALTOT > 50000
U_IniciarWfContrato(CN9->CN9_NUMERO, "GERENTE")
EndIf
ReturnPegadinhas
- Contrato com vigencia futura nao gera medicao imediata.
- Aditivos sao CN9 separados — vincular ao original via CN9_CONTRA.
Quando usar
- Sincronizar registro novo com sistema externo (CRM, e-commerce, EDI)
- Gerar registros vinculados em tabelas Z customizadas
- Enviar notificacao por email/SMS apos cadastro
- Criar workflow de aprovacao
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
- CN9 — contrato (GCT) (geralmente posicionada quando PE dispara)
- Relacionadas: CNE