Esta documentação foi traduzida automaticamente por IA.
As APIs disponíveis na estrutura do pacote do lado do servidor são mostradas no código a seguir:
PluginWorkflowServerClasse do plugin de fluxo de trabalho.
Geralmente, durante a execução do aplicativo, você pode chamar app.pm.get<PluginWorkflowServer>(PluginWorkflowServer) em qualquer lugar onde possa obter a instância do aplicativo app para acessar a instância do plugin de fluxo de trabalho (referida como plugin abaixo).
registerTrigger()Estende e registra um novo tipo de gatilho.
Assinatura
registerTrigger(type: string, trigger: typeof Trigger | Trigger })
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
type | string | Identificador do tipo de gatilho |
trigger | typeof Trigger | Trigger | Tipo ou instância do gatilho |
Exemplo
registerInstruction()Estende e registra um novo tipo de nó.
Assinatura
registerInstruction(type: string, instruction: typeof Instruction | Instruction })
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
type | string | Identificador do tipo de instrução |
instruction | typeof Instruction | Instruction | Tipo ou instância da instrução |
Exemplo
trigger()Aciona um fluxo de trabalho específico. Usado principalmente em gatilhos personalizados para acionar o fluxo de trabalho correspondente quando um evento personalizado específico é detectado.
Assinatura
trigger(workflow: Workflow, context: any)
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
workflow | WorkflowModel | Objeto do fluxo de trabalho a ser acionado |
context | object | Dados de contexto fornecidos no momento do acionamento |
Atualmente, context é um item obrigatório. Se não for fornecido, o fluxo de trabalho não será acionado.
Exemplo
resume()Retoma a execução de um fluxo de trabalho em espera com uma tarefa de nó específica.
EXECUTION_STATUS.STARTED) podem ser retomados.JOB_STATUS.PENDING) podem ser retomadas.Assinatura
resume(job: JobModel)
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
job | JobModel | Objeto da tarefa atualizada |
O objeto da tarefa passado é geralmente um objeto atualizado, e seu status é normalmente atualizado para um valor diferente de JOB_STATUS.PENDING, caso contrário, ele continuará em espera.
Exemplo
Veja os detalhes no código-fonte.
TriggerA classe base para gatilhos, usada para estender tipos de gatilhos personalizados.
| Parâmetro | Tipo | Descrição |
|---|---|---|
constructor | (public readonly workflow: PluginWorkflowServer): Trigger | Construtor |
on? | (workflow: WorkflowModel): void | Manipulador de eventos após ativar um fluxo de trabalho |
off? | (workflow: WorkflowModel): void | Manipulador de eventos após desativar um fluxo de trabalho |
on/off são usados para registrar/desregistrar listeners de eventos quando um fluxo de trabalho é ativado/desativado. O parâmetro passado é a instância do fluxo de trabalho correspondente ao gatilho, que pode ser processado de acordo com a configuração. Alguns tipos de gatilho que já possuem eventos escutados globalmente podem não precisar implementar esses dois métodos. Por exemplo, em um gatilho agendado, você pode registrar um temporizador em on e desregistrá-lo em off.
InstructionA classe base para tipos de instrução, usada para estender tipos de instrução personalizados.
| Parâmetro | Tipo | Descrição |
|---|---|---|
constructor | (public readonly workflow: PluginWorkflowServer): Instruction | Construtor |
run | Runner | Lógica de execução para a primeira entrada no nó |
resume? | Runner | Lógica de execução para entrar no nó após retomar de uma interrupção |
getScope? | (node: FlowNodeModel, data: any, processor: Processor): any | Fornece o conteúdo da variável local para a ramificação gerada pelo nó correspondente |
Tipos Relacionados
Para getScope, você pode consultar a implementação do nó de loop, que é usada para fornecer o conteúdo da variável local para as ramificações.
EXECUTION_STATUSUma tabela de constantes para os status do plano de execução do fluxo de trabalho, usada para identificar o status atual do plano de execução correspondente.
| Nome da Constante | Significado |
|---|---|
EXECUTION_STATUS.QUEUEING | Em fila |
EXECUTION_STATUS.STARTED | Iniciado |
EXECUTION_STATUS.RESOLVED | Resolvido |
EXECUTION_STATUS.FAILED | Falhou |
EXECUTION_STATUS.ERROR | Erro na execução |
EXECUTION_STATUS.ABORTED | Abortado |
EXECUTION_STATUS.CANCELED | Cancelado |
EXECUTION_STATUS.REJECTED | Rejeitado |
EXECUTION_STATUS.RETRY_NEEDED | Não executado com sucesso, necessário tentar novamente |
Exceto pelos três primeiros, todos os outros representam um estado de falha, mas podem ser usados para descrever diferentes motivos de falha.
JOB_STATUSUma tabela de constantes para os status das tarefas de nó do fluxo de trabalho, usada para identificar o status atual da tarefa de nó correspondente. O status gerado pelo nó também afeta o status de todo o plano de execução.
| Nome da Constante | Significado |
|---|---|
JOB_STATUS.PENDING | Pendente: A execução chegou a este nó, mas a instrução exige que ele seja suspenso e aguarde |
JOB_STATUS.RESOLVED | Resolvido |
JOB_STATUS.FAILED | Falhou: A execução deste nó não atendeu às condições configuradas |
JOB_STATUS.ERROR | Erro: Ocorreu um erro não tratado durante a execução deste nó |
JOB_STATUS.ABORTED | Abortado: A execução deste nó foi encerrada por outra lógica após estar em estado pendente |
JOB_STATUS.CANCELED | Cancelado: A execução deste nó foi cancelada manualmente após estar em estado pendente |
JOB_STATUS.REJECTED | Rejeitado: A continuação deste nó foi rejeitada manualmente após estar em estado pendente |
JOB_STATUS.RETRY_NEEDED | Não executado com sucesso, necessário tentar novamente |
As APIs disponíveis na estrutura do pacote do lado do cliente são mostradas no código a seguir:
PluginWorkflowClientregisterTrigger()Registra o painel de configuração para o tipo de gatilho.
Assinatura
registerTrigger(type: string, trigger: typeof Trigger | Trigger): void
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
type | string | Identificador do tipo de gatilho, consistente com o identificador usado para registro |
trigger | typeof Trigger | Trigger | Tipo ou instância do gatilho |
registerInstruction()Registra o painel de configuração para o tipo de nó.
Assinatura
registerInstruction(type: string, instruction: typeof Instruction | Instruction): void
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
type | string | Identificador do tipo de nó, consistente com o identificador usado para registro |
instruction | typeof Instruction | Instruction | Tipo ou instância do nó |
registerInstructionGroup()Registra um grupo de tipos de nó. O NocoBase oferece 4 grupos de tipos de nó padrão:
'control': Controle'collection': Operações de coleção'manual': Processamento manual'extended': Outras extensõesSe você precisar estender outros grupos, pode usar este método para registrá-los.
Assinatura
registerInstructionGroup(type: string, group: { label: string }): void
Parâmetros
| Parâmetro | Tipo | Descrição |
|---|---|---|
type | string | Identificador do grupo de nós, consistente com o identificador usado para registro |
group | { label: string } | Informações do grupo, atualmente inclui apenas o título |
Exemplo
TriggerA classe base para gatilhos, usada para estender tipos de gatilhos personalizados.
| Parâmetro | Tipo | Descrição |
|---|---|---|
title | string | Nome do tipo de gatilho |
fieldset | { [key: string]: ISchema } | Coleção de itens de configuração do gatilho |
scope? | { [key: string]: any } | Coleção de objetos que podem ser usados no Schema dos itens de configuração |
components? | { [key: string]: React.FC } | Coleção de componentes que podem ser usados no Schema dos itens de configuração |
useVariables? | (config: any, options: UseVariableOptions ) => VariableOptions | Acessor de valor para dados de contexto do gatilho |
useVariables não for definido, significa que este tipo de gatilho não oferece uma função de recuperação de valor, e os dados de contexto do gatilho não podem ser selecionados nos nós do fluxo de trabalho.InstructionA classe base para instruções, usada para estender tipos de nós personalizados.
| Parâmetro | Tipo | Descrição |
|---|---|---|
group | string | Identificador do grupo de tipos de nó, opções atuais: 'control'/'collection'/'manual'/'extended' |
fieldset | Record<string, ISchema> | Coleção de itens de configuração do nó |
scope? | Record<string, Function> | Coleção de objetos que podem ser usados no Schema dos itens de configuração |
components? | Record<string, React.FC> | Coleção de componentes que podem ser usados no Schema dos itens de configuração |
Component? | React.FC | Componente de renderização personalizado para o nó |
useVariables? | (node, options: UseVariableOptions) => VariableOption | Método para o nó fornecer opções de variáveis do nó |
useScopeVariables? | (node, options?) => VariableOptions | Método para o nó fornecer opções de variáveis locais da ramificação |
useInitializers? | (node) => SchemaInitializerItemType | Método para o nó fornecer opções de inicializadores |
isAvailable? | (ctx: NodeAvailableContext) => boolean | Método para determinar se o nó está disponível |
Tipos Relacionados
useVariables não for definido, significa que este tipo de nó não oferece uma função de recuperação de valor, e os dados de resultado deste tipo de nó não podem ser selecionados nos nós do fluxo de trabalho. Se o valor do resultado for singular (não selecionável), você pode retornar um conteúdo estático que expresse a informação correspondente (consulte: código-fonte do nó de cálculo). Se for necessário que seja selecionável (por exemplo, uma propriedade de um Objeto), você pode personalizar a saída do componente de seleção correspondente (consulte: código-fonte do nó de criação de dados).Component é um componente de renderização personalizado para o nó. Quando a renderização padrão do nó não é suficiente, ele pode ser completamente substituído para uma renderização de visualização de nó personalizada. Por exemplo, se você precisar fornecer mais botões de ação ou outras interações para o nó inicial de um tipo de ramificação, você usaria este método (consulte: código-fonte da ramificação paralela).useInitializers é usado para fornecer um método para inicializar blocos. Por exemplo, em um nó manual, você pode inicializar blocos de usuário relacionados com base nos nós upstream. Se este método for fornecido, ele estará disponível ao inicializar blocos na configuração da interface do nó manual (consulte: código-fonte do nó de criação de dados).isAvailable é usado principalmente para determinar se um nó pode ser usado (adicionado) no ambiente atual. O ambiente atual inclui o fluxo de trabalho atual, nós upstream e o índice da ramificação atual.