Orchestrator

Configure a Workflow

文本由 Phrase Language AI 从英语机器翻译而得。

要继续示工作流,需要配置它。

可以通过单击配置选项卡上的编辑参数,或右键单击块并选择编辑参数来访问块配置,以打开编辑参数窗口。一旦块有了参数,添加参数按钮切换到编辑参数

要为示例配置块,请遵循以下步骤:

  1. 打开language-blue.svg列表区域操作的编辑参数窗口。

  2. 访问令牌项目字段将需要在运行时解析的动态值。

    1. 单击访问令牌字段的链接图标Orc_link.jpg并选择circle-blue.svg获取访问令牌操作。

      链接变为绿色,字段可以编辑。

    2. 访问引用的触发器或操作属性的语法是:

      {{$.path.to.value}}

      circle-blue.svgFetch 访问令牌的输出为:

      { "tokens": {"strings_token":"STRINGS_TOKEN", "tms_token":"TMS_TOKEN"} }

      制作访问令牌字段{{$.tokens.strings_token}}所需的表达式。

    3. 单击项目字段的链接图标Orc_link.jpg并选择history-orange.svguploads:创建触发。

      链接变为绿色,字段可以编辑。

    4. history-orange.svguploads:创建触发器的输出类似:

      {
        "branch": {
          "name": "my_branch"
        },
        "event": "uploads:create",
        "消息"":“用户-1 初始化文件上传文件.yml,项目名称_1672734591_11,分支 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",
          “格式”:“yml”,
          "id": "upload-1",
          "state": "initialized",
          "summary": {},
          “标签”:空,
          "updated_at":"2023-01-03 08:29:48 UTC"
        },
        "user": {
          "gravatar_uid":"29a2d1baa67d4ea524cf0f247f7bbb94",
          “id”:"9c365b9a6f77c247c3de959f6152b231",
          "name":"Joe Sixpack"
          "username": "user-1"
        }
      }
      

      制作项目字段{{$.project.id}}所需的表达式。

    5. 点击保存

      编辑参数窗口关闭,操作的参数保存

  3. 通过将 ID 传递给work-blue.svg创建工作操作,需要项目的默认区域来创建工作。用 circle-blue.svgjq 转换 JSON 操作接收 JSON 输入,应用指定的筛选,然后再次输出 JSON

    1. 工作流块窗口的操作选项卡中,搜索 Phrase-jq

      circle-blue.svgTransform JSON with jq 操作块拖放到language-blue.svg列表区域操作下方以连接它们。

    2. 打开 Transform JSON with jq 操作的编辑参数窗口。

    3. 输入类型下拉列表中选择JSON

    4. 单击输入字段的链接图标Orc_link.jpg并选择language-blue.svg列表区域设置操作。

      链接变为绿色,字段可以编辑。

    5. 输入字段接受 JSON 输入。一个特殊的固定表达式(@,而不是$)确保被引用操作的整个输出被传递到字段中。

      输入字段中输入表达式{{@.outputs.result}}

    6. 单击 Jq 字段的链接图标Orc_link.jpg并选择language-blue.svg列表区域设置操作。

      链接变为绿色,字段可以编辑。

    7. 需要区域列表的筛选,该筛选返回一个新列表,其中包含需要默认属性为true的所有元素。

      每个项目只能有一个默认区域,且列表有一个可识别的必需元素。该元素使用 .[0] 数组语法直接访问。

      Jq 字段中输入表达式映射(select(.default))|.[0]

    8. 点击保存

      编辑参数窗口关闭,操作的参数保存

  4. 现在可以配置work-blue.svg创建工作操作,并将使用以前块的模式。

    1. 单击访问令牌字段的链接图标Orc_link.jpg并选择circle-blue.svg获取访问令牌操作。

      链接变为绿色,字段可以编辑。

      输入表达式{{$.tokens.strings_token}}

    2. 单击项目字段的链接图标Orc_link.jpg并选择language-orange.svguploads:创建触发。

      链接变为绿色,字段可以编辑。

      输入表达式{{$.project.id}}

    3. 单击原文/源语区域字段的链接图标Orc_link.jpg,并选择 Transform JSON with jq 操作。

      链接变为绿色,字段可以编辑。

      输入表达式{{@.outputs.result}}

    4. 截止日期可以用sprig或expr函数计算,但在本例中,将使用API理解的硬编码日期。

      截止日期字段中,输入 2023-12-31T12:00:00Z

    5. 点击保存

      配置已保存,详细信息可在配置选项卡中查看。

  5. 每个操作都可以有一个或多个条件,并结合逻辑 ANDOR。在运行时评估这些条件,只有当条件评估为 true 时,操作及其子操作才会执行。

    要在示例中反映这一点,在选择work-blue.svg创建工作操作时,从条件选项卡中单击编辑条件,或右键单击块并选择编辑条件

    编辑条件窗口打开。

    1. 沿用以前块的模式,将变量字段与 language-orange.svguploads:创建触发器关联,并输入表达式{{$.upload.tag}}

    2. 从第一个下拉列表中选择以反转语句。

    3. 比较下拉列表选择“是空”

    4. 点击保存

      条件在条件选项卡上。

    如果上传不包含标签(意味着没有新的/更新的键/翻译),工作流流将在这一点上停止。

  6. 工作现在需要译文区域。在本例中,将创建两个区域:一个是西班牙语(es-ES),一个是德语(de-DE)。与步骤3一样,将在编辑参数窗口中为两个 circle-blue.svgTransform JSON with jq 操作添加区域。

    1. 在两个操作的输入字段中,输入表达式{{@.outputs.result}},链接到language-blue.svg列表区域设置操作并保存参数。

    2. 在一个操作的 Jg 字段中,输入表达式映射(select(.name == "es-ES"))|.[0]并链接到language-blue.svg列表区域操作。

      保存参数。

    3. 在第二个操作中,输入表达式映射(select(.name == "de-DE"))|.[0]并链接到language-blue.svg列表区域操作。

      保存参数。

  7. 区域现已应用于创建工作。

    配置两者 为具有相同模式的工作操作work-blue.svg添加目标区域

  8. 现在可以开始工作。

    使用与以前定义的模式配置work-blue.svg开始工作操作。

这篇文章有帮助吗?

Sorry about that! In what way was it not helpful?

The article didn’t address my problem.
I couldn’t understand the article.
The feature doesn’t do what I need.
Other reason.

Note that feedback is provided anonymously so we aren't able to reply to questions.
If you'd like to ask a question, submit a request to our Support team.
Thank you for your feedback.