Skip to content

Commit

Permalink
Merge pull request #215 from BlakeWilliams/acc-add-chat-schedule-msg
Browse files Browse the repository at this point in the history
Adds support for scheduling messages in Slack Web API
  • Loading branch information
acconrad authored Feb 25, 2020
2 parents c6b9824 + 2a8b06a commit b1bf16b
Show file tree
Hide file tree
Showing 3 changed files with 129 additions and 2 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ def application do
end

def deps do
[{:slack, "~> 0.21.0"}]
[{:slack, "~> 0.21.1"}]
end
```

Expand Down
127 changes: 127 additions & 0 deletions lib/slack/web/docs/chat.scheduleMessage.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,127 @@
{
"desc": "Schedules a message to be sent to a channel.",

"args": {
"token": {
"required": true,
"example": "xxxx-xxxxxxxxx-xxxx",
"desc": "Authentication token bearing required scopes."
},
"channel": {
"required": true,
"example": "C1234567890",
"desc": "Channel, private group, or DM channel to send message to. Can be an encoded ID, or a name."
},
"post_at": {
"required": true,
"example": "299876400",
"desc": "Unix EPOCH timestamp of time in future to send the message."
},
"as_user": {
"required": false,
"example": "true",
"desc": "Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See `chat.postMessage`."
},
"attachments": {
"required": false,
"example": "[{\"pretext\": \"pre-hello\", \"text\": \"text-world\"}]",
"desc": "A JSON-based array of structured attachments, presented as a URL-encoded string."
},
"blocks": {
"required": false,
"example": "[{\"type\": \"section\", \"text\": {\"type\": \"plain_text\", \"text\": \"Hello world\"}}]",
"desc": "A JSON-based array of structured blocks, presented as a URL-encoded string."
},
"link_names": {
"required": false,
"example": "true",
"desc": "Find and link channel names and usernames."
},
"parse": {
"required": false,
"example": "full",
"desc": "Change how messages are treated. Defaults to none. See `chat.postMessage`."
},
"reply_broadcast": {
"required": false,
"example": "true",
"desc": "Used in conjunction with `thread_ts` and indicates whether reply should be made visible to everyone in the channel or conversation. Defaults to `false`."
},
"thread_ts": {
"required": false,
"example": "1234567890.123456",
"desc": "Provide another message's `ts` value to make this message a reply. Avoid using a reply's `ts` value; use its parent instead."
},
"unfurl_links": {
"required": false,
"example": "true",
"desc": "Pass true to enable unfurling of primarily text-based content."
},
"unfurl_media": {
"required": false,
"example": "false",
"desc": "Pass false to disable unfurling of media content."
}
},

"response": {
"ok": true,
"channel": "C1H9RESGL",
"scheduled_message_id": "Q1298393284",
"post_at": "1562180400",
"message": {
"text": "Here's a message for you in the future",
"username": "ecto1",
"bot_id": "B19LU7CSY",
"attachments": [
{
"text": "This is an attachment",
"id": 1,
"fallback": "This is an attachment's fallback"
}
],
"type": "delayed_message",
"subtype": "bot_message"
}
},

"errors": {
"invalid_time" : "value passed for `post_time` was invalid.",
"time_in_past" : "value passed for `post_time` was in the past.",
"time_too_far": "value passed for `post_time` was too far into the future.",
"channel_not_found": "Value passed for `channel` was invalid.",
"not_in_channel": "Cannot post user messages to a channel they are not in.",
"is_archived": "Channel has been archived.",
"msg_too_long": "Message text is too long",
"no_text": "No message text provided",
"restricted_action": "A workspace preference prevents the authenticated user from posting.",
"restricted_action_read_only_channel": "Cannot post any message into a read-only channel.",
"restricted_action_thread_only_channel": "Cannot post top-level messages into a thread-only channel.",
"restricted_action_non_threadable_channel": "Cannot post thread replies into a non_threadable channel.",
"too_many_attachments": "Too many attachments were provided with this message. A maximum of 100 attachments are allowed on a message.",
"rate_limited": "Application has posted too many messages, read the Rate Limit documentation for more information",
"not_authed": "No authentication token provided.",
"invalid_auth": "Some aspect of authentication cannot be validated. Either the provided token is invalid or the request originates from an IP address disallowed from making the request.",
"account_inactive": "Authentication token is for a deleted user or workspace.",
"token_revoked": "Authentication token is for a deleted user or workspace or the app has been removed.",
"no_permission": "The workspace token used in this request does not have the permissions necessary to complete the request. Make sure your app is a member of the conversation it's attempting to post a message to.",
"org_login_required": "The workspace is undergoing an enterprise migration and will not be available until migration is complete.",
"ekm_access_denied": "Administrators have suspended the ability to post a message.",
"missing_scope": "The token used is not granted the specific scope permissions required to complete this request.",
"invalid_arguments": "The method was called with invalid arguments.",
"invalid_arg_name": "The method was passed an argument whose name falls outside the bounds of accepted or expected values. This includes very long names and names with non-alphanumeric characters other than _. If you get this error, it is typically an indication that you have made a very malformed API call.",
"invalid_charset": "The method was called via a `POST` request, but the `charset` specified in the `Content-Type` header was invalid. Valid charset names are: `utf-8` `iso-8859-1`.",
"invalid_form_data": "The method was called via a `POST` request with `Content-Type` `application/x-www-form-urlencoded` or `multipart/form-data`, but the form data was either missing or syntactically invalid.",
"invalid_post_type": "The method was called via a `POST` request, but the specified `Content-Type` was invalid. Valid types are: `application/json` `application/x-www-form-urlencoded` `multipart/form-data` `text/plain`.",
"missing_post_type": "The method was called via a `POST` request and included a data payload, but the request did not include a `Content-Type` header.",
"team_added_to_org": "The workspace associated with your request is currently undergoing migration to an Enterprise Organization. Web API and other platform operations will be intermittently unavailable until the transition is complete.",
"request_timeout": "The method was called via a `POST` request, but the `POST` data was either missing or truncated.",
"fatal_error": "The server could not complete your operation(s) without encountering a catastrophic error. It's possible some aspect of the operation succeeded before the error was raised."
},

"warnings": {
"message_truncated": "The `text` field of a message should have no more than 40,000 characters. We truncate really long messages.",
"missing_charset": "The method was called via a `POST` request, and recommended practice for the specified `Content-Type` is to include a `charset` parameter. However, no `charset` was present. Specifically, non-form-data content types (e.g. `text/plain`) are the ones for which `charset` is recommended.",
"superfluous_charset": "The method was called via a `POST` request, and the specified `Content-Type` is not defined to understand the `charset` parameter. However, `charset` was in fact present. Specifically, form-data content types (e.g. `multipart/form-data`) are the ones for which `charset` is superfluous."
}
}
2 changes: 1 addition & 1 deletion mix.exs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ defmodule Slack.Mixfile do
def project do
[
app: :slack,
version: "0.21.0",
version: "0.21.1",
elixir: "~> 1.6",
elixirc_paths: elixirc_paths(Mix.env()),
name: "Slack",
Expand Down

0 comments on commit b1bf16b

Please sign in to comment.