Para continuar com o fluxo de trabalho de exemplo, ele precisará ser configurado.
A configuração do bloco pode ser acessada clicando em Editar parâmetros na aba , ou clicando com o botão direito no bloco e selecionando Editar parâmetros para abrir a janela . Uma vez que um bloco tenha parâmetros, o botão muda para .
Para configurar os blocos para o exemplo, siga estas etapas:
-
Abra a janela para a ação
.Listar locais
-
Os campos e precisarão de valores dinâmicos que são resolvidos em tempo de execução.
-
Clique no ícone de link
para o campo e selecione a ação
.Buscar tokens de acesso
O link fica verde e o campo pode ser editado.
-
A sintaxe para acessar as propriedades de um gatilho ou ação referenciada é:
{{$.path.to.value}}Com a saída para
sendo:Buscar tokens de acesso
{ "tokens": {"strings_token": "STRINGS_TOKEN", "tms_token": "TMS_TOKEN"} }tornando a expressão necessária para o campo
{{$.tokens.strings_token}}. -
Clique no ícone de link
para o campo e selecione o gatilho
.uploads:create
O link fica verde e o campo pode ser editado.
-
A saída do gatilho
se assemelha a:uploads:create
{ "branch": { "name": "my_branch" }, "event": "uploads:create", "mensagem": "usuário-1 inicializou o upload do arquivo file.yml no projeto name_1672734591_11 dentro do ramo my_branch\n", "project": { "created_at": "2023-01-03 08:29:51 UTC", "id": "abcdabcdabcdabcd-11", "main_format": "yml", "name": "name_1672734591_10", "point_of_contact": null, "project_image_url": null, "slug": "name_1672734591_10", "updated_at": "2023-01-03 08:29:51 UTC" }, "upload": { "created_at": "2023-01-03 08:29:48 UTC", "filename": "file.yml", "format": "yml", "id": "upload-1", "estado": "inicializado", "resumo": {}, "tag": null, "updated_at": "2023-01-03 08:29:48 UTC", }, "usuário": { "gravatar_uid": "29a2d1baa67d4ea524cf0f247f7bbb94", "id": "9c365b9a6f77c247c3de959f6152b231", "name": "Joe Sixpack", "username": "user-1" } }fazendo a expressão obrigatória para o campo
{{$.project.id}}. -
Clique em Gravar.
A janela é fechada e os parâmetros da ação são gravados.
-
-
O local padrão do projeto é necessário para criar um trabalho, passando o ID para a ação
. A açãoCriar trabalho
recebe uma entrada JSON, aplica o filtro especificado e então gera a saída JSON novamenteTransformar JSON com jq
-
Na aba na janela , procure por frase-jq.
Arraste e solte o bloco de ação
abaixo do bloco de açãoTransformar JSON com jq
para conectá-los.listar locais
-
Abra a janela para a ação
Transformar JSON com jq. -
Selecione no campo suspenso .
-
Clique no ícone de link
para o campo e selecione a ação
.listar locais
O link fica verde e o campo pode ser editado.
-
O campo aceita a entrada JSON. Uma expressão fixa especial (
@em vez de$) garante que toda a saída da ação referenciada seja passada para o campo.Digite a expressão
{{@.outputs.result}}no campo . -
Clique no ícone de link
para o campo e selecione a ação
.listar locais
O link fica verde e o campo pode ser editado.
-
Um filtro da lista de locais que retorna uma nova lista contendo todos os elementos onde a propriedade
defaultétrueé necessário.Pode haver apenas um local padrão por projeto e a lista tem um elemento identificável e obrigatório. Esse elemento é acessado diretamente com a sintaxe de array
.[0].Digite a expressão
map(select(.default))|.[0]no campo . -
Clique em Gravar.
A janela fecha e os parâmetros para a ação são salvos
-
-
A ação
agora pode ser configurada e usará padrões de blocos anteriores.Criar um trabalho
-
Clique no ícone de link
para o campo e selecione a ação
.Buscar tokens de acesso
O link fica verde e o campo pode ser editado.
Digite a expressão
{{$.tokens.strings_token}}. -
Clique no ícone de link
para o campo e selecione o gatilho
.uploads:criar
O link fica verde e o campo pode ser editado.
Digite a expressão
{{$.project.id}}. -
Clique no ícone de link
para o campo e selecione a ação
Transform JSON with jq.O link fica verde e o campo pode ser editado.
Digite a expressão
{{@.outputs.result}}. -
A data de vencimento pode ser calculada com funções sprig ou Expr, mas para fins deste exemplo, uma data codificada será usada, compreendida pela API.
No campo , digite 2023-12-31T12:00:00Z.
-
Clique em Gravar.
A configuração é salva e os detalhes podem ser visualizados na aba .
-
-
Cada ação pode ter uma ou mais condições combinadas com os operadores lógicos
EeOU. Essas condições são avaliadas em tempo de execução e a ação e seus secundários só serão executados se a condição for avaliada como verdadeira.Para refletir isso no exemplo, enquanto a ação
estiver selecionada, clique em Editar condições na aba ou clique com o botão direito no bloco e selecione Editar condições.Criar um trabalho
A janela é aberta.
-
Seguindo padrões de blocos anteriores, vincule o campo ao gatilho
e digite a expressãouploads:criar
{{$.upload.tag}}. -
Selecione NÃO na primeira lista suspensa para inverter a declaração.
-
Selecione IsNull na lista suspensa .
-
Clique em Gravar.
A condição é apresentada na aba .
O fluxo de trabalho será interrompido neste ponto se o upload não contiver um código (o que significa que não houve novas chaves/traduções atualizadas).
-
-
Os locais de destino agora são obrigatórios para o trabalho. Para os propósitos do exemplo, dois locais serão criados; um para espanhol (es-ES) e um para alemão (de-DE). Os locais serão adicionados às duas
ações na janela como na etapa 3.Transformar JSON com jq
-
No campo de ambas as ações, insira a expressão
{{@.outputs.result}}, vincule à açãoe grave o parâmetro.List locales
-
No campo de uma ação, insira a expressão
map(select(.name == "es-ES"))|.[0]e vincule à ação.List locales
Grave o parâmetro.
-
Na segunda ação, insira a expressão
map(select(.name == "de-DE"))|.[0]e vincule à ação.List locales
Grave o parâmetro.
-
-
Os locais agora serão aplicados à criação do trabalho.
Configure as duas ações
com os mesmos padrões definidos anteriormente.Adicionar um local de destino a um trabalho
-
O trabalho agora pode ser iniciado.
Configure a ação
com os mesmos padrões definidos anteriormente.Iniciar um trabalho