Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update slackapi/slack-github-action action to v2 #194

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Dec 30, 2024

This PR contains the following updates:

Package Type Update Change
slackapi/slack-github-action action major v1.27.1 -> v2.0.0

Release Notes

slackapi/slack-github-action (slackapi/slack-github-action)

v2.0.0: Slack Send v2.0.0

Compare Source

YAML! And more API methods! With improved erroring! And more!

Sending data to Slack can now be done with the YAML format, and that data can be sent to a Slack API method or technique of choice with the provided payload. And additional configurations can improve error handling or customize values between steps.

Breaking changes happen with this update and recommended migration strategies are detailed below. Adding this step to new workflows might prefer to follow the README instead 📚

What's changed

Both inputs of payload variables, techniques for sending the payload, additional configurations, and expected outputs were changed:

The following sections detail these changes with recommended changes for existing GitHub workflows using this step and certain features.

If something seems off after making these changes, please feel free to open an issue for discussion! 👾

Sending variables

The source of variables remains the same, using one of the following inputs:

  • payload: Inputs written inline in your GitHub workflow file.
  • payload-file-path: Inputs gathered from a file.
  • No input: Uses the default event context with a payload matching the GitHub event.
⚠️ Breaking changes
Only one payload input can be provided

This Action now exits with an error if both payload and payload-file-path are provided.

Prior to updating: Both options could be provided with payload being preferred.

Recommended change: Use either payload, payload-file-path, or neither, when providing inputs. But don't include both.

Only one technique to send can be provided

This Action now exits with an error if both method and webhook techniques are provided.

Prior to updating: Both techniques could be used to send the same payload.

Recommended change: Use either method or webhook to send data, but not both.

Variable replacements no longer happen by default

This Action now sends payload provided in a payload-file-path file exactly as is.

Prior to updating: Templatized variables in input files were replaced with the matching github or env variable:

{
  "channel": "${{ env.SLACK_CHANNEL_ID }}",
  "text": "A commit was made: ${{ github.sha }}"
}

Changing the above file into something like this before being sent:

{
  "channel": "C0123456789",
  "text": "A commit was made: 3982e204d2ae590e908dd1e279e63933da566c8c"
}

Recommended change: To continue replacing templated variables provided from the step env or default GitHub event context and payload, set the payload-templated variable to true.

Payload file path parsed option was removed

This Action removed the payload-file-path-parsed input option.

Prior to updating: This option, which defaulted to true, could be set to false to avoid replacing templatized variables in a provided payload-file-path file.

Recommended change: Remove this option if it's set to false or set the new payload-templated option to true to continue parsing the provided payload.

🎁 Enhancements
Payloads can now be written in YAML

This Action now supports writing payload or payload-file-path values with YAML!

Prior to updating: Values provided as payloads had to be JSON.

Recommended change: Optional. Format the input payload value as YAML to match the surrounding steps:

- name: Post to a Slack channel
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      channel: ${{ secrets.SLACK_CHANNEL_ID }}
      text: "Greetings <@&#8203;channel>!"
Payload can now be written in unwrapped JSON

This Action now supports writing payload with unwrapped JSON, where surrounding braces are removed.

Prior to updating: Values provided as payloads had to be JSON.

Recommended change: Optional. Remove the surrounding braces from an existing payload value:

- name: Post to a Slack channel
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      "channel": "${{ secrets.SLACK_CHANNEL_ID }}",
      "text": "Greetings <@&#8203;channel>!",

Sending techniques

The techniques for sending variables remains the same, using one of the following:

Changes for different technique might be different and are included in each of the following sections.

Technique 1: Slack Workflow Builder
⚠️ Breaking changes
The webhook type must be specified in webhook inputs

This Action now requires setting the webhook-type as a step input value.

Prior to updating: The webhook type could be omitted to send to Workflow Builder.

Recommended change: Set the webhook-type value to webhook-trigger, as shown in the example below.

Payload flattening no longer happens by default

This Action no longer flattens or stringifies payloads being sent to Workflow Builder by default.

Prior to updating: Payloads sent using a webhook trigger were flattened with a . delimiter and have values stringified before being sent.

Recommended change: If payload flattening is needed, use the payload-delimiter option. Inputs of Slack workflows should use an underscore _ as a delimiter to match expected inputs of Workflow Builder:

- name: Send GitHub Action data to a Slack workflow
  uses: slackapi/[email protected]
  with:
    payload-delimiter: "_"
    webhook: ${{ secrets.SLACK_WEBHOOK_URL }}
    webhook-type: webhook-trigger
🎁 Enhancements
The webhook URL can be specified in webhook inputs

This Action can now set the webhook URL as a step input.

Prior to updating: The SLACK_WEBHOOK_URL environment variable set this value.

Recommended change: Optional. Use the webhook input value, as shown above, to set the webhook URL.

Technique 2: Slack API methods

This technique can now send to the Slack API methods and supports all token types!

⚠️ Breaking changes
The Slack API method now must be specified in inputs

This Action now requires that the Slack API method is specified in inputs.

Prior to updating: Messages would be posted using chat.postMessage or chat.update behind the scenes.

Recommend change: Use the method that matches the message being posted, or use a different method:

- name: Post to a Slack channel
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      channel: ${{ secrets.SLACK_CHANNEL_ID }}
      text: "Greetings <@&#8203;channel>!"

Note: Steps with update-ts should use chat.update as the method.

A token must be provided with other inputs

This Action expects a token as a step input value.

Prior to updating: Bot tokens were provided with the SLACK_BOT_TOKEN environment variable.

Recommended change: Provide the token scoped for the method as a step input, as shown above. The SLACK_TOKEN environment variable can also be used.

Inputs to the Slack API method must be provided in payloads

This Action now passes all provided values for payloads to the Slack API method.

Prior to updating: The channel-id and slack-message values were used.

Recommended change: Include the values sent to the Slack API method in the provided payload, as shown above.

Messages cannot be sent to multiple channels in one step

This Action can no longer send messages to multiple channels.

Prior to updating: Multiple channels could be provided to channel-id.

Recommended change: Update your GitHub workflow to repeat the same chat.postMessage step multiple times with different channel IDs.

Technique 3: Slack incoming webhook
⚠️ Breaking changes
The webhook type must be specified for incoming webhooks

This Action now requires setting the webhook-type as a step input value.

Prior to updating: The webhook type could be omitted to send to Workflow Builder.

Recommended change: Set the webhook-type value to webhook-trigger, as shown in the example below:

- name: Post a message in a channel
  uses: slackapi/[email protected]
  with:
    webhook: ${{ secrets.SLACK_WEBHOOK_URL }}
    webhook-type: incoming-webhook
    payload: |
      text: "Greetings from this step!"
🎁 Enhancements
The webhook URL must be specified for incoming webhooks

This Action can now set the webhook URL as a step input.

Prior to updating: The SLACK_WEBHOOK_URL environment variable set this value.

Recommended change: Optional. Use the webhook input value, as shown above, to set the webhook URL.

Additional configurations

🎁 Enhancements
Steps can exit with an error after a failed Slack API call

This Action can now exit if the Slack API returns an erroring response.

Prior to updating: Errors due to invalid payloads were ignored.

Recommended change: If a failing response from the Slack API should cause a step to fail, the errors value should be set to true since it defaults to false:

- name: Attempt to inverse a message
  uses: slackapi/[email protected]
  with:
    errors: true
    method: chat.reverse
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      "message": "palindrome"
Failed requests can be retried various amounts of times

This Action can now retry requests that failed due to rate limits.

Prior to updating: Rate limited requests were retried a fixed amount of times.

Recommended change: Set the retries option to a setting of choice:

- name: Attempt to inverse a message
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    retries: rapid
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      "message": "Good luck!"
Provided payloads can be flattened with a delimiter

This Action can now flatten and stringify payloads from any source.

Prior to updating: Payloads from the payload-file-path source were flattened with a period . delimiter by default.

Recommended change: Set the payload-delimiter option to an underscore _ to flatten and stringify nested payloads:

- name: Send GitHub Action data to a Slack workflow
  uses: slackapi/[email protected]
  with:
    payload-delimiter: "_"
    webhook: ${{ secrets.SLACK_WEBHOOK_URL }}
    webhook-type: webhook-trigger

In the example above, data from the default GitHub event context and event payload are flattened before being sent with a webhook to Workflow Builder, matching the expected input shape of Workflow Builder.

Provided payloads can have templated variables replaced

This Action can now replace templated variables from any source.

Prior to updating: Templated variables were replaced by default in payloads from the payload-file-path source.

Recommended change: Set the payload-templated option to true to replace templated variables in provided payloads:

- name: Send custom JSON data to Slack workflow
  uses: slackapi/[email protected]
  with:
    payload-file-path: "./payload-slack-content.json"
    payload-templated: true
    webhook: ${{ secrets.SLACK_WEBHOOK_URL }}
    webhook-type: webhook-trigger
Proxying HTTPS requests can be done within inputs

This Action can now set HTTPS proxies within the step inputs.

Prior to updating: The HTTPS_PROXY environment variable was recommended.

Recommended change: Set the proxy step input:

- name: Post to a Slack channel via a proxy
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    proxy: "http://proxy.example.org:8080" # Change this to a custom value
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      channel: ${{ secrets.SLACK_CHANNEL_ID }}
      text: "This message was sent through a proxy"

Expected outputs

The outputs from steps continues to return the following values, with changes noted below:

  • time: number The Unix epoch time that the step completed.
  • channel_id: string. The channel ID included in the response of some Slack API methods.
  • ts: string. The timestamp of the Slack event or message.
  • thread_ts: string. The timestamp of a parent Slack message with threaded replies.
⚠️ Breaking changes
The time value is now returned as the Unix epoch time

This Action now returns the Unix epoch time of when the step completed.

Prior to updating: The returned time value was formatted as a JavaScript date.

Recommenced change: Configure following steps to use time as an epoch offset.

🎁 Enhancements
An ok value is added to represent response success

This Action now returns ok to represent a successful send.

Prior to updating: Checking the time value or other outputs could be used to determine the status of some steps.

Recommended change: Configure steps that require certain successful responses of prior steps to check ok:

- name: Send a message into channel
  id: message
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      channel: ${{ secrets.SLACK_CHANNEL_ID }}
      text: "Something is happening and is in action"
- name: Reply to that message with outputs
  if: ${{ steps.message.outputs.ok }}
  uses: slackapi/[email protected]
  with:
    method: chat.postMessage
    token: ${{ secrets.SLACK_BOT_TOKEN }}
    payload: |
      channel: ${{ secrets.SLACK_CHANNEL_ID }}
      text: "The previous step completed <!date^${{ steps.message.outputs.time }}^{date_num} at {time_secs}|just now>."
      thread_ts: "${{ steps.message.outputs.ts }}"
A response value is added with the response data

This Action now returns the JSON response value from Slack API requests.

Prior to change: Some response values were returned for conversation APIs.

Recommended change: Use the output response of one step as input to another for more complex workflows.


We're hoping the update goes well, but please do let us know if something seems off! 💌


Configuration

📅 Schedule: Branch creation - "* 0-3 * * 1" in timezone America/Chicago, Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

@renovate renovate bot requested a review from a team December 30, 2024 09:13
Copy link

coderabbitai bot commented Dec 30, 2024

Important

Review skipped

Bot user detected.

To trigger a single review, invoke the @coderabbitai review command.

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.


🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

github-actions bot commented Dec 30, 2024

🏗️ E2E / ts-no-cli-runner (#1776)  •  ➡️ View in Autoblocks


🟢  typescript-e2e-test-suite-1-no-cli-runner

Overall
Pass Rate 100.00% (+25.00%)
Passed 4 (+1.00)
Failed 0 (-1.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 1.00 (+1.00) 1.00 (+0.25) 1.00 (+0.00) 4 (+1) 0 (-1) 0 (+0)
is-friendly 0.06 (-0.23) 0.47 (-0.10) 0.80 (-0.06) 4 (+0) 0 (+0) 0 (+0)
Test Case Duration
Min 50.13ms (+33.86)
Avg 281.93ms (+49.65)
Max 688.32ms (+110.83)

 
 
🔴  typescript-e2e-test-suite-2-no-cli-runner

Overall
Pass Rate 70.00% (+0.00%)
Passed 7 (+0.00)
Failed 3 (+0.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (+0.00) 0.70 (+0.00) 1.00 (+0.00) 7 (+0) 3 (+0) 0 (+0)
is-friendly 0.09 (+0.07) 0.60 (+0.26) 0.99 (+0.29) 10 (+0) 0 (+0) 0 (+0)
Test Case Duration
Min 111.47ms (-10.92)
Avg 444.93ms (+14.98)
Max 868.15ms (-5.07)

 
 

Generated by Autoblocks against a82267b

Copy link

github-actions bot commented Dec 30, 2024

🏗️ E2E / ts (#1776)  •  ➡️ View in Autoblocks


🔴  typescript-e2e-test-suite-1-with-cli-runner

Overall
Pass Rate 50.00% (-50.00%)
Passed 2 (-2.00)
Failed 2 (+2.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (-1.00) 0.50 (-0.50) 1.00 (+0.00) 2 (-2) 2 (+2) 0 (+0)
is-friendly 0.42 (+0.31) 0.62 (+0.14) 0.87 (+0.04) 4 (+0) 0 (+0) 0 (+0)
Test Case Duration
Min 198.51ms (+68.12)
Avg 504.12ms (+24.55)
Max 627.91ms (-297.85)

 
 
🔴  typescript-e2e-test-suite-2-with-cli-runner

Overall
Pass Rate 90.00% (+30.00%)
Passed 9 (+3.00)
Failed 1 (-3.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (+0.00) 0.90 (+0.30) 1.00 (+0.00) 9 (+3) 1 (-3) 0 (+0)
is-friendly 0.08 (+0.04) 0.47 (+0.09) 0.99 (+0.13) 10 (+0) 0 (+0) 0 (+0)
Test Case Duration
Min 34.55ms (+0.01)
Avg 466.2ms (-1.58)
Max 817.86ms (-77.47)

 
 

Generated by Autoblocks against a82267b

Copy link

github-actions bot commented Dec 30, 2024

🏗️ E2E / py (#1775)  •  ➡️ View in Autoblocks


🔴  python-e2e-test-suite-1-with-cli-runner    x = "x2"  y = "y1"

Overall
Pass Rate 75.00% (-25.00%)
Passed 3 (-1.00)
Failed 1 (+1.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (-1.00) 0.75 (-0.25) 1.00 (+0.00) 3 (-1) 1 (+1) 0 (+0)
is-friendly 0.06 (-0.09) 0.51 (+0.15) 0.96 (+0.40) 4 (+1) 0 (+0) 0 (-1)
Test Case Duration
Min 303.2ms (+116.69)
Avg 313.61ms (-217.53)
Max 334.19ms (-622.81)

 
 
🟢  python-e2e-test-suite-1-with-cli-runner    x = "x1"  y = "y1"

Overall
Pass Rate 100.00% (+0.00%)
Passed 4 (+0.00)
Failed 0 (+0.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 1.00 (+0.00) 1.00 (+0.00) 1.00 (+0.00) 4 (+0) 0 (+0) 0 (+0)
is-friendly 0.38 (+0.23) 0.63 (+0.27) 0.87 (+0.31) 4 (+1) 0 (+0) 0 (-1)
Test Case Duration
Min 45.18ms (-141.33)
Avg 594.67ms (+63.53)
Max 950.34ms (-6.66)

 
 
🔴  python-e2e-test-suite-2-with-cli-runner

Overall
Pass Rate 80.00% (+0.00%)
Passed 8 (+0.00)
Failed 2 (+0.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (+0.00) 0.80 (+0.00) 1.00 (+0.00) 8 (+0) 2 (+0) 0 (+0)
is-friendly 0.20 (+0.16) 0.69 (+0.42) 1.00 (+0.26) 8 (+0) 0 (+0) 2 (+0)
Test Case Duration
Min 99.25ms (+19.99)
Avg 452.41ms (+38.07)
Max 980.53ms (+76.15)

 
 

Generated by Autoblocks against a82267b

Copy link

github-actions bot commented Dec 30, 2024

🏗️ E2E / py-no-cli-runner (#1775)  •  ➡️ View in Autoblocks


🔴  python-e2e-test-suite-1-no-cli-runner    x = "x1"  y = "y1"

Overall
Pass Rate 75.00% (-25.00%)
Passed 3 (-1.00)
Failed 1 (+1.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (-1.00) 0.75 (-0.25) 1.00 (+0.00) 3 (-1) 1 (+1) 0 (+0)
is-friendly 0.66 (+0.46) 0.76 (+0.22) 0.87 (-0.02) 2 (-2) 0 (+0) 2 (+2)
Test Case Duration
Min 592.58ms (+497.32)
Avg 706.66ms (+165.3)
Max 815.86ms (-45.22)

 
 
🔴  python-e2e-test-suite-1-no-cli-runner    x = "x2"  y = "y1"

Overall
Pass Rate 75.00% (-25.00%)
Passed 3 (-1.00)
Failed 1 (+1.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 0.00 (-1.00) 0.75 (-0.25) 1.00 (+0.00) 3 (-1) 1 (+1) 0 (+0)
is-friendly 0.31 (+0.11) 0.52 (-0.02) 0.90 (+0.00) 4 (+0) 0 (+0) 0 (+0)
Test Case Duration
Min 95.3ms (+0.04)
Avg 432.47ms (-108.89)
Max 900.29ms (+39.2)

 
 
🟢  python-e2e-test-suite-2-no-cli-runner

Overall
Pass Rate 100.00% (+20.00%)
Passed 10 (+2.00)
Failed 0 (-2.00)
Evaluator ID Min Score Avg Score Max Score Passed Failed Skipped
has-all-substrings 1.00 (+1.00) 1.00 (+0.20) 1.00 (+0.00) 10 (+2) 0 (-2) 0 (+0)
is-friendly 0.01 (+0.01) 0.48 (+0.10) 0.98 (-0.00) 6 (-2) 0 (+0) 4 (+2)
Test Case Duration
Min 27.23ms (-96.05)
Avg 374.35ms (-30.25)
Max 934.56ms (+60.68)

 
 

Generated by Autoblocks against a82267b

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants