Para continuar com o fluxo de trabalho de amostra, ele precisará ser configurado.
A configuração de blocos pode ser acessada clicando em Edicionar parâmetros na aba ou clicando com o clique direito no bloco e selecionando Edicionar parâmetros para abrir a janela . Assim que um bloco tiver parâmetros, o botão será alterado para .
Para configurar os blocos para o exemplo, siga estes passos:
-
Abra a janela
para a ação
.Listas locais
-
Os campos
e precisarão de valores dinâmicos que sejam resolvidos no momento de execução.-
Clique no
do ícone de link para o campo e selecione a ação
.Tokens de acesso do Fetch
O link se torna verde e o campo pode ser editado.
-
A sintaxe para acessar as propriedades de um acionamento ou ação referido é:
{{$.path.to.value}}
Com a saída para os tokens de acesso do
sendo:Fetch
{ "tokens": {"strings_token": "STRINGS_TOKEN", "tms_token": "TMS_TOKEN"} }
fazendo a expressão necessária para o
{{$.tokens.strings_token}} de
campo . -
Clique no ícone de link
para o campo e selecione o acionamento
.uploads:crear
O link se torna verde e o campo pode ser editado.
-
A saída do acionamento
é semelhante:uploads:create
{ "branch": { "name": "my_branch" }, "event": "uploads:criar", "message": "usuário-1 arquivo inicializado upload file.yml no projeto nome_1672734591_11 no ramo my_ramo\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", "name": "Joe Sixpack", "username": "user-1" } }
fazendo a expressão necessária para o
{{$.project.id}} de
campo do . -
Clique em Gravar.
As janelas
são fechadas e os parâmetros da ação são salvos
-
-
O local padrão do projeto é necessário criar um trabalho transferindo o ID para a ação
. A açãoCriar trabalho
leva uma entrada JSON, aplica o filtro especificado e então retorna ao JSONTransform JSON with jq
-
Na aba Phrase-jq.
na janela , procureArraste e solte o bloco de ação
abaixo da ação deTransformar JSON com jq
para conectá-los.lista locais
-
Abra a janela
para a açãoTransformar JSON com jq
. -
Selecione
no campo suspenso . -
Clique no
do ícone de link para o campo e selecione a ação
.lista locais
O link se torna verde e o campo pode ser editado.
-
O campo
leva a entrada JSON. Uma expressão fixa especial (@
em vez de$
) garante que toda a saída da ação referida seja passada ao campo.Insira a expressão
{{@.outputs.result}}
no campo . -
Clique no
do ícone de link para o campo e selecione a ação
.lista locais
O link se torna verde e o campo pode ser editado.
-
É necessário filtrar a lista de locais para retornar uma nova lista contendo todos os elementos em que a propriedade
padrão
éverdadeira
.Apenas pode haver 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
.[0]
matriz.Insira a expressão
map(select(.default)) |.[0]
no campo . -
Clique em Gravar.
As janelas
são fechadas e os parâmetros da ação são salvos
-
-
A ação
já pode ser configurada e usará padrões de blocos anteriores.Criar trabalho
-
Clique no
do ícone de link para o campo e selecione a ação
.Tokens de acesso do Fetch
O link se torna 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 acionamento
.uploads:crear
O link se torna verde e o campo pode ser editado.
Digite a expressão
{{$.project.id}}
. -
Clique no
do ícone de link para o campo e selecione a ação
Transformar JSON com jq
.O link se torna verde e o campo pode ser editado.
Digite a expressão
{{@.outputs.result}}
. -
A data de entrega pode ser calculada com funções sprig ou Expr, mas para fins deste exemplo será usada uma data codificada hardcoded entendida pela API.
No campo 2023-12-31T12:00:00Z.
, digite -
Clique em Gravar.
A configuração é gravada e os detalhes podem ser visualizados na aba
.
-
-
Cada ação pode ter uma ou mais condições combinadas com lógico
E
eOU
. Essas condições são avaliadas em tempo de execução, e a ação e seus subtipos só serão executados se a condição for avaliada como verdadeira.Para refletir isso no exemplo, ao ter a ação
selecionada, clique em Edicionar condições na aba ou clique com clique direito no bloco e selecione Edicionar condições.Criar um trabalho
A janela
é aberta.-
Seguindo os padrões de blocos anteriores, vincule o campo
aos
acionamento e insira a expressãouploads:create
{{$.upload.tag}}
. -
Selecione NÃO na primeira lista suspensa para inverter a declaração.
-
Selecione IsNull na lista suspensa de .
-
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 (pelo que não houve chaves novas/atualizadas/traduções).
-
-
Os locais de tradução agora são necessários para o trabalho. Para os efeitos do exemplo, serão criados dois locais; um para o espanhol (es-ES) e um para o alemão (de-DE). Os locais serão adicionados aos dois
ações jq na janela como na etapa 3.JSON Transform com
-
No campo
de ambas ações insira a expressão{{@.outputs.result}}
, vincule-se à ação
e grave o parâmetro.lista locais
-
No campo
de uma ação, insira a ação expressãomap(select(.name == "es-ES") |.[0]
e vincule-se à ação
.lista locais
Gravar o parâmetro.
-
Na segunda ação, insira a expressão
map(select(.name == "de-DE") |.[0]
e vincule-se à ação
.lista locais
Gravar o parâmetro.
-
-
Os locais agora serão aplicados à criação de trabalhos.
Configurar os dois
de trabalho com os mesmos padrões definidos anteriormente.Adicionar um local de tradução a uma ação
-
O trabalho já pode ser iniciado.
Configure a ação
com os mesmos padrões definidos anteriormente.Iniciar trabalho