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 exigirão 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 iniciou 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", "state": "initialized", "summary": {}, "tag": null, "updated_at": "2023-01-03 08:29:48 UTC" }, "user": { "gravatar_uid": "29a2d1baa67d4ea524cf0f247f7bbb94", "id": "9c365b9a6f77c247c3de959f6152b231", "nome": "Joe Sixpack", "username": "user-1" } }fazendo a expressão necessária para o campo
{{$.project.id}}. -
Clique em Gravar.
A janela fecha e os parâmetros para a ação são salvos
-
-
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 JSON novamenteTransformar JSON com jq
-
Na aba na janela , procure por frase-jq.
Arraste e solte o bloco de ação
abaixo da açãoTransformar JSON com jq
para conectá-los.lista de 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
.lista de locais
O link fica verde e o campo pode ser editado.
-
O campo recebe 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
.lista de 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
padrãoéverdadeiroé necessário.Pode haver apenas um local padrão por projeto e a lista tem um elemento identificável e necessário. Esse elemento é acessado diretamente com a sintaxe de array
.[0].Digite a expressão
map(selecionar(.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:create
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
Transformar JSON com 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 os propósitos deste exemplo, uma data codificada será usada, entendida 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
ANDlógico eOR. Essas condições são avaliadas em tempo de execução e a ação e seus filhos só serão executados se a condição for 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 se abre.
-
Seguindo padrões de blocos anteriores, vincule o campo ao gatilho
e digite a expressãouploads:create
{{$.upload.tag}}. -
Selecione NÃO na primeira lista suspensa para inverter a afirmação.
-
Selecione IsNull na lista suspensa .
-
Clique em Gravar.
A condição é apresentada na aba .
O fluxo de trabalho parará neste ponto se o upload não contiver uma tag (significando que não houve novas/chaves/traduções atualizadas).
-
-
Os locais de destino agora são necessá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 no passo 3.Transformar JSON com jq
-
No campo de ambas as ações, digite a expressão
{{@.outputs.result}}, vincule à açãoe salve o parâmetro.Listar locais
-
No campo de uma ação, insira a expressão
map(select(.name == "es-ES"))|.[0]e vincule à ação.Lista de locais
Grave o parâmetro.
-
Na segunda ação, insira a expressão
map(select(.name == "de-DE"))|.[0]e vincule à ação.Lista de locais
Grave o parâmetro.
-
-
Os locais agora serão aplicados à criação de trabalho.
Configure as duas ações
com os mesmos padrões definidos anteriormente.Adicionar um local alvo a um trabalho
-
O trabalho agora pode ser iniciado.
Configure a ação
com os mesmos padrões definidos anteriormente.Iniciar um trabalho