Module slack_sdk.web.async_client
A Python module for interacting with Slack's Web API.
Expand source code
# !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
#
# *** DO NOT EDIT THIS FILE ***
#
# 1) Modify slack_sdk/web/client.py
# 2) Run `python setup.py codegen`
#
# !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
"""A Python module for interacting with Slack's Web API."""
import json
import os
import warnings
from io import IOBase
from typing import Union, Sequence, Optional, Dict, Tuple, Any, List
import slack_sdk.errors as e
from slack_sdk.models.views import View
from .async_base_client import AsyncBaseClient, AsyncSlackResponse
from .internal_utils import (
_parse_web_class_objects,
_update_call_participants,
_warn_if_text_or_attachment_fallback_is_missing,
_remove_none_values,
_to_v2_file_upload_item,
_upload_file_via_v2_url,
_attach_full_file_metadata_async,
_validate_for_legacy_client,
_print_files_upload_v2_suggestion,
)
from ..models.attachments import Attachment
from ..models.blocks import Block
from ..models.metadata import Metadata
class AsyncWebClient(AsyncBaseClient):
"""A WebClient allows apps to communicate with the Slack Platform's Web API.
https://api.slack.com/methods
The Slack Web API is an interface for querying information from
and enacting change in a Slack workspace.
This client handles constructing and sending HTTP requests to Slack
as well as parsing any responses received into a `SlackResponse`.
Attributes:
token (str): A string specifying an `xoxp-*` or `xoxb-*` token.
base_url (str): A string representing the Slack API base URL.
Default is `'https://www.slack.com/api/'`
timeout (int): The maximum number of seconds the client will wait
to connect and receive a response from Slack.
Default is 30 seconds.
ssl (SSLContext): An [`ssl.SSLContext`][1] instance, helpful for specifying
your own custom certificate chain.
proxy (str): String representing a fully-qualified URL to a proxy through
which to route all requests to the Slack API. Even if this parameter
is not specified, if any of the following environment variables are
present, they will be loaded into this parameter: `HTTPS_PROXY`,
`https_proxy`, `HTTP_PROXY` or `http_proxy`.
headers (dict): Additional request headers to attach to all requests.
Methods:
`api_call`: Constructs a request and executes the API call to Slack.
Example of recommended usage:
```python
import os
from slack_sdk.web.async_client import AsyncWebClient
client = AsyncWebClient(token=os.environ['SLACK_API_TOKEN'])
response = client.chat_postMessage(
channel='#random',
text="Hello world!")
assert response["ok"]
assert response["message"]["text"] == "Hello world!"
```
Example manually creating an API request:
```python
import os
from slack_sdk.web.async_client import AsyncWebClient
client = AsyncWebClient(token=os.environ['SLACK_API_TOKEN'])
response = client.api_call(
api_method='chat.postMessage',
json={'channel': '#random','text': "Hello world!"}
)
assert response["ok"]
assert response["message"]["text"] == "Hello world!"
```
Note:
Any attributes or methods prefixed with _underscores are
intended to be "private" internal use only. They may be changed or
removed at anytime.
[1]: https://docs.python.org/3/library/ssl.html#ssl.SSLContext
"""
async def admin_analytics_getFile(
self,
*,
type: str,
date: Optional[str] = None,
metadata_only: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve analytics data for a given date, presented as a compressed JSON file
https://api.slack.com/methods/admin.analytics.getFile
"""
kwargs.update({"type": type})
if date is not None:
kwargs.update({"date": date})
if metadata_only is not None:
kwargs.update({"metadata_only": metadata_only})
return await self.api_call("admin.analytics.getFile", params=kwargs)
async def admin_apps_approve(
self,
*,
app_id: Optional[str] = None,
request_id: Optional[str] = None,
enterprise_id: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Approve an app for installation on a workspace.
Either app_id or request_id is required.
These IDs can be obtained either directly via the app_requested event,
or by the admin.apps.requests.list method.
https://api.slack.com/methods/admin.apps.approve
"""
if app_id:
kwargs.update({"app_id": app_id})
elif request_id:
kwargs.update({"request_id": request_id})
else:
raise e.SlackRequestError("The app_id or request_id argument must be specified.")
kwargs.update(
{
"enterprise_id": enterprise_id,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.approve", params=kwargs)
async def admin_apps_approved_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
enterprise_id: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List approved apps for an org or workspace.
https://api.slack.com/methods/admin.apps.approved.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"enterprise_id": enterprise_id,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.approved.list", http_verb="GET", params=kwargs)
async def admin_apps_clearResolution(
self,
*,
app_id: str,
enterprise_id: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Clear an app resolution
https://api.slack.com/methods/admin.apps.clearResolution
"""
kwargs.update(
{
"app_id": app_id,
"enterprise_id": enterprise_id,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.clearResolution", http_verb="POST", params=kwargs)
async def admin_apps_requests_cancel(
self,
*,
request_id: str,
enterprise_id: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List app requests for a team/workspace.
https://api.slack.com/methods/admin.apps.requests.cancel
"""
kwargs.update(
{
"request_id": request_id,
"enterprise_id": enterprise_id,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.requests.cancel", http_verb="POST", params=kwargs)
async def admin_apps_requests_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List app requests for a team/workspace.
https://api.slack.com/methods/admin.apps.requests.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.requests.list", http_verb="GET", params=kwargs)
async def admin_apps_restrict(
self,
*,
app_id: Optional[str] = None,
request_id: Optional[str] = None,
enterprise_id: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Restrict an app for installation on a workspace.
Exactly one of the team_id or enterprise_id arguments is required, not both.
Either app_id or request_id is required. These IDs can be obtained either directly
via the app_requested event, or by the admin.apps.requests.list method.
https://api.slack.com/methods/admin.apps.restrict
"""
if app_id:
kwargs.update({"app_id": app_id})
elif request_id:
kwargs.update({"request_id": request_id})
else:
raise e.SlackRequestError("The app_id or request_id argument must be specified.")
kwargs.update(
{
"enterprise_id": enterprise_id,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.restrict", params=kwargs)
async def admin_apps_restricted_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
enterprise_id: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List restricted apps for an org or workspace.
https://api.slack.com/methods/admin.apps.restricted.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"enterprise_id": enterprise_id,
"team_id": team_id,
}
)
return await self.api_call("admin.apps.restricted.list", http_verb="GET", params=kwargs)
async def admin_apps_uninstall(
self,
*,
app_id: str,
enterprise_id: Optional[str] = None,
team_ids: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Uninstall an app from one or many workspaces, or an entire enterprise organization.
With an org-level token, enterprise_id or team_ids is required.
https://api.slack.com/methods/admin.apps.uninstall
"""
kwargs.update({"app_id": app_id})
if enterprise_id is not None:
kwargs.update({"enterprise_id": enterprise_id})
if team_ids is not None:
if isinstance(team_ids, (list, Tuple)):
kwargs.update({"team_ids": ",".join(team_ids)})
else:
kwargs.update({"team_ids": team_ids})
return await self.api_call("admin.apps.uninstall", http_verb="POST", params=kwargs)
async def admin_apps_activities_list(
self,
*,
app_id: Optional[str] = None,
component_id: Optional[str] = None,
component_type: Optional[str] = None,
log_event_type: Optional[str] = None,
max_date_created: Optional[int] = None,
min_date_created: Optional[int] = None,
min_log_level: Optional[str] = None,
sort_direction: Optional[str] = None,
source: Optional[str] = None,
team_id: Optional[str] = None,
trace_id: Optional[str] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Get logs for a specified team/org
https://api.slack.com/methods/admin.apps.activities.list
"""
kwargs.update(
{
"app_id": app_id,
"component_id": component_id,
"component_type": component_type,
"log_event_type": log_event_type,
"max_date_created": max_date_created,
"min_date_created": min_date_created,
"min_log_level": min_log_level,
"sort_direction": sort_direction,
"source": source,
"team_id": team_id,
"trace_id": trace_id,
"cursor": cursor,
"limit": limit,
}
)
return await self.api_call("admin.apps.activities.list", params=kwargs)
async def admin_apps_config_lookup(
self,
*,
app_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Look up the app config for connectors by their IDs
https://api.slack.com/methods/admin.apps.config.lookup
"""
if isinstance(app_ids, (list, Tuple)):
kwargs.update({"app_ids": ",".join(app_ids)})
else:
kwargs.update({"app_ids": app_ids})
return await self.api_call("admin.apps.config.lookup", params=kwargs)
async def admin_apps_config_set(
self,
*,
app_id: str,
domain_restrictions: Optional[Dict[str, Any]] = None,
workflow_auth_strategy: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set the app config for a connector
https://api.slack.com/methods/admin.apps.config.set
"""
kwargs.update(
{
"app_id": app_id,
"workflow_auth_strategy": workflow_auth_strategy,
}
)
if domain_restrictions is not None:
kwargs.update({"domain_restrictions": json.dumps(domain_restrictions)})
return await self.api_call("admin.apps.config.set", params=kwargs)
async def admin_auth_policy_getEntities(
self,
*,
policy_name: str,
cursor: Optional[str] = None,
entity_type: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Fetch all the entities assigned to a particular authentication policy by name.
https://api.slack.com/methods/admin.auth.policy.getEntities
"""
kwargs.update({"policy_name": policy_name})
if cursor is not None:
kwargs.update({"cursor": cursor})
if entity_type is not None:
kwargs.update({"entity_type": entity_type})
if limit is not None:
kwargs.update({"limit": limit})
return await self.api_call("admin.auth.policy.getEntities", http_verb="POST", params=kwargs)
async def admin_auth_policy_assignEntities(
self,
*,
entity_ids: Union[str, Sequence[str]],
policy_name: str,
entity_type: str,
**kwargs,
) -> AsyncSlackResponse:
"""Assign entities to a particular authentication policy.
https://api.slack.com/methods/admin.auth.policy.assignEntities
"""
if isinstance(entity_ids, (list, Tuple)):
kwargs.update({"entity_ids": ",".join(entity_ids)})
else:
kwargs.update({"entity_ids": entity_ids})
kwargs.update({"policy_name": policy_name})
kwargs.update({"entity_type": entity_type})
return await self.api_call("admin.auth.policy.assignEntities", http_verb="POST", params=kwargs)
async def admin_auth_policy_removeEntities(
self,
*,
entity_ids: Union[str, Sequence[str]],
policy_name: str,
entity_type: str,
**kwargs,
) -> AsyncSlackResponse:
"""Remove specified entities from a specified authentication policy.
https://api.slack.com/methods/admin.auth.policy.removeEntities
"""
if isinstance(entity_ids, (list, Tuple)):
kwargs.update({"entity_ids": ",".join(entity_ids)})
else:
kwargs.update({"entity_ids": entity_ids})
kwargs.update({"policy_name": policy_name})
kwargs.update({"entity_type": entity_type})
return await self.api_call("admin.auth.policy.removeEntities", http_verb="POST", params=kwargs)
async def admin_barriers_create(
self,
*,
barriered_from_usergroup_ids: Union[str, Sequence[str]],
primary_usergroup_id: str,
restricted_subjects: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Create an Information Barrier
https://api.slack.com/methods/admin.barriers.create
"""
kwargs.update({"primary_usergroup_id": primary_usergroup_id})
if isinstance(barriered_from_usergroup_ids, (list, Tuple)):
kwargs.update({"barriered_from_usergroup_ids": ",".join(barriered_from_usergroup_ids)})
else:
kwargs.update({"barriered_from_usergroup_ids": barriered_from_usergroup_ids})
if isinstance(restricted_subjects, (list, Tuple)):
kwargs.update({"restricted_subjects": ",".join(restricted_subjects)})
else:
kwargs.update({"restricted_subjects": restricted_subjects})
return await self.api_call("admin.barriers.create", http_verb="POST", params=kwargs)
async def admin_barriers_delete(
self,
*,
barrier_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Delete an existing Information Barrier
https://api.slack.com/methods/admin.barriers.delete
"""
kwargs.update({"barrier_id": barrier_id})
return await self.api_call("admin.barriers.delete", http_verb="POST", params=kwargs)
async def admin_barriers_update(
self,
*,
barrier_id: str,
barriered_from_usergroup_ids: Union[str, Sequence[str]],
primary_usergroup_id: str,
restricted_subjects: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Update an existing Information Barrier
https://api.slack.com/methods/admin.barriers.update
"""
kwargs.update({"barrier_id": barrier_id, "primary_usergroup_id": primary_usergroup_id})
if isinstance(barriered_from_usergroup_ids, (list, Tuple)):
kwargs.update({"barriered_from_usergroup_ids": ",".join(barriered_from_usergroup_ids)})
else:
kwargs.update({"barriered_from_usergroup_ids": barriered_from_usergroup_ids})
if isinstance(restricted_subjects, (list, Tuple)):
kwargs.update({"restricted_subjects": ",".join(restricted_subjects)})
else:
kwargs.update({"restricted_subjects": restricted_subjects})
return await self.api_call("admin.barriers.update", http_verb="POST", params=kwargs)
async def admin_barriers_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Get all Information Barriers for your organization
https://api.slack.com/methods/admin.barriers.list"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
}
)
return await self.api_call("admin.barriers.list", http_verb="GET", params=kwargs)
async def admin_conversations_create(
self,
*,
is_private: bool,
name: str,
description: Optional[str] = None,
org_wide: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Create a public or private channel-based conversation.
https://api.slack.com/methods/admin.conversations.create
"""
kwargs.update(
{
"is_private": is_private,
"name": name,
"description": description,
"org_wide": org_wide,
"team_id": team_id,
}
)
return await self.api_call("admin.conversations.create", params=kwargs)
async def admin_conversations_delete(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Delete a public or private channel.
https://api.slack.com/methods/admin.conversations.delete
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.delete", params=kwargs)
async def admin_conversations_invite(
self,
*,
channel_id: str,
user_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Invite a user to a public or private channel.
https://api.slack.com/methods/admin.conversations.invite
"""
kwargs.update({"channel_id": channel_id})
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
# NOTE: the endpoint is unable to handle Content-Type: application/json as of Sep 3, 2020.
return await self.api_call("admin.conversations.invite", params=kwargs)
async def admin_conversations_archive(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Archive a public or private channel.
https://api.slack.com/methods/admin.conversations.archive
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.archive", params=kwargs)
async def admin_conversations_unarchive(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Unarchive a public or private channel.
https://api.slack.com/methods/admin.conversations.archive
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.unarchive", params=kwargs)
async def admin_conversations_rename(
self,
*,
channel_id: str,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Rename a public or private channel.
https://api.slack.com/methods/admin.conversations.rename
"""
kwargs.update({"channel_id": channel_id, "name": name})
return await self.api_call("admin.conversations.rename", params=kwargs)
async def admin_conversations_search(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
query: Optional[str] = None,
search_channel_types: Optional[Union[str, Sequence[str]]] = None,
sort: Optional[str] = None,
sort_dir: Optional[str] = None,
team_ids: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Search for public or private channels in an Enterprise organization.
https://api.slack.com/methods/admin.conversations.search
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"query": query,
"sort": sort,
"sort_dir": sort_dir,
}
)
if isinstance(search_channel_types, (list, Tuple)):
kwargs.update({"search_channel_types": ",".join(search_channel_types)})
else:
kwargs.update({"search_channel_types": search_channel_types})
if isinstance(team_ids, (list, Tuple)):
kwargs.update({"team_ids": ",".join(team_ids)})
else:
kwargs.update({"team_ids": team_ids})
return await self.api_call("admin.conversations.search", params=kwargs)
async def admin_conversations_convertToPrivate(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Convert a public channel to a private channel.
https://api.slack.com/methods/admin.conversations.convertToPrivate
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.convertToPrivate", params=kwargs)
async def admin_conversations_convertToPublic(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Convert a privte channel to a public channel.
https://api.slack.com/methods/admin.conversations.convertToPublic
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.convertToPublic", params=kwargs)
async def admin_conversations_setConversationPrefs(
self,
*,
channel_id: str,
prefs: Union[str, Dict[str, str]],
**kwargs,
) -> AsyncSlackResponse:
"""Set the posting permissions for a public or private channel.
https://api.slack.com/methods/admin.conversations.setConversationPrefs
"""
kwargs.update({"channel_id": channel_id})
if isinstance(prefs, dict):
kwargs.update({"prefs": json.dumps(prefs)})
else:
kwargs.update({"prefs": prefs})
return await self.api_call("admin.conversations.setConversationPrefs", params=kwargs)
async def admin_conversations_getConversationPrefs(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Get conversation preferences for a public or private channel.
https://api.slack.com/methods/admin.conversations.getConversationPrefs
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.getConversationPrefs", params=kwargs)
async def admin_conversations_disconnectShared(
self,
*,
channel_id: str,
leaving_team_ids: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Disconnect a connected channel from one or more workspaces.
https://api.slack.com/methods/admin.conversations.disconnectShared
"""
kwargs.update({"channel_id": channel_id})
if isinstance(leaving_team_ids, (list, Tuple)):
kwargs.update({"leaving_team_ids": ",".join(leaving_team_ids)})
else:
kwargs.update({"leaving_team_ids": leaving_team_ids})
return await self.api_call("admin.conversations.disconnectShared", params=kwargs)
async def admin_conversations_lookup(
self,
*,
last_message_activity_before: int,
team_ids: Union[str, Sequence[str]],
cursor: Optional[str] = None,
limit: Optional[int] = None,
max_member_count: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Returns channels on the given team using the filters.
https://api.slack.com/methods/admin.conversations.lookup
"""
kwargs.update(
{
"last_message_activity_before": last_message_activity_before,
"cursor": cursor,
"limit": limit,
"max_member_count": max_member_count,
}
)
if isinstance(team_ids, (list, Tuple)):
kwargs.update({"team_ids": ",".join(team_ids)})
else:
kwargs.update({"team_ids": team_ids})
return await self.api_call("admin.conversations.lookup", params=kwargs)
async def admin_conversations_ekm_listOriginalConnectedChannelInfo(
self,
*,
channel_ids: Optional[Union[str, Sequence[str]]] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
team_ids: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all disconnected channels—i.e.,
channels that were once connected to other workspaces and then disconnected—and
the corresponding original channel IDs for key revocation with EKM.
https://api.slack.com/methods/admin.conversations.ekm.listOriginalConnectedChannelInfo
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
}
)
if isinstance(channel_ids, (list, Tuple)):
kwargs.update({"channel_ids": ",".join(channel_ids)})
else:
kwargs.update({"channel_ids": channel_ids})
if isinstance(team_ids, (list, Tuple)):
kwargs.update({"team_ids": ",".join(team_ids)})
else:
kwargs.update({"team_ids": team_ids})
return await self.api_call("admin.conversations.ekm.listOriginalConnectedChannelInfo", params=kwargs)
async def admin_conversations_restrictAccess_addGroup(
self,
*,
channel_id: str,
group_id: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Add an allowlist of IDP groups for accessing a channel.
https://api.slack.com/methods/admin.conversations.restrictAccess.addGroup
"""
kwargs.update(
{
"channel_id": channel_id,
"group_id": group_id,
"team_id": team_id,
}
)
return await self.api_call(
"admin.conversations.restrictAccess.addGroup",
http_verb="GET",
params=kwargs,
)
async def admin_conversations_restrictAccess_listGroups(
self,
*,
channel_id: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all IDP Groups linked to a channel.
https://api.slack.com/methods/admin.conversations.restrictAccess.listGroups
"""
kwargs.update(
{
"channel_id": channel_id,
"team_id": team_id,
}
)
return await self.api_call(
"admin.conversations.restrictAccess.listGroups",
http_verb="GET",
params=kwargs,
)
async def admin_conversations_restrictAccess_removeGroup(
self,
*,
channel_id: str,
group_id: str,
team_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Remove a linked IDP group linked from a private channel.
https://api.slack.com/methods/admin.conversations.restrictAccess.removeGroup
"""
kwargs.update(
{
"channel_id": channel_id,
"group_id": group_id,
"team_id": team_id,
}
)
return await self.api_call(
"admin.conversations.restrictAccess.removeGroup",
http_verb="GET",
params=kwargs,
)
async def admin_conversations_setTeams(
self,
*,
channel_id: str,
org_channel: Optional[bool] = None,
target_team_ids: Optional[Union[str, Sequence[str]]] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set the workspaces in an Enterprise grid org that connect to a public or private channel.
https://api.slack.com/methods/admin.conversations.setTeams
"""
kwargs.update(
{
"channel_id": channel_id,
"org_channel": org_channel,
"team_id": team_id,
}
)
if isinstance(target_team_ids, (list, Tuple)):
kwargs.update({"target_team_ids": ",".join(target_team_ids)})
else:
kwargs.update({"target_team_ids": target_team_ids})
return await self.api_call("admin.conversations.setTeams", params=kwargs)
async def admin_conversations_getTeams(
self,
*,
channel_id: str,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set the workspaces in an Enterprise grid org that connect to a channel.
https://api.slack.com/methods/admin.conversations.getTeams
"""
kwargs.update(
{
"channel_id": channel_id,
"cursor": cursor,
"limit": limit,
}
)
return await self.api_call("admin.conversations.getTeams", params=kwargs)
async def admin_conversations_getCustomRetention(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Get a channel's retention policy
https://api.slack.com/methods/admin.conversations.getCustomRetention
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.getCustomRetention", params=kwargs)
async def admin_conversations_removeCustomRetention(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Remove a channel's retention policy
https://api.slack.com/methods/admin.conversations.removeCustomRetention
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("admin.conversations.removeCustomRetention", params=kwargs)
async def admin_conversations_setCustomRetention(
self,
*,
channel_id: str,
duration_days: int,
**kwargs,
) -> AsyncSlackResponse:
"""Set a channel's retention policy
https://api.slack.com/methods/admin.conversations.setCustomRetention
"""
kwargs.update({"channel_id": channel_id, "duration_days": duration_days})
return await self.api_call("admin.conversations.setCustomRetention", params=kwargs)
async def admin_conversations_bulkArchive(
self,
*,
channel_ids: Union[Sequence[str], str],
**kwargs,
) -> AsyncSlackResponse:
"""Archive public or private channels in bulk.
https://api.slack.com/methods/admin.conversations.bulkArchive
"""
kwargs.update({"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids})
return await self.api_call("admin.conversations.bulkArchive", params=kwargs)
async def admin_conversations_bulkDelete(
self,
*,
channel_ids: Union[Sequence[str], str],
**kwargs,
) -> AsyncSlackResponse:
"""Delete public or private channels in bulk.
https://slack.com/api/admin.conversations.bulkDelete
"""
kwargs.update({"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids})
return await self.api_call("admin.conversations.bulkDelete", params=kwargs)
async def admin_conversations_bulkMove(
self,
*,
channel_ids: Union[Sequence[str], str],
target_team_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Move public or private channels in bulk.
https://api.slack.com/methods/admin.conversations.bulkMove
"""
kwargs.update(
{
"target_team_id": target_team_id,
"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids,
}
)
return await self.api_call("admin.conversations.bulkMove", params=kwargs)
async def admin_emoji_add(
self,
*,
name: str,
url: str,
**kwargs,
) -> AsyncSlackResponse:
"""Add an emoji.
https://api.slack.com/methods/admin.emoji.add
"""
kwargs.update({"name": name, "url": url})
return await self.api_call("admin.emoji.add", http_verb="GET", params=kwargs)
async def admin_emoji_addAlias(
self,
*,
alias_for: str,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Add an emoji alias.
https://api.slack.com/methods/admin.emoji.addAlias
"""
kwargs.update({"alias_for": alias_for, "name": name})
return await self.api_call("admin.emoji.addAlias", http_verb="GET", params=kwargs)
async def admin_emoji_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List emoji for an Enterprise Grid organization.
https://api.slack.com/methods/admin.emoji.list
"""
kwargs.update({"cursor": cursor, "limit": limit})
return await self.api_call("admin.emoji.list", http_verb="GET", params=kwargs)
async def admin_emoji_remove(
self,
*,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Remove an emoji across an Enterprise Grid organization.
https://api.slack.com/methods/admin.emoji.remove
"""
kwargs.update({"name": name})
return await self.api_call("admin.emoji.remove", http_verb="GET", params=kwargs)
async def admin_emoji_rename(
self,
*,
name: str,
new_name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Rename an emoji.
https://api.slack.com/methods/admin.emoji.rename
"""
kwargs.update({"name": name, "new_name": new_name})
return await self.api_call("admin.emoji.rename", http_verb="GET", params=kwargs)
async def admin_functions_list(
self,
*,
app_ids: Union[str, Sequence[str]],
team_id: Optional[str] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Look up functions by a set of apps
https://api.slack.com/methods/admin.functions.list
"""
if isinstance(app_ids, (list, Tuple)):
kwargs.update({"app_ids": ",".join(app_ids)})
else:
kwargs.update({"app_ids": app_ids})
kwargs.update(
{
"team_id": team_id,
"cursor": cursor,
"limit": limit,
}
)
return await self.api_call("admin.functions.list", params=kwargs)
async def admin_functions_permissions_lookup(
self,
*,
function_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Lookup the visibility of multiple Slack functions
and include the users if it is limited to particular named entities.
https://api.slack.com/methods/admin.functions.permissions.lookup
"""
if isinstance(function_ids, (list, Tuple)):
kwargs.update({"function_ids": ",".join(function_ids)})
else:
kwargs.update({"function_ids": function_ids})
return await self.api_call("admin.functions.permissions.lookup", params=kwargs)
async def admin_functions_permissions_set(
self,
*,
function_id: str,
visibility: str,
user_ids: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set the visibility of a Slack function
and define the users or workspaces if it is set to named_entities
https://api.slack.com/methods/admin.functions.permissions.set
"""
kwargs.update(
{
"function_id": function_id,
"visibility": visibility,
}
)
if user_ids is not None:
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
return await self.api_call("admin.functions.permissions.set", params=kwargs)
async def admin_roles_addAssignments(
self,
*,
role_id: str,
entity_ids: Union[str, Sequence[str]],
user_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Adds members to the specified role with the specified scopes
https://api.slack.com/methods/admin.roles.addAssignments
"""
kwargs.update({"role_id": role_id})
if isinstance(entity_ids, (list, Tuple)):
kwargs.update({"entity_ids": ",".join(entity_ids)})
else:
kwargs.update({"entity_ids": entity_ids})
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
return await self.api_call("admin.roles.addAssignments", params=kwargs)
async def admin_roles_listAssignments(
self,
*,
role_ids: Optional[Union[str, Sequence[str]]] = None,
entity_ids: Optional[Union[str, Sequence[str]]] = None,
cursor: Optional[str] = None,
limit: Optional[Union[str, int]] = None,
sort_dir: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists assignments for all roles across entities.
Options to scope results by any combination of roles or entities
https://api.slack.com/methods/admin.roles.listAssignments
"""
kwargs.update({"cursor": cursor, "limit": limit, "sort_dir": sort_dir})
if isinstance(entity_ids, (list, Tuple)):
kwargs.update({"entity_ids": ",".join(entity_ids)})
else:
kwargs.update({"entity_ids": entity_ids})
if isinstance(role_ids, (list, Tuple)):
kwargs.update({"role_ids": ",".join(role_ids)})
else:
kwargs.update({"role_ids": role_ids})
return await self.api_call("admin.roles.listAssignments", params=kwargs)
async def admin_roles_removeAssignments(
self,
*,
role_id: str,
entity_ids: Union[str, Sequence[str]],
user_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Removes a set of users from a role for the given scopes and entities
https://api.slack.com/methods/admin.roles.removeAssignments
"""
kwargs.update({"role_id": role_id})
if isinstance(entity_ids, (list, Tuple)):
kwargs.update({"entity_ids": ",".join(entity_ids)})
else:
kwargs.update({"entity_ids": entity_ids})
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
return await self.api_call("admin.roles.removeAssignments", params=kwargs)
async def admin_users_session_reset(
self,
*,
user_id: str,
mobile_only: Optional[bool] = None,
web_only: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Wipes all valid sessions on all devices for a given user.
https://api.slack.com/methods/admin.users.session.reset
"""
kwargs.update(
{
"user_id": user_id,
"mobile_only": mobile_only,
"web_only": web_only,
}
)
return await self.api_call("admin.users.session.reset", params=kwargs)
async def admin_users_session_resetBulk(
self,
*,
user_ids: Union[str, Sequence[str]],
mobile_only: Optional[bool] = None,
web_only: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Enqueues an asynchronous job to wipe all valid sessions on all devices for a given list of users
https://api.slack.com/methods/admin.users.session.resetBulk
"""
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
kwargs.update(
{
"mobile_only": mobile_only,
"web_only": web_only,
}
)
return await self.api_call("admin.users.session.resetBulk", params=kwargs)
async def admin_users_session_invalidate(
self,
*,
session_id: str,
team_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Invalidate a single session for a user by session_id.
https://api.slack.com/methods/admin.users.session.invalidate
"""
kwargs.update({"session_id": session_id, "team_id": team_id})
return await self.api_call("admin.users.session.invalidate", params=kwargs)
async def admin_users_session_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
user_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists all active user sessions for an organization
https://api.slack.com/methods/admin.users.session.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"team_id": team_id,
"user_id": user_id,
}
)
return await self.api_call("admin.users.session.list", params=kwargs)
async def admin_teams_settings_setDefaultChannels(
self,
*,
team_id: str,
channel_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Set the default channels of a workspace.
https://api.slack.com/methods/admin.teams.settings.setDefaultChannels
"""
kwargs.update({"team_id": team_id})
if isinstance(channel_ids, (list, Tuple)):
kwargs.update({"channel_ids": ",".join(channel_ids)})
else:
kwargs.update({"channel_ids": channel_ids})
return await self.api_call("admin.teams.settings.setDefaultChannels", http_verb="GET", params=kwargs)
async def admin_users_session_getSettings(
self,
*,
user_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Get user-specific session settings—the session duration
and what happens when the client closes—given a list of users.
https://api.slack.com/methods/admin.users.session.getSettings
"""
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
return await self.api_call("admin.users.session.getSettings", params=kwargs)
async def admin_users_session_setSettings(
self,
*,
user_ids: Union[str, Sequence[str]],
desktop_app_browser_quit: Optional[bool] = None,
duration: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Configure the user-level session settings—the session duration
and what happens when the client closes—for one or more users.
https://api.slack.com/methods/admin.users.session.setSettings
"""
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
kwargs.update(
{
"desktop_app_browser_quit": desktop_app_browser_quit,
"duration": duration,
}
)
return await self.api_call("admin.users.session.setSettings", params=kwargs)
async def admin_users_session_clearSettings(
self,
*,
user_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Clear user-specific session settings—the session duration
and what happens when the client closes—for a list of users.
https://api.slack.com/methods/admin.users.session.clearSettings
"""
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
return await self.api_call("admin.users.session.clearSettings", params=kwargs)
async def admin_users_unsupportedVersions_export(
self,
*,
date_end_of_support: Optional[Union[str, int]] = None,
date_sessions_started: Optional[Union[str, int]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Ask Slackbot to send you an export listing all workspace members using unsupported software,
presented as a zipped CSV file.
https://api.slack.com/methods/admin.users.unsupportedVersions.export
"""
kwargs.update(
{
"date_end_of_support": date_end_of_support,
"date_sessions_started": date_sessions_started,
}
)
return await self.api_call("admin.users.unsupportedVersions.export", params=kwargs)
async def admin_inviteRequests_approve(
self,
*,
invite_request_id: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Approve a workspace invite request.
https://api.slack.com/methods/admin.inviteRequests.approve
"""
kwargs.update({"invite_request_id": invite_request_id, "team_id": team_id})
return await self.api_call("admin.inviteRequests.approve", params=kwargs)
async def admin_inviteRequests_approved_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all approved workspace invite requests.
https://api.slack.com/methods/admin.inviteRequests.approved.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"team_id": team_id,
}
)
return await self.api_call("admin.inviteRequests.approved.list", params=kwargs)
async def admin_inviteRequests_denied_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all denied workspace invite requests.
https://api.slack.com/methods/admin.inviteRequests.denied.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"team_id": team_id,
}
)
return await self.api_call("admin.inviteRequests.denied.list", params=kwargs)
async def admin_inviteRequests_deny(
self,
*,
invite_request_id: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Deny a workspace invite request.
https://api.slack.com/methods/admin.inviteRequests.deny
"""
kwargs.update({"invite_request_id": invite_request_id, "team_id": team_id})
return await self.api_call("admin.inviteRequests.deny", params=kwargs)
async def admin_inviteRequests_list(
self,
**kwargs,
) -> AsyncSlackResponse:
"""List all pending workspace invite requests."""
return await self.api_call("admin.inviteRequests.list", params=kwargs)
async def admin_teams_admins_list(
self,
*,
team_id: str,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all of the admins on a given workspace.
https://api.slack.com/methods/admin.inviteRequests.list
"""
kwargs.update(
{
"cursor": cursor,
"limit": limit,
"team_id": team_id,
}
)
return await self.api_call("admin.teams.admins.list", http_verb="GET", params=kwargs)
async def admin_teams_create(
self,
*,
team_domain: str,
team_name: str,
team_description: Optional[str] = None,
team_discoverability: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Create an Enterprise team.
https://api.slack.com/methods/admin.teams.create
"""
kwargs.update(
{
"team_domain": team_domain,
"team_name": team_name,
"team_description": team_description,
"team_discoverability": team_discoverability,
}
)
return await self.api_call("admin.teams.create", params=kwargs)
async def admin_teams_list(
self,
*,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all teams on an Enterprise organization.
https://api.slack.com/methods/admin.teams.list
"""
kwargs.update({"cursor": cursor, "limit": limit})
return await self.api_call("admin.teams.list", params=kwargs)
async def admin_teams_owners_list(
self,
*,
team_id: str,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all of the admins on a given workspace.
https://api.slack.com/methods/admin.teams.owners.list
"""
kwargs.update({"team_id": team_id, "cursor": cursor, "limit": limit})
return await self.api_call("admin.teams.owners.list", http_verb="GET", params=kwargs)
async def admin_teams_settings_info(
self,
*,
team_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Fetch information about settings in a workspace
https://api.slack.com/methods/admin.teams.settings.info
"""
kwargs.update({"team_id": team_id})
return await self.api_call("admin.teams.settings.info", params=kwargs)
async def admin_teams_settings_setDescription(
self,
*,
team_id: str,
description: str,
**kwargs,
) -> AsyncSlackResponse:
"""Set the description of a given workspace.
https://api.slack.com/methods/admin.teams.settings.setDescription
"""
kwargs.update({"team_id": team_id, "description": description})
return await self.api_call("admin.teams.settings.setDescription", params=kwargs)
async def admin_teams_settings_setDiscoverability(
self,
*,
team_id: str,
discoverability: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the icon of a workspace.
https://api.slack.com/methods/admin.teams.settings.setDiscoverability
"""
kwargs.update({"team_id": team_id, "discoverability": discoverability})
return await self.api_call("admin.teams.settings.setDiscoverability", params=kwargs)
async def admin_teams_settings_setIcon(
self,
*,
team_id: str,
image_url: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the icon of a workspace.
https://api.slack.com/methods/admin.teams.settings.setIcon
"""
kwargs.update({"team_id": team_id, "image_url": image_url})
return await self.api_call("admin.teams.settings.setIcon", http_verb="GET", params=kwargs)
async def admin_teams_settings_setName(
self,
*,
team_id: str,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the icon of a workspace.
https://api.slack.com/methods/admin.teams.settings.setName
"""
kwargs.update({"team_id": team_id, "name": name})
return await self.api_call("admin.teams.settings.setName", params=kwargs)
async def admin_usergroups_addChannels(
self,
*,
channel_ids: Union[str, Sequence[str]],
usergroup_id: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Add one or more default channels to an IDP group.
https://api.slack.com/methods/admin.usergroups.addChannels
"""
kwargs.update({"team_id": team_id, "usergroup_id": usergroup_id})
if isinstance(channel_ids, (list, Tuple)):
kwargs.update({"channel_ids": ",".join(channel_ids)})
else:
kwargs.update({"channel_ids": channel_ids})
return await self.api_call("admin.usergroups.addChannels", params=kwargs)
async def admin_usergroups_addTeams(
self,
*,
usergroup_id: str,
team_ids: Union[str, Sequence[str]],
auto_provision: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Associate one or more default workspaces with an organization-wide IDP group.
https://api.slack.com/methods/admin.usergroups.addTeams
"""
kwargs.update({"usergroup_id": usergroup_id, "auto_provision": auto_provision})
if isinstance(team_ids, (list, Tuple)):
kwargs.update({"team_ids": ",".join(team_ids)})
else:
kwargs.update({"team_ids": team_ids})
return await self.api_call("admin.usergroups.addTeams", params=kwargs)
async def admin_usergroups_listChannels(
self,
*,
usergroup_id: str,
include_num_members: Optional[bool] = None,
team_id: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Add one or more default channels to an IDP group.
https://api.slack.com/methods/admin.usergroups.listChannels
"""
kwargs.update(
{
"usergroup_id": usergroup_id,
"include_num_members": include_num_members,
"team_id": team_id,
}
)
return await self.api_call("admin.usergroups.listChannels", params=kwargs)
async def admin_usergroups_removeChannels(
self,
*,
usergroup_id: str,
channel_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Add one or more default channels to an IDP group.
https://api.slack.com/methods/admin.usergroups.removeChannels
"""
kwargs.update({"usergroup_id": usergroup_id})
if isinstance(channel_ids, (list, Tuple)):
kwargs.update({"channel_ids": ",".join(channel_ids)})
else:
kwargs.update({"channel_ids": channel_ids})
return await self.api_call("admin.usergroups.removeChannels", params=kwargs)
async def admin_users_assign(
self,
*,
team_id: str,
user_id: str,
channel_ids: Optional[Union[str, Sequence[str]]] = None,
is_restricted: Optional[bool] = None,
is_ultra_restricted: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Add an Enterprise user to a workspace.
https://api.slack.com/methods/admin.users.assign
"""
kwargs.update(
{
"team_id": team_id,
"user_id": user_id,
"is_restricted": is_restricted,
"is_ultra_restricted": is_ultra_restricted,
}
)
if isinstance(channel_ids, (list, Tuple)):
kwargs.update({"channel_ids": ",".join(channel_ids)})
else:
kwargs.update({"channel_ids": channel_ids})
return await self.api_call("admin.users.assign", params=kwargs)
async def admin_users_invite(
self,
*,
team_id: str,
email: str,
channel_ids: Union[str, Sequence[str]],
custom_message: Optional[str] = None,
email_password_policy_enabled: Optional[bool] = None,
guest_expiration_ts: Optional[Union[str, float]] = None,
is_restricted: Optional[bool] = None,
is_ultra_restricted: Optional[bool] = None,
real_name: Optional[str] = None,
resend: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Invite a user to a workspace.
https://api.slack.com/methods/admin.users.invite
"""
kwargs.update(
{
"team_id": team_id,
"email": email,
"custom_message": custom_message,
"email_password_policy_enabled": email_password_policy_enabled,
"guest_expiration_ts": str(guest_expiration_ts) if guest_expiration_ts is not None else None,
"is_restricted": is_restricted,
"is_ultra_restricted": is_ultra_restricted,
"real_name": real_name,
"resend": resend,
}
)
if isinstance(channel_ids, (list, Tuple)):
kwargs.update({"channel_ids": ",".join(channel_ids)})
else:
kwargs.update({"channel_ids": channel_ids})
return await self.api_call("admin.users.invite", params=kwargs)
async def admin_users_list(
self,
*,
team_id: str,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List users on a workspace
https://api.slack.com/methods/admin.users.list
"""
kwargs.update(
{
"team_id": team_id,
"cursor": cursor,
"limit": limit,
}
)
return await self.api_call("admin.users.list", params=kwargs)
async def admin_users_remove(
self,
*,
team_id: str,
user_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Remove a user from a workspace.
https://api.slack.com/methods/admin.users.remove
"""
kwargs.update({"team_id": team_id, "user_id": user_id})
return await self.api_call("admin.users.remove", params=kwargs)
async def admin_users_setAdmin(
self,
*,
team_id: str,
user_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Set an existing guest, regular user, or owner to be an admin user.
https://api.slack.com/methods/admin.users.setAdmin
"""
kwargs.update({"team_id": team_id, "user_id": user_id})
return await self.api_call("admin.users.setAdmin", params=kwargs)
async def admin_users_setExpiration(
self,
*,
expiration_ts: int,
user_id: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set an expiration for a guest user.
https://api.slack.com/methods/admin.users.setExpiration
"""
kwargs.update({"expiration_ts": expiration_ts, "team_id": team_id, "user_id": user_id})
return await self.api_call("admin.users.setExpiration", params=kwargs)
async def admin_users_setOwner(
self,
*,
team_id: str,
user_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Set an existing guest, regular user, or admin user to be a workspace owner.
https://api.slack.com/methods/admin.users.setOwner
"""
kwargs.update({"team_id": team_id, "user_id": user_id})
return await self.api_call("admin.users.setOwner", params=kwargs)
async def admin_users_setRegular(
self,
*,
team_id: str,
user_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Set an existing guest user, admin user, or owner to be a regular user.
https://api.slack.com/methods/admin.users.setRegular
"""
kwargs.update({"team_id": team_id, "user_id": user_id})
return await self.api_call("admin.users.setRegular", params=kwargs)
async def admin_workflows_search(
self,
*,
app_id: Optional[str] = None,
collaborator_ids: Optional[Union[str, Sequence[str]]] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
no_collaborators: Optional[bool] = None,
num_trigger_ids: Optional[int] = None,
query: Optional[str] = None,
sort: Optional[str] = None,
sort_dir: Optional[str] = None,
source: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Search workflows within the team or enterprise
https://api.slack.com/methods/admin.workflows.search
"""
if collaborator_ids is not None:
if isinstance(collaborator_ids, (list, Tuple)):
kwargs.update({"collaborator_ids": ",".join(collaborator_ids)})
else:
kwargs.update({"collaborator_ids": collaborator_ids})
kwargs.update(
{
"app_id": app_id,
"cursor": cursor,
"limit": limit,
"no_collaborators": no_collaborators,
"num_trigger_ids": num_trigger_ids,
"query": query,
"sort": sort,
"sort_dir": sort_dir,
"source": source,
}
)
return await self.api_call("admin.workflows.search", params=kwargs)
async def admin_workflows_permissions_lookup(
self,
*,
workflow_ids: Union[str, Sequence[str]],
max_workflow_triggers: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Look up the permissions for a set of workflows
https://api.slack.com/methods/admin.workflows.permissions.lookup
"""
if isinstance(workflow_ids, (list, Tuple)):
kwargs.update({"workflow_ids": ",".join(workflow_ids)})
else:
kwargs.update({"workflow_ids": workflow_ids})
kwargs.update(
{
"max_workflow_triggers": max_workflow_triggers,
}
)
return await self.api_call("admin.workflows.permissions.lookup", params=kwargs)
async def admin_workflows_collaborators_add(
self,
*,
collaborator_ids: Union[str, Sequence[str]],
workflow_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Add collaborators to workflows within the team or enterprise
https://api.slack.com/methods/admin.workflows.collaborators.add
"""
if isinstance(collaborator_ids, (list, Tuple)):
kwargs.update({"collaborator_ids": ",".join(collaborator_ids)})
else:
kwargs.update({"collaborator_ids": collaborator_ids})
if isinstance(workflow_ids, (list, Tuple)):
kwargs.update({"workflow_ids": ",".join(workflow_ids)})
else:
kwargs.update({"workflow_ids": workflow_ids})
return await self.api_call("admin.workflows.collaborators.add", params=kwargs)
async def admin_workflows_collaborators_remove(
self,
*,
collaborator_ids: Union[str, Sequence[str]],
workflow_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Remove collaborators from workflows within the team or enterprise
https://api.slack.com/methods/admin.workflows.collaborators.remove
"""
if isinstance(collaborator_ids, (list, Tuple)):
kwargs.update({"collaborator_ids": ",".join(collaborator_ids)})
else:
kwargs.update({"collaborator_ids": collaborator_ids})
if isinstance(workflow_ids, (list, Tuple)):
kwargs.update({"workflow_ids": ",".join(workflow_ids)})
else:
kwargs.update({"workflow_ids": workflow_ids})
return await self.api_call("admin.workflows.collaborators.remove", params=kwargs)
async def admin_workflows_unpublish(
self,
*,
workflow_ids: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Unpublish workflows within the team or enterprise
https://api.slack.com/methods/admin.workflows.unpublish
"""
if isinstance(workflow_ids, (list, Tuple)):
kwargs.update({"workflow_ids": ",".join(workflow_ids)})
else:
kwargs.update({"workflow_ids": workflow_ids})
return await self.api_call("admin.workflows.unpublish", params=kwargs)
async def api_test(
self,
*,
error: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Checks API calling code.
https://api.slack.com/methods/api.test
"""
kwargs.update({"error": error})
return await self.api_call("api.test", params=kwargs)
async def apps_connections_open(
self,
*,
app_token: str,
**kwargs,
) -> AsyncSlackResponse:
"""Generate a temporary Socket Mode WebSocket URL that your app can connect to
in order to receive events and interactive payloads
https://api.slack.com/methods/apps.connections.open
"""
kwargs.update({"token": app_token})
return await self.api_call("apps.connections.open", http_verb="POST", params=kwargs)
async def apps_event_authorizations_list(
self,
*,
event_context: str,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Get a list of authorizations for the given event context.
Each authorization represents an app installation that the event is visible to.
https://api.slack.com/methods/apps.event.authorizations.list
"""
kwargs.update({"event_context": event_context, "cursor": cursor, "limit": limit})
return await self.api_call("apps.event.authorizations.list", params=kwargs)
async def apps_uninstall(
self,
*,
client_id: str,
client_secret: str,
**kwargs,
) -> AsyncSlackResponse:
"""Uninstalls your app from a workspace.
https://api.slack.com/methods/apps.uninstall
"""
kwargs.update({"client_id": client_id, "client_secret": client_secret})
return await self.api_call("apps.uninstall", params=kwargs)
async def auth_revoke(
self,
*,
test: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Revokes a token.
https://api.slack.com/methods/auth.revoke
"""
kwargs.update({"test": test})
return await self.api_call("auth.revoke", http_verb="GET", params=kwargs)
async def auth_test(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Checks authentication & identity.
https://api.slack.com/methods/auth.test
"""
return await self.api_call("auth.test", params=kwargs)
async def auth_teams_list(
self,
cursor: Optional[str] = None,
limit: Optional[int] = None,
include_icon: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List the workspaces a token can access.
https://api.slack.com/methods/auth.teams.list
"""
kwargs.update({"cursor": cursor, "limit": limit, "include_icon": include_icon})
return await self.api_call("auth.teams.list", params=kwargs)
async def bookmarks_add(
self,
*,
channel_id: str,
title: str,
type: str,
emoji: Optional[str] = None,
entity_id: Optional[str] = None,
link: Optional[str] = None, # include when type is 'link'
parent_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Add bookmark to a channel.
https://api.slack.com/methods/bookmarks.add
"""
kwargs.update(
{
"channel_id": channel_id,
"title": title,
"type": type,
"emoji": emoji,
"entity_id": entity_id,
"link": link,
"parent_id": parent_id,
}
)
return await self.api_call("bookmarks.add", http_verb="POST", params=kwargs)
async def bookmarks_edit(
self,
*,
bookmark_id: str,
channel_id: str,
emoji: Optional[str] = None,
link: Optional[str] = None,
title: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Edit bookmark.
https://api.slack.com/methods/bookmarks.edit
"""
kwargs.update(
{
"bookmark_id": bookmark_id,
"channel_id": channel_id,
"emoji": emoji,
"link": link,
"title": title,
}
)
return await self.api_call("bookmarks.edit", http_verb="POST", params=kwargs)
async def bookmarks_list(
self,
*,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""List bookmark for the channel.
https://api.slack.com/methods/bookmarks.list
"""
kwargs.update({"channel_id": channel_id})
return await self.api_call("bookmarks.list", http_verb="POST", params=kwargs)
async def bookmarks_remove(
self,
*,
bookmark_id: str,
channel_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Remove bookmark from the channel.
https://api.slack.com/methods/bookmarks.remove
"""
kwargs.update({"bookmark_id": bookmark_id, "channel_id": channel_id})
return await self.api_call("bookmarks.remove", http_verb="POST", params=kwargs)
async def bots_info(
self,
*,
bot: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about a bot user.
https://api.slack.com/methods/bots.info
"""
kwargs.update({"bot": bot, "team_id": team_id})
return await self.api_call("bots.info", http_verb="GET", params=kwargs)
async def calls_add(
self,
*,
external_unique_id: str,
join_url: str,
created_by: Optional[str] = None,
date_start: Optional[int] = None,
desktop_app_join_url: Optional[str] = None,
external_display_id: Optional[str] = None,
title: Optional[str] = None,
users: Optional[Union[str, Sequence[Dict[str, str]]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Registers a new Call.
https://api.slack.com/methods/calls.add
"""
kwargs.update(
{
"external_unique_id": external_unique_id,
"join_url": join_url,
"created_by": created_by,
"date_start": date_start,
"desktop_app_join_url": desktop_app_join_url,
"external_display_id": external_display_id,
"title": title,
}
)
_update_call_participants( # skipcq: PTC-W0039
kwargs,
users if users is not None else kwargs.get("users"), # skipcq: PTC-W0039
) # skipcq: PTC-W0039
return await self.api_call("calls.add", http_verb="POST", params=kwargs)
async def calls_end(
self,
*,
id: str,
duration: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse: # skipcq: PYL-W0622
"""Ends a Call.
https://api.slack.com/methods/calls.end
"""
kwargs.update({"id": id, "duration": duration})
return await self.api_call("calls.end", http_verb="POST", params=kwargs)
async def calls_info(
self,
*,
id: str,
**kwargs,
) -> AsyncSlackResponse: # skipcq: PYL-W0622
"""Returns information about a Call.
https://api.slack.com/methods/calls.info
"""
kwargs.update({"id": id})
return await self.api_call("calls.info", http_verb="POST", params=kwargs)
async def calls_participants_add(
self,
*,
id: str, # skipcq: PYL-W0622
users: Union[str, Sequence[Dict[str, str]]],
**kwargs,
) -> AsyncSlackResponse:
"""Registers new participants added to a Call.
https://api.slack.com/methods/calls.participants.add
"""
kwargs.update({"id": id})
_update_call_participants(kwargs, users)
return await self.api_call("calls.participants.add", http_verb="POST", params=kwargs)
async def calls_participants_remove(
self,
*,
id: str, # skipcq: PYL-W0622
users: Union[str, Sequence[Dict[str, str]]],
**kwargs,
) -> AsyncSlackResponse:
"""Registers participants removed from a Call.
https://api.slack.com/methods/calls.participants.remove
"""
kwargs.update({"id": id})
_update_call_participants(kwargs, users)
return await self.api_call("calls.participants.remove", http_verb="POST", params=kwargs)
async def calls_update(
self,
*,
id: str,
desktop_app_join_url: Optional[str] = None,
join_url: Optional[str] = None,
title: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse: # skipcq: PYL-W0622
"""Updates information about a Call.
https://api.slack.com/methods/calls.update
"""
kwargs.update(
{
"id": id,
"desktop_app_join_url": desktop_app_join_url,
"join_url": join_url,
"title": title,
}
)
return await self.api_call("calls.update", http_verb="POST", params=kwargs)
# --------------------------
# Deprecated: channels.*
# You can use conversations.* APIs instead.
# https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api
# --------------------------
async def channels_archive(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Archives a channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.archive", json=kwargs)
async def channels_create(
self,
*,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Creates a channel."""
kwargs.update({"name": name})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.create", json=kwargs)
async def channels_history(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Fetches history of messages and events from a channel."""
kwargs.update({"channel": channel})
return await self.api_call("channels.history", http_verb="GET", params=kwargs)
async def channels_info(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about a channel."""
kwargs.update({"channel": channel})
return await self.api_call("channels.info", http_verb="GET", params=kwargs)
async def channels_invite(
self,
*,
channel: str,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Invites a user to a channel."""
kwargs.update({"channel": channel, "user": user})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.invite", json=kwargs)
async def channels_join(
self,
*,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Joins a channel, creating it if needed."""
kwargs.update({"name": name})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.join", json=kwargs)
async def channels_kick(
self,
*,
channel: str,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Removes a user from a channel."""
kwargs.update({"channel": channel, "user": user})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.kick", json=kwargs)
async def channels_leave(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Leaves a channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.leave", json=kwargs)
async def channels_list(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Lists all channels in a Slack team."""
return await self.api_call("channels.list", http_verb="GET", params=kwargs)
async def channels_mark(
self,
*,
channel: str,
ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the read cursor in a channel."""
kwargs.update({"channel": channel, "ts": ts})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.mark", json=kwargs)
async def channels_rename(
self,
*,
channel: str,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Renames a channel."""
kwargs.update({"channel": channel, "name": name})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.rename", json=kwargs)
async def channels_replies(
self,
*,
channel: str,
thread_ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a thread of messages posted to a channel"""
kwargs.update({"channel": channel, "thread_ts": thread_ts})
return await self.api_call("channels.replies", http_verb="GET", params=kwargs)
async def channels_setPurpose(
self,
*,
channel: str,
purpose: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the purpose for a channel."""
kwargs.update({"channel": channel, "purpose": purpose})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.setPurpose", json=kwargs)
async def channels_setTopic(
self,
*,
channel: str,
topic: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the topic for a channel."""
kwargs.update({"channel": channel, "topic": topic})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.setTopic", json=kwargs)
async def channels_unarchive(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Unarchives a channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("channels.unarchive", json=kwargs)
# --------------------------
async def chat_delete(
self,
*,
channel: str,
ts: str,
as_user: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Deletes a message.
https://api.slack.com/methods/chat.delete
"""
kwargs.update({"channel": channel, "ts": ts, "as_user": as_user})
return await self.api_call("chat.delete", params=kwargs)
async def chat_deleteScheduledMessage(
self,
*,
channel: str,
scheduled_message_id: str,
as_user: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Deletes a scheduled message.
https://api.slack.com/methods/chat.deleteScheduledMessage
"""
kwargs.update(
{
"channel": channel,
"scheduled_message_id": scheduled_message_id,
"as_user": as_user,
}
)
return await self.api_call("chat.deleteScheduledMessage", params=kwargs)
async def chat_getPermalink(
self,
*,
channel: str,
message_ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a permalink URL for a specific extant message
https://api.slack.com/methods/chat.getPermalink
"""
kwargs.update({"channel": channel, "message_ts": message_ts})
return await self.api_call("chat.getPermalink", http_verb="GET", params=kwargs)
async def chat_meMessage(
self,
*,
channel: str,
text: str,
**kwargs,
) -> AsyncSlackResponse:
"""Share a me message into a channel.
https://api.slack.com/methods/chat.meMessage
"""
kwargs.update({"channel": channel, "text": text})
return await self.api_call("chat.meMessage", params=kwargs)
async def chat_postEphemeral(
self,
*,
channel: str,
user: str,
text: Optional[str] = None,
as_user: Optional[bool] = None,
attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None,
blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None,
thread_ts: Optional[str] = None,
icon_emoji: Optional[str] = None,
icon_url: Optional[str] = None,
link_names: Optional[bool] = None,
username: Optional[str] = None,
parse: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Sends an ephemeral message to a user in a channel.
https://api.slack.com/methods/chat.postEphemeral
"""
kwargs.update(
{
"channel": channel,
"user": user,
"text": text,
"as_user": as_user,
"attachments": attachments,
"blocks": blocks,
"thread_ts": thread_ts,
"icon_emoji": icon_emoji,
"icon_url": icon_url,
"link_names": link_names,
"username": username,
"parse": parse,
}
)
_parse_web_class_objects(kwargs)
kwargs = _remove_none_values(kwargs)
_warn_if_text_or_attachment_fallback_is_missing("chat.postEphemeral", kwargs)
# NOTE: intentionally using json over params for the API methods using blocks/attachments
return await self.api_call("chat.postEphemeral", json=kwargs)
async def chat_postMessage(
self,
*,
channel: str,
text: Optional[str] = None,
as_user: Optional[bool] = None,
attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None,
blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None,
thread_ts: Optional[str] = None,
reply_broadcast: Optional[bool] = None,
unfurl_links: Optional[bool] = None,
unfurl_media: Optional[bool] = None,
container_id: Optional[str] = None,
icon_emoji: Optional[str] = None,
icon_url: Optional[str] = None,
mrkdwn: Optional[bool] = None,
link_names: Optional[bool] = None,
username: Optional[str] = None,
parse: Optional[str] = None, # none, full
metadata: Optional[Union[Dict, Metadata]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Sends a message to a channel.
https://api.slack.com/methods/chat.postMessage
"""
kwargs.update(
{
"channel": channel,
"text": text,
"as_user": as_user,
"attachments": attachments,
"blocks": blocks,
"thread_ts": thread_ts,
"reply_broadcast": reply_broadcast,
"unfurl_links": unfurl_links,
"unfurl_media": unfurl_media,
"container_id": container_id,
"icon_emoji": icon_emoji,
"icon_url": icon_url,
"mrkdwn": mrkdwn,
"link_names": link_names,
"username": username,
"parse": parse,
"metadata": metadata,
}
)
_parse_web_class_objects(kwargs)
kwargs = _remove_none_values(kwargs)
_warn_if_text_or_attachment_fallback_is_missing("chat.postMessage", kwargs)
# NOTE: intentionally using json over params for the API methods using blocks/attachments
return await self.api_call("chat.postMessage", json=kwargs)
async def chat_scheduleMessage(
self,
*,
channel: str,
post_at: Union[str, int],
text: str,
as_user: Optional[bool] = None,
attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None,
blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None,
thread_ts: Optional[str] = None,
parse: Optional[str] = None,
reply_broadcast: Optional[bool] = None,
unfurl_links: Optional[bool] = None,
unfurl_media: Optional[bool] = None,
link_names: Optional[bool] = None,
metadata: Optional[Union[Dict, Metadata]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Schedules a message.
https://api.slack.com/methods/chat.scheduleMessage
"""
kwargs.update(
{
"channel": channel,
"post_at": post_at,
"text": text,
"as_user": as_user,
"attachments": attachments,
"blocks": blocks,
"thread_ts": thread_ts,
"reply_broadcast": reply_broadcast,
"parse": parse,
"unfurl_links": unfurl_links,
"unfurl_media": unfurl_media,
"link_names": link_names,
"metadata": metadata,
}
)
_parse_web_class_objects(kwargs)
kwargs = _remove_none_values(kwargs)
_warn_if_text_or_attachment_fallback_is_missing("chat.scheduleMessage", kwargs)
# NOTE: intentionally using json over params for the API methods using blocks/attachments
return await self.api_call("chat.scheduleMessage", json=kwargs)
async def chat_unfurl(
self,
*,
channel: Optional[str] = None,
ts: Optional[str] = None,
source: Optional[str] = None,
unfurl_id: Optional[str] = None,
unfurls: Optional[Dict[str, Dict]] = None, # or user_auth_*
user_auth_blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None,
user_auth_message: Optional[str] = None,
user_auth_required: Optional[bool] = None,
user_auth_url: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Provide custom unfurl behavior for user-posted URLs.
https://api.slack.com/methods/chat.unfurl
"""
kwargs.update(
{
"channel": channel,
"ts": ts,
"source": source,
"unfurl_id": unfurl_id,
"unfurls": unfurls,
"user_auth_blocks": user_auth_blocks,
"user_auth_message": user_auth_message,
"user_auth_required": user_auth_required,
"user_auth_url": user_auth_url,
}
)
_parse_web_class_objects(kwargs) # for user_auth_blocks
kwargs = _remove_none_values(kwargs)
# NOTE: intentionally using json over params for API methods using blocks/attachments
return await self.api_call("chat.unfurl", json=kwargs)
async def chat_update(
self,
*,
channel: str,
ts: str,
text: Optional[str] = None,
attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None,
blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None,
as_user: Optional[bool] = None,
file_ids: Optional[Union[str, Sequence[str]]] = None,
link_names: Optional[bool] = None,
parse: Optional[str] = None, # none, full
reply_broadcast: Optional[bool] = None,
metadata: Optional[Union[Dict, Metadata]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Updates a message in a channel.
https://api.slack.com/methods/chat.update
"""
kwargs.update(
{
"channel": channel,
"ts": ts,
"text": text,
"attachments": attachments,
"blocks": blocks,
"as_user": as_user,
"link_names": link_names,
"parse": parse,
"reply_broadcast": reply_broadcast,
"metadata": metadata,
}
)
if isinstance(file_ids, (list, Tuple)):
kwargs.update({"file_ids": ",".join(file_ids)})
else:
kwargs.update({"file_ids": file_ids})
_parse_web_class_objects(kwargs)
kwargs = _remove_none_values(kwargs)
_warn_if_text_or_attachment_fallback_is_missing("chat.update", kwargs)
# NOTE: intentionally using json over params for API methods using blocks/attachments
return await self.api_call("chat.update", json=kwargs)
async def chat_scheduledMessages_list(
self,
*,
channel: Optional[str] = None,
cursor: Optional[str] = None,
latest: Optional[str] = None,
limit: Optional[int] = None,
oldest: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists all scheduled messages.
https://api.slack.com/methods/chat.scheduledMessages.list
"""
kwargs.update(
{
"channel": channel,
"cursor": cursor,
"latest": latest,
"limit": limit,
"oldest": oldest,
"team_id": team_id,
}
)
return await self.api_call("chat.scheduledMessages.list", params=kwargs)
async def conversations_acceptSharedInvite(
self,
*,
channel_name: str,
channel_id: Optional[str] = None,
invite_id: Optional[str] = None,
free_trial_accepted: Optional[bool] = None,
is_private: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Accepts an invitation to a Slack Connect channel.
https://api.slack.com/methods/conversations.acceptSharedInvite
"""
if channel_id is None and invite_id is None:
raise e.SlackRequestError("Either channel_id or invite_id must be provided.")
kwargs.update(
{
"channel_name": channel_name,
"channel_id": channel_id,
"invite_id": invite_id,
"free_trial_accepted": free_trial_accepted,
"is_private": is_private,
"team_id": team_id,
}
)
return await self.api_call("conversations.acceptSharedInvite", http_verb="POST", params=kwargs)
async def conversations_approveSharedInvite(
self,
*,
invite_id: str,
target_team: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Approves an invitation to a Slack Connect channel.
https://api.slack.com/methods/conversations.approveSharedInvite
"""
kwargs.update({"invite_id": invite_id, "target_team": target_team})
return await self.api_call("conversations.approveSharedInvite", http_verb="POST", params=kwargs)
async def conversations_archive(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Archives a conversation.
https://api.slack.com/methods/conversations.archive
"""
kwargs.update({"channel": channel})
return await self.api_call("conversations.archive", params=kwargs)
async def conversations_close(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Closes a direct message or multi-person direct message.
https://api.slack.com/methods/conversations.close
"""
kwargs.update({"channel": channel})
return await self.api_call("conversations.close", params=kwargs)
async def conversations_create(
self,
*,
name: str,
is_private: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Initiates a public or private channel-based conversation
https://api.slack.com/methods/conversations.create
"""
kwargs.update({"name": name, "is_private": is_private, "team_id": team_id})
return await self.api_call("conversations.create", params=kwargs)
async def conversations_declineSharedInvite(
self,
*,
invite_id: str,
target_team: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Declines a Slack Connect channel invite.
https://api.slack.com/methods/conversations.declineSharedInvite
"""
kwargs.update({"invite_id": invite_id, "target_team": target_team})
return await self.api_call("conversations.declineSharedInvite", http_verb="GET", params=kwargs)
async def conversations_history(
self,
*,
channel: str,
cursor: Optional[str] = None,
inclusive: Optional[bool] = None,
include_all_metadata: Optional[bool] = None,
latest: Optional[str] = None,
limit: Optional[int] = None,
oldest: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Fetches a conversation's history of messages and events.
https://api.slack.com/methods/conversations.history
"""
kwargs.update(
{
"channel": channel,
"cursor": cursor,
"inclusive": inclusive,
"include_all_metadata": include_all_metadata,
"limit": limit,
"latest": latest,
"oldest": oldest,
}
)
return await self.api_call("conversations.history", http_verb="GET", params=kwargs)
async def conversations_info(
self,
*,
channel: str,
include_locale: Optional[bool] = None,
include_num_members: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve information about a conversation.
https://api.slack.com/methods/conversations.info
"""
kwargs.update(
{
"channel": channel,
"include_locale": include_locale,
"include_num_members": include_num_members,
}
)
return await self.api_call("conversations.info", http_verb="GET", params=kwargs)
async def conversations_invite(
self,
*,
channel: str,
users: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""Invites users to a channel.
https://api.slack.com/methods/conversations.invite
"""
kwargs.update({"channel": channel})
if isinstance(users, (list, Tuple)):
kwargs.update({"users": ",".join(users)})
else:
kwargs.update({"users": users})
return await self.api_call("conversations.invite", params=kwargs)
async def conversations_inviteShared(
self,
*,
channel: str,
emails: Optional[Union[str, Sequence[str]]] = None,
user_ids: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Sends an invitation to a Slack Connect channel.
https://api.slack.com/methods/conversations.inviteShared
"""
if emails is None and user_ids is None:
raise e.SlackRequestError("Either emails or user ids must be provided.")
kwargs.update({"channel": channel})
if isinstance(emails, (list, Tuple)):
kwargs.update({"emails": ",".join(emails)})
else:
kwargs.update({"emails": emails})
if isinstance(user_ids, (list, Tuple)):
kwargs.update({"user_ids": ",".join(user_ids)})
else:
kwargs.update({"user_ids": user_ids})
return await self.api_call("conversations.inviteShared", http_verb="GET", params=kwargs)
async def conversations_join(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Joins an existing conversation.
https://api.slack.com/methods/conversations.join
"""
kwargs.update({"channel": channel})
return await self.api_call("conversations.join", params=kwargs)
async def conversations_kick(
self,
*,
channel: str,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Removes a user from a conversation.
https://api.slack.com/methods/conversations.kick
"""
kwargs.update({"channel": channel, "user": user})
return await self.api_call("conversations.kick", params=kwargs)
async def conversations_leave(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Leaves a conversation.
https://api.slack.com/methods/conversations.leave
"""
kwargs.update({"channel": channel})
return await self.api_call("conversations.leave", params=kwargs)
async def conversations_list(
self,
*,
cursor: Optional[str] = None,
exclude_archived: Optional[bool] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
types: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists all channels in a Slack team.
https://api.slack.com/methods/conversations.list
"""
kwargs.update(
{
"cursor": cursor,
"exclude_archived": exclude_archived,
"limit": limit,
"team_id": team_id,
}
)
if isinstance(types, (list, Tuple)):
kwargs.update({"types": ",".join(types)})
else:
kwargs.update({"types": types})
return await self.api_call("conversations.list", http_verb="GET", params=kwargs)
async def conversations_listConnectInvites(
self,
*,
count: Optional[int] = None,
cursor: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List shared channel invites that have been generated
or received but have not yet been approved by all parties.
https://api.slack.com/methods/conversations.listConnectInvites
"""
kwargs.update({"count": count, "cursor": cursor, "team_id": team_id})
return await self.api_call("conversations.listConnectInvites", params=kwargs)
async def conversations_mark(
self,
*,
channel: str,
ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the read cursor in a channel.
https://api.slack.com/methods/conversations.mark
"""
kwargs.update({"channel": channel, "ts": ts})
return await self.api_call("conversations.mark", params=kwargs)
async def conversations_members(
self,
*,
channel: str,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve members of a conversation.
https://api.slack.com/methods/conversations.members
"""
kwargs.update({"channel": channel, "cursor": cursor, "limit": limit})
return await self.api_call("conversations.members", http_verb="GET", params=kwargs)
async def conversations_open(
self,
*,
channel: Optional[str] = None,
return_im: Optional[bool] = None,
users: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Opens or resumes a direct message or multi-person direct message.
https://api.slack.com/methods/conversations.open
"""
if channel is None and users is None:
raise e.SlackRequestError("Either channel or users must be provided.")
kwargs.update({"channel": channel, "return_im": return_im})
if isinstance(users, (list, Tuple)):
kwargs.update({"users": ",".join(users)})
else:
kwargs.update({"users": users})
return await self.api_call("conversations.open", params=kwargs)
async def conversations_rename(
self,
*,
channel: str,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Renames a conversation.
https://api.slack.com/methods/conversations.rename
"""
kwargs.update({"channel": channel, "name": name})
return await self.api_call("conversations.rename", params=kwargs)
async def conversations_replies(
self,
*,
channel: str,
ts: str,
cursor: Optional[str] = None,
inclusive: Optional[bool] = None,
include_all_metadata: Optional[bool] = None,
latest: Optional[str] = None,
limit: Optional[int] = None,
oldest: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a thread of messages posted to a conversation
https://api.slack.com/methods/conversations.replies
"""
kwargs.update(
{
"channel": channel,
"ts": ts,
"cursor": cursor,
"inclusive": inclusive,
"include_all_metadata": include_all_metadata,
"limit": limit,
"latest": latest,
"oldest": oldest,
}
)
return await self.api_call("conversations.replies", http_verb="GET", params=kwargs)
async def conversations_setPurpose(
self,
*,
channel: str,
purpose: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the purpose for a conversation.
https://api.slack.com/methods/conversations.setPurpose
"""
kwargs.update({"channel": channel, "purpose": purpose})
return await self.api_call("conversations.setPurpose", params=kwargs)
async def conversations_setTopic(
self,
*,
channel: str,
topic: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the topic for a conversation.
https://api.slack.com/methods/conversations.setTopic
"""
kwargs.update({"channel": channel, "topic": topic})
return await self.api_call("conversations.setTopic", params=kwargs)
async def conversations_unarchive(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Reverses conversation archival.
https://api.slack.com/methods/conversations.unarchive
"""
kwargs.update({"channel": channel})
return await self.api_call("conversations.unarchive", params=kwargs)
async def dialog_open(
self,
*,
dialog: Dict[str, Any],
trigger_id: str,
**kwargs,
) -> AsyncSlackResponse:
"""Open a dialog with a user.
https://api.slack.com/methods/dialog.open
"""
kwargs.update({"dialog": dialog, "trigger_id": trigger_id})
kwargs = _remove_none_values(kwargs)
# NOTE: As the dialog can be a dict, this API call works only with json format.
return await self.api_call("dialog.open", json=kwargs)
async def dnd_endDnd(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Ends the current user's Do Not Disturb session immediately.
https://api.slack.com/methods/dnd.endDnd
"""
return await self.api_call("dnd.endDnd", params=kwargs)
async def dnd_endSnooze(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Ends the current user's snooze mode immediately.
https://api.slack.com/methods/dnd.endSnooze
"""
return await self.api_call("dnd.endSnooze", params=kwargs)
async def dnd_info(
self,
*,
team_id: Optional[str] = None,
user: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieves a user's current Do Not Disturb status.
https://api.slack.com/methods/dnd.info
"""
kwargs.update({"team_id": team_id, "user": user})
return await self.api_call("dnd.info", http_verb="GET", params=kwargs)
async def dnd_setSnooze(
self,
*,
num_minutes: Union[int, str],
**kwargs,
) -> AsyncSlackResponse:
"""Turns on Do Not Disturb mode for the current user, or changes its duration.
https://api.slack.com/methods/dnd.setSnooze
"""
kwargs.update({"num_minutes": num_minutes})
return await self.api_call("dnd.setSnooze", http_verb="GET", params=kwargs)
async def dnd_teamInfo(
self,
users: Union[str, Sequence[str]],
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieves the Do Not Disturb status for users on a team.
https://api.slack.com/methods/dnd.teamInfo
"""
if isinstance(users, (list, Tuple)):
kwargs.update({"users": ",".join(users)})
else:
kwargs.update({"users": users})
kwargs.update({"team_id": team_id})
return await self.api_call("dnd.teamInfo", http_verb="GET", params=kwargs)
async def emoji_list(
self,
include_categories: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists custom emoji for a team.
https://api.slack.com/methods/emoji.list
"""
kwargs.update({"include_categories": include_categories})
return await self.api_call("emoji.list", http_verb="GET", params=kwargs)
async def files_comments_delete(
self,
*,
file: str,
id: str,
**kwargs, # skipcq: PYL-W0622
) -> AsyncSlackResponse:
"""Deletes an existing comment on a file.
https://api.slack.com/methods/files.comments.delete
"""
kwargs.update({"file": file, "id": id})
return await self.api_call("files.comments.delete", params=kwargs)
async def files_delete(
self,
*,
file: str,
**kwargs,
) -> AsyncSlackResponse:
"""Deletes a file.
https://api.slack.com/methods/files.delete
"""
kwargs.update({"file": file})
return await self.api_call("files.delete", params=kwargs)
async def files_info(
self,
*,
file: str,
count: Optional[int] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
page: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about a team file.
https://api.slack.com/methods/files.info
"""
kwargs.update(
{
"file": file,
"count": count,
"cursor": cursor,
"limit": limit,
"page": page,
}
)
return await self.api_call("files.info", http_verb="GET", params=kwargs)
async def files_list(
self,
*,
channel: Optional[str] = None,
count: Optional[int] = None,
page: Optional[int] = None,
show_files_hidden_by_limit: Optional[bool] = None,
team_id: Optional[str] = None,
ts_from: Optional[str] = None,
ts_to: Optional[str] = None,
types: Optional[Union[str, Sequence[str]]] = None,
user: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists & filters team files.
https://api.slack.com/methods/files.list
"""
kwargs.update(
{
"channel": channel,
"count": count,
"page": page,
"show_files_hidden_by_limit": show_files_hidden_by_limit,
"team_id": team_id,
"ts_from": ts_from,
"ts_to": ts_to,
"user": user,
}
)
if isinstance(types, (list, Tuple)):
kwargs.update({"types": ",".join(types)})
else:
kwargs.update({"types": types})
return await self.api_call("files.list", http_verb="GET", params=kwargs)
async def files_remote_info(
self,
*,
external_id: Optional[str] = None,
file: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve information about a remote file added to Slack.
https://api.slack.com/methods/files.remote.info
"""
kwargs.update({"external_id": external_id, "file": file})
return await self.api_call("files.remote.info", http_verb="GET", params=kwargs)
async def files_remote_list(
self,
*,
channel: Optional[str] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
ts_from: Optional[str] = None,
ts_to: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve information about a remote file added to Slack.
https://api.slack.com/methods/files.remote.list
"""
kwargs.update(
{
"channel": channel,
"cursor": cursor,
"limit": limit,
"ts_from": ts_from,
"ts_to": ts_to,
}
)
return await self.api_call("files.remote.list", http_verb="GET", params=kwargs)
async def files_remote_add(
self,
*,
external_id: str,
external_url: str,
title: str,
filetype: Optional[str] = None,
indexable_file_contents: Optional[Union[str, bytes, IOBase]] = None,
preview_image: Optional[Union[str, bytes, IOBase]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Adds a file from a remote service.
https://api.slack.com/methods/files.remote.add
"""
kwargs.update(
{
"external_id": external_id,
"external_url": external_url,
"title": title,
"filetype": filetype,
}
)
files = None
# preview_image (file): Preview of the document via multipart/form-data.
if preview_image is not None or indexable_file_contents is not None:
files = {
"preview_image": preview_image,
"indexable_file_contents": indexable_file_contents,
}
return await self.api_call(
# Intentionally using "POST" method over "GET" here
"files.remote.add",
http_verb="POST",
data=kwargs,
files=files,
)
async def files_remote_update(
self,
*,
external_id: Optional[str] = None,
external_url: Optional[str] = None,
file: Optional[str] = None,
title: Optional[str] = None,
filetype: Optional[str] = None,
indexable_file_contents: Optional[str] = None,
preview_image: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Updates an existing remote file.
https://api.slack.com/methods/files.remote.update
"""
kwargs.update(
{
"external_id": external_id,
"external_url": external_url,
"file": file,
"title": title,
"filetype": filetype,
}
)
files = None
# preview_image (file): Preview of the document via multipart/form-data.
if preview_image is not None or indexable_file_contents is not None:
files = {
"preview_image": preview_image,
"indexable_file_contents": indexable_file_contents,
}
return await self.api_call(
# Intentionally using "POST" method over "GET" here
"files.remote.update",
http_verb="POST",
data=kwargs,
files=files,
)
async def files_remote_remove(
self,
*,
external_id: Optional[str] = None,
file: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Remove a remote file.
https://api.slack.com/methods/files.remote.remove
"""
kwargs.update({"external_id": external_id, "file": file})
return await self.api_call("files.remote.remove", http_verb="POST", params=kwargs)
async def files_remote_share(
self,
*,
channels: Union[str, Sequence[str]],
external_id: Optional[str] = None,
file: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Share a remote file into a channel.
https://api.slack.com/methods/files.remote.share
"""
if external_id is None and file is None:
raise e.SlackRequestError("Either external_id or file must be provided.")
if isinstance(channels, (list, Tuple)):
kwargs.update({"channels": ",".join(channels)})
else:
kwargs.update({"channels": channels})
kwargs.update({"external_id": external_id, "file": file})
return await self.api_call("files.remote.share", http_verb="GET", params=kwargs)
async def files_revokePublicURL(
self,
*,
file: str,
**kwargs,
) -> AsyncSlackResponse:
"""Revokes public/external sharing access for a file
https://api.slack.com/methods/files.revokePublicURL
"""
kwargs.update({"file": file})
return await self.api_call("files.revokePublicURL", params=kwargs)
async def files_sharedPublicURL(
self,
*,
file: str,
**kwargs,
) -> AsyncSlackResponse:
"""Enables a file for public/external sharing.
https://api.slack.com/methods/files.sharedPublicURL
"""
kwargs.update({"file": file})
return await self.api_call("files.sharedPublicURL", params=kwargs)
async def files_upload(
self,
*,
file: Optional[Union[str, bytes, IOBase]] = None,
content: Optional[Union[str, bytes]] = None,
filename: Optional[str] = None,
filetype: Optional[str] = None,
initial_comment: Optional[str] = None,
thread_ts: Optional[str] = None,
title: Optional[str] = None,
channels: Optional[Union[str, Sequence[str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Uploads or creates a file.
https://api.slack.com/methods/files.upload
"""
_print_files_upload_v2_suggestion()
if file is None and content is None:
raise e.SlackRequestError("The file or content argument must be specified.")
if file is not None and content is not None:
raise e.SlackRequestError("You cannot specify both the file and the content argument.")
if isinstance(channels, (list, Tuple)):
kwargs.update({"channels": ",".join(channels)})
else:
kwargs.update({"channels": channels})
kwargs.update(
{
"filename": filename,
"filetype": filetype,
"initial_comment": initial_comment,
"thread_ts": thread_ts,
"title": title,
}
)
if file:
if kwargs.get("filename") is None and isinstance(file, str):
# use the local filename if filename is missing
if kwargs.get("filename") is None:
kwargs["filename"] = file.split(os.path.sep)[-1]
return await self.api_call("files.upload", files={"file": file}, data=kwargs)
else:
kwargs["content"] = content
return await self.api_call("files.upload", data=kwargs)
async def files_upload_v2(
self,
*,
# for sending a single file
filename: Optional[str] = None, # you can skip this only when sending along with content parameter
file: Optional[Union[str, bytes, IOBase]] = None,
content: Optional[Union[str, bytes]] = None,
title: Optional[str] = None,
alt_txt: Optional[str] = None,
snippet_type: Optional[str] = None,
# To upload multiple files at a time
file_uploads: Optional[List[Dict[str, Any]]] = None,
channel: Optional[str] = None,
initial_comment: Optional[str] = None,
thread_ts: Optional[str] = None,
request_file_info: bool = True,
**kwargs,
) -> AsyncSlackResponse:
"""This wrapper method provides an easy way to upload files using the following endpoints:
- step1: https://api.slack.com/methods/files.getUploadURLExternal
- step2: "https://files.slack.com/upload/v1/..." URLs returned from files.getUploadURLExternal API
- step3: https://api.slack.com/methods/files.completeUploadExternal
and https://api.slack.com/methods/files.info
"""
if file is None and content is None and file_uploads is None:
raise e.SlackRequestError("Any of file, content, and file_uploads must be specified.")
if file is not None and content is not None:
raise e.SlackRequestError("You cannot specify both the file and the content argument.")
# deprecated arguments:
channels, filetype = kwargs.get("channels"), kwargs.get("filetype")
if channels is not None:
warnings.warn(
"Although the channels parameter is still supported for smooth migration from legacy files.upload, "
"we recommend using the new channel parameter with a single str value instead for more clarity."
)
if (isinstance(channels, (list, Tuple)) and len(channels) > 1) or (
isinstance(channels, str) and len(channels.split(",")) > 1
):
raise e.SlackRequestError(
"Sharing files with multiple channels is no longer supported in v2. "
"Share files in each channel separately instead."
)
if filetype is not None:
warnings.warn("The filetype parameter is no longer supported. Please remove it from the arguments.")
# step1: files.getUploadURLExternal per file
files: List[Dict[str, Any]] = []
if file_uploads is not None:
for f in file_uploads:
files.append(_to_v2_file_upload_item(f))
else:
f = _to_v2_file_upload_item(
{
"filename": filename,
"file": file,
"content": content,
"title": title,
"alt_txt": alt_txt,
"snippet_type": snippet_type,
}
)
files.append(f)
for f in files:
url_response = await self.files_getUploadURLExternal(
filename=f.get("filename"),
length=f.get("length"),
alt_txt=f.get("alt_txt"),
snippet_type=f.get("snippet_type"),
token=kwargs.get("token"),
)
_validate_for_legacy_client(url_response)
f["file_id"] = url_response.get("file_id") # type: ignore
f["upload_url"] = url_response.get("upload_url") # type: ignore
# step2: "https://files.slack.com/upload/v1/..." per file
for f in files:
upload_result = _upload_file_via_v2_url(
url=f["upload_url"],
data=f["data"],
logger=self._logger,
timeout=self.timeout,
proxy=self.proxy,
ssl=self.ssl,
)
if upload_result.get("status") != 200:
status = upload_result.get("status")
body = upload_result.get("body")
message = (
"Failed to upload a file "
f"(status: {status}, body: {body}, filename: {f.get('filename')}, title: {f.get('title')})"
)
raise e.SlackRequestError(message)
# step3: files.completeUploadExternal with all the sets of (file_id + title)
channel_to_share = channel
if channels is not None:
if isinstance(channels, str):
channel_to_share = channels.split(",")[0]
else:
channel_to_share = channels[0]
completion = await self.files_completeUploadExternal(
files=[{"id": f["file_id"], "title": f["title"]} for f in files],
channel_id=channel_to_share,
initial_comment=initial_comment,
thread_ts=thread_ts,
token=kwargs.get("token"),
**kwargs,
)
if request_file_info is True:
await _attach_full_file_metadata_async(
client=self,
token_as_arg=kwargs.get("token"),
completion=completion,
)
return completion
async def files_getUploadURLExternal(
self,
*,
filename: str,
length: int,
alt_txt: Optional[str] = None,
snippet_type: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets a URL for an edge external upload.
https://api.slack.com/methods/files.getUploadURLExternal
"""
kwargs.update(
{
"filename": filename,
"length": length,
"alt_txt": alt_txt,
"snippet_type": snippet_type,
}
)
return await self.api_call("files.getUploadURLExternal", params=kwargs)
async def files_completeUploadExternal(
self,
*,
files: List[Dict[str, str]],
channel_id: Optional[str] = None,
initial_comment: Optional[str] = None,
thread_ts: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Finishes an upload started with files.getUploadURLExternal.
https://api.slack.com/methods/files.completeUploadExternal
"""
_files = [{k: v for k, v in f.items() if v is not None} for f in files]
kwargs.update(
{
"files": json.dumps(_files),
"channel_id": channel_id,
"initial_comment": initial_comment,
"thread_ts": thread_ts,
}
)
return await self.api_call("files.completeUploadExternal", params=kwargs)
# --------------------------
# Deprecated: groups.*
# You can use conversations.* APIs instead.
# https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api
# --------------------------
async def groups_archive(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Archives a private channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.archive", json=kwargs)
async def groups_create(
self,
*,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Creates a private channel."""
kwargs.update({"name": name})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.create", json=kwargs)
async def groups_createChild(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Clones and archives a private channel."""
kwargs.update({"channel": channel})
return await self.api_call("groups.createChild", http_verb="GET", params=kwargs)
async def groups_history(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Fetches history of messages and events from a private channel."""
kwargs.update({"channel": channel})
return await self.api_call("groups.history", http_verb="GET", params=kwargs)
async def groups_info(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about a private channel."""
kwargs.update({"channel": channel})
return await self.api_call("groups.info", http_verb="GET", params=kwargs)
async def groups_invite(
self,
*,
channel: str,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Invites a user to a private channel."""
kwargs.update({"channel": channel, "user": user})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.invite", json=kwargs)
async def groups_kick(
self,
*,
channel: str,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Removes a user from a private channel."""
kwargs.update({"channel": channel, "user": user})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.kick", json=kwargs)
async def groups_leave(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Leaves a private channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.leave", json=kwargs)
async def groups_list(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Lists private channels that the calling user has access to."""
return await self.api_call("groups.list", http_verb="GET", params=kwargs)
async def groups_mark(
self,
*,
channel: str,
ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the read cursor in a private channel."""
kwargs.update({"channel": channel, "ts": ts})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.mark", json=kwargs)
async def groups_open(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Opens a private channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.open", json=kwargs)
async def groups_rename(
self,
*,
channel: str,
name: str,
**kwargs,
) -> AsyncSlackResponse:
"""Renames a private channel."""
kwargs.update({"channel": channel, "name": name})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.rename", json=kwargs)
async def groups_replies(
self,
*,
channel: str,
thread_ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a thread of messages posted to a private channel"""
kwargs.update({"channel": channel, "thread_ts": thread_ts})
return await self.api_call("groups.replies", http_verb="GET", params=kwargs)
async def groups_setPurpose(
self,
*,
channel: str,
purpose: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the purpose for a private channel."""
kwargs.update({"channel": channel, "purpose": purpose})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.setPurpose", json=kwargs)
async def groups_setTopic(
self,
*,
channel: str,
topic: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the topic for a private channel."""
kwargs.update({"channel": channel, "topic": topic})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.setTopic", json=kwargs)
async def groups_unarchive(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Unarchives a private channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("groups.unarchive", json=kwargs)
# --------------------------
# Deprecated: im.*
# You can use conversations.* APIs instead.
# https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api
# --------------------------
async def im_close(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Close a direct message channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("im.close", json=kwargs)
async def im_history(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Fetches history of messages and events from direct message channel."""
kwargs.update({"channel": channel})
return await self.api_call("im.history", http_verb="GET", params=kwargs)
async def im_list(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Lists direct message channels for the calling user."""
return await self.api_call("im.list", http_verb="GET", params=kwargs)
async def im_mark(
self,
*,
channel: str,
ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the read cursor in a direct message channel."""
kwargs.update({"channel": channel, "ts": ts})
kwargs = _remove_none_values(kwargs)
return await self.api_call("im.mark", json=kwargs)
async def im_open(
self,
*,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Opens a direct message channel."""
kwargs.update({"user": user})
kwargs = _remove_none_values(kwargs)
return await self.api_call("im.open", json=kwargs)
async def im_replies(
self,
*,
channel: str,
thread_ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a thread of messages posted to a direct message conversation"""
kwargs.update({"channel": channel, "thread_ts": thread_ts})
return await self.api_call("im.replies", http_verb="GET", params=kwargs)
# --------------------------
async def migration_exchange(
self,
*,
users: Union[str, Sequence[str]],
team_id: Optional[str] = None,
to_old: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""For Enterprise Grid workspaces, map local user IDs to global user IDs
https://api.slack.com/methods/migration.exchange
"""
if isinstance(users, (list, Tuple)):
kwargs.update({"users": ",".join(users)})
else:
kwargs.update({"users": users})
kwargs.update({"team_id": team_id, "to_old": to_old})
return await self.api_call("migration.exchange", http_verb="GET", params=kwargs)
# --------------------------
# Deprecated: mpim.*
# You can use conversations.* APIs instead.
# https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api
# --------------------------
async def mpim_close(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Closes a multiparty direct message channel."""
kwargs.update({"channel": channel})
kwargs = _remove_none_values(kwargs)
return await self.api_call("mpim.close", json=kwargs)
async def mpim_history(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Fetches history of messages and events from a multiparty direct message."""
kwargs.update({"channel": channel})
return await self.api_call("mpim.history", http_verb="GET", params=kwargs)
async def mpim_list(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Lists multiparty direct message channels for the calling user."""
return await self.api_call("mpim.list", http_verb="GET", params=kwargs)
async def mpim_mark(
self,
*,
channel: str,
ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Sets the read cursor in a multiparty direct message channel."""
kwargs.update({"channel": channel, "ts": ts})
kwargs = _remove_none_values(kwargs)
return await self.api_call("mpim.mark", json=kwargs)
async def mpim_open(
self,
*,
users: Union[str, Sequence[str]],
**kwargs,
) -> AsyncSlackResponse:
"""This method opens a multiparty direct message."""
if isinstance(users, (list, Tuple)):
kwargs.update({"users": ",".join(users)})
else:
kwargs.update({"users": users})
return await self.api_call("mpim.open", params=kwargs)
async def mpim_replies(
self,
*,
channel: str,
thread_ts: str,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a thread of messages posted to a direct message conversation from a
multiparty direct message.
"""
kwargs.update({"channel": channel, "thread_ts": thread_ts})
return await self.api_call("mpim.replies", http_verb="GET", params=kwargs)
# --------------------------
async def oauth_v2_access(
self,
*,
client_id: str,
client_secret: str,
# This field is required when processing the OAuth redirect URL requests
# while it's absent for token rotation
code: Optional[str] = None,
redirect_uri: Optional[str] = None,
# This field is required for token rotation
grant_type: Optional[str] = None,
# This field is required for token rotation
refresh_token: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Exchanges a temporary OAuth verifier code for an access token.
https://api.slack.com/methods/oauth.v2.access
"""
if redirect_uri is not None:
kwargs.update({"redirect_uri": redirect_uri})
if code is not None:
kwargs.update({"code": code})
if grant_type is not None:
kwargs.update({"grant_type": grant_type})
if refresh_token is not None:
kwargs.update({"refresh_token": refresh_token})
return await self.api_call(
"oauth.v2.access",
data=kwargs,
auth={"client_id": client_id, "client_secret": client_secret},
)
async def oauth_access(
self,
*,
client_id: str,
client_secret: str,
code: str,
redirect_uri: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Exchanges a temporary OAuth verifier code for an access token.
https://api.slack.com/methods/oauth.access
"""
if redirect_uri is not None:
kwargs.update({"redirect_uri": redirect_uri})
kwargs.update({"code": code})
return await self.api_call(
"oauth.access",
data=kwargs,
auth={"client_id": client_id, "client_secret": client_secret},
)
async def oauth_v2_exchange(
self,
*,
token: str,
client_id: str,
client_secret: str,
**kwargs,
) -> AsyncSlackResponse:
"""Exchanges a legacy access token for a new expiring access token and refresh token
https://api.slack.com/methods/oauth.v2.exchange
"""
kwargs.update({"client_id": client_id, "client_secret": client_secret, "token": token})
return await self.api_call("oauth.v2.exchange", params=kwargs)
async def openid_connect_token(
self,
client_id: str,
client_secret: str,
code: Optional[str] = None,
redirect_uri: Optional[str] = None,
grant_type: Optional[str] = None,
refresh_token: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Exchanges a temporary OAuth verifier code for an access token for Sign in with Slack.
https://api.slack.com/methods/openid.connect.token
"""
if redirect_uri is not None:
kwargs.update({"redirect_uri": redirect_uri})
if code is not None:
kwargs.update({"code": code})
if grant_type is not None:
kwargs.update({"grant_type": grant_type})
if refresh_token is not None:
kwargs.update({"refresh_token": refresh_token})
return await self.api_call(
"openid.connect.token",
data=kwargs,
auth={"client_id": client_id, "client_secret": client_secret},
)
async def openid_connect_userInfo(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Get the identity of a user who has authorized Sign in with Slack.
https://api.slack.com/methods/openid.connect.userInfo
"""
return await self.api_call("openid.connect.userInfo", params=kwargs)
async def pins_add(
self,
*,
channel: str,
timestamp: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Pins an item to a channel.
https://api.slack.com/methods/pins.add
"""
kwargs.update({"channel": channel, "timestamp": timestamp})
return await self.api_call("pins.add", params=kwargs)
async def pins_list(
self,
*,
channel: str,
**kwargs,
) -> AsyncSlackResponse:
"""Lists items pinned to a channel.
https://api.slack.com/methods/pins.list
"""
kwargs.update({"channel": channel})
return await self.api_call("pins.list", http_verb="GET", params=kwargs)
async def pins_remove(
self,
*,
channel: str,
timestamp: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Un-pins an item from a channel.
https://api.slack.com/methods/pins.remove
"""
kwargs.update({"channel": channel, "timestamp": timestamp})
return await self.api_call("pins.remove", params=kwargs)
async def reactions_add(
self,
*,
channel: str,
name: str,
timestamp: str,
**kwargs,
) -> AsyncSlackResponse:
"""Adds a reaction to an item.
https://api.slack.com/methods/reactions.add
"""
kwargs.update({"channel": channel, "name": name, "timestamp": timestamp})
return await self.api_call("reactions.add", params=kwargs)
async def reactions_get(
self,
*,
channel: Optional[str] = None,
file: Optional[str] = None,
file_comment: Optional[str] = None,
full: Optional[bool] = None,
timestamp: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets reactions for an item.
https://api.slack.com/methods/reactions.get
"""
kwargs.update(
{
"channel": channel,
"file": file,
"file_comment": file_comment,
"full": full,
"timestamp": timestamp,
}
)
return await self.api_call("reactions.get", http_verb="GET", params=kwargs)
async def reactions_list(
self,
*,
count: Optional[int] = None,
cursor: Optional[str] = None,
full: Optional[bool] = None,
limit: Optional[int] = None,
page: Optional[int] = None,
team_id: Optional[str] = None,
user: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists reactions made by a user.
https://api.slack.com/methods/reactions.list
"""
kwargs.update(
{
"count": count,
"cursor": cursor,
"full": full,
"limit": limit,
"page": page,
"team_id": team_id,
"user": user,
}
)
return await self.api_call("reactions.list", http_verb="GET", params=kwargs)
async def reactions_remove(
self,
*,
name: str,
channel: Optional[str] = None,
file: Optional[str] = None,
file_comment: Optional[str] = None,
timestamp: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Removes a reaction from an item.
https://api.slack.com/methods/reactions.remove
"""
kwargs.update(
{
"name": name,
"channel": channel,
"file": file,
"file_comment": file_comment,
"timestamp": timestamp,
}
)
return await self.api_call("reactions.remove", params=kwargs)
async def reminders_add(
self,
*,
text: str,
time: str,
team_id: Optional[str] = None,
user: Optional[str] = None,
recurrence: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Creates a reminder.
https://api.slack.com/methods/reminders.add
"""
kwargs.update(
{
"text": text,
"time": time,
"team_id": team_id,
"user": user,
"recurrence": recurrence,
}
)
return await self.api_call("reminders.add", params=kwargs)
async def reminders_complete(
self,
*,
reminder: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Marks a reminder as complete.
https://api.slack.com/methods/reminders.complete
"""
kwargs.update({"reminder": reminder, "team_id": team_id})
return await self.api_call("reminders.complete", params=kwargs)
async def reminders_delete(
self,
*,
reminder: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Deletes a reminder.
https://api.slack.com/methods/reminders.delete
"""
kwargs.update({"reminder": reminder, "team_id": team_id})
return await self.api_call("reminders.delete", params=kwargs)
async def reminders_info(
self,
*,
reminder: str,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about a reminder.
https://api.slack.com/methods/reminders.info
"""
kwargs.update({"reminder": reminder, "team_id": team_id})
return await self.api_call("reminders.info", http_verb="GET", params=kwargs)
async def reminders_list(
self,
*,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists all reminders created by or for a given user.
https://api.slack.com/methods/reminders.list
"""
kwargs.update({"team_id": team_id})
return await self.api_call("reminders.list", http_verb="GET", params=kwargs)
async def rtm_connect(
self,
*,
batch_presence_aware: Optional[bool] = None,
presence_sub: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Starts a Real Time Messaging session.
https://api.slack.com/methods/rtm.connect
"""
kwargs.update({"batch_presence_aware": batch_presence_aware, "presence_sub": presence_sub})
return await self.api_call("rtm.connect", http_verb="GET", params=kwargs)
async def rtm_start(
self,
*,
batch_presence_aware: Optional[bool] = None,
include_locale: Optional[bool] = None,
mpim_aware: Optional[bool] = None,
no_latest: Optional[bool] = None,
no_unreads: Optional[bool] = None,
presence_sub: Optional[bool] = None,
simple_latest: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Starts a Real Time Messaging session.
https://api.slack.com/methods/rtm.start
"""
kwargs.update(
{
"batch_presence_aware": batch_presence_aware,
"include_locale": include_locale,
"mpim_aware": mpim_aware,
"no_latest": no_latest,
"no_unreads": no_unreads,
"presence_sub": presence_sub,
"simple_latest": simple_latest,
}
)
return await self.api_call("rtm.start", http_verb="GET", params=kwargs)
async def search_all(
self,
*,
query: str,
count: Optional[int] = None,
highlight: Optional[bool] = None,
page: Optional[int] = None,
sort: Optional[str] = None,
sort_dir: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Searches for messages and files matching a query.
https://api.slack.com/methods/search.all
"""
kwargs.update(
{
"query": query,
"count": count,
"highlight": highlight,
"page": page,
"sort": sort,
"sort_dir": sort_dir,
"team_id": team_id,
}
)
return await self.api_call("search.all", http_verb="GET", params=kwargs)
async def search_files(
self,
*,
query: str,
count: Optional[int] = None,
highlight: Optional[bool] = None,
page: Optional[int] = None,
sort: Optional[str] = None,
sort_dir: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Searches for files matching a query.
https://api.slack.com/methods/search.files
"""
kwargs.update(
{
"query": query,
"count": count,
"highlight": highlight,
"page": page,
"sort": sort,
"sort_dir": sort_dir,
"team_id": team_id,
}
)
return await self.api_call("search.files", http_verb="GET", params=kwargs)
async def search_messages(
self,
*,
query: str,
count: Optional[int] = None,
cursor: Optional[str] = None,
highlight: Optional[bool] = None,
page: Optional[int] = None,
sort: Optional[str] = None,
sort_dir: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Searches for messages matching a query.
https://api.slack.com/methods/search.messages
"""
kwargs.update(
{
"query": query,
"count": count,
"cursor": cursor,
"highlight": highlight,
"page": page,
"sort": sort,
"sort_dir": sort_dir,
"team_id": team_id,
}
)
return await self.api_call("search.messages", http_verb="GET", params=kwargs)
async def stars_add(
self,
*,
channel: Optional[str] = None,
file: Optional[str] = None,
file_comment: Optional[str] = None,
timestamp: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Adds a star to an item.
https://api.slack.com/methods/stars.add
"""
kwargs.update(
{
"channel": channel,
"file": file,
"file_comment": file_comment,
"timestamp": timestamp,
}
)
return await self.api_call("stars.add", params=kwargs)
async def stars_list(
self,
*,
count: Optional[int] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
page: Optional[int] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists stars for a user.
https://api.slack.com/methods/stars.list
"""
kwargs.update(
{
"count": count,
"cursor": cursor,
"limit": limit,
"page": page,
"team_id": team_id,
}
)
return await self.api_call("stars.list", http_verb="GET", params=kwargs)
async def stars_remove(
self,
*,
channel: Optional[str] = None,
file: Optional[str] = None,
file_comment: Optional[str] = None,
timestamp: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Removes a star from an item.
https://api.slack.com/methods/stars.remove
"""
kwargs.update(
{
"channel": channel,
"file": file,
"file_comment": file_comment,
"timestamp": timestamp,
}
)
return await self.api_call("stars.remove", params=kwargs)
async def team_accessLogs(
self,
*,
before: Optional[Union[int, str]] = None,
count: Optional[Union[int, str]] = None,
page: Optional[Union[int, str]] = None,
team_id: Optional[str] = None,
cursor: Optional[str] = None,
limit: Optional[int] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets the access logs for the current team.
https://api.slack.com/methods/team.accessLogs
"""
kwargs.update(
{
"before": before,
"count": count,
"page": page,
"team_id": team_id,
"cursor": cursor,
"limit": limit,
}
)
return await self.api_call("team.accessLogs", http_verb="GET", params=kwargs)
async def team_billableInfo(
self,
*,
team_id: Optional[str] = None,
user: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets billable users information for the current team.
https://api.slack.com/methods/team.billableInfo
"""
kwargs.update({"team_id": team_id, "user": user})
return await self.api_call("team.billableInfo", http_verb="GET", params=kwargs)
async def team_billing_info(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Reads a workspace's billing plan information.
https://api.slack.com/methods/team.billing.info
"""
return await self.api_call("team.billing.info", params=kwargs)
async def team_info(
self,
*,
team: Optional[str] = None,
domain: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about the current team.
https://api.slack.com/methods/team.info
"""
kwargs.update({"team": team, "domain": domain})
return await self.api_call("team.info", http_verb="GET", params=kwargs)
async def team_integrationLogs(
self,
*,
app_id: Optional[str] = None,
change_type: Optional[str] = None,
count: Optional[Union[int, str]] = None,
page: Optional[Union[int, str]] = None,
service_id: Optional[str] = None,
team_id: Optional[str] = None,
user: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets the integration logs for the current team.
https://api.slack.com/methods/team.integrationLogs
"""
kwargs.update(
{
"app_id": app_id,
"change_type": change_type,
"count": count,
"page": page,
"service_id": service_id,
"team_id": team_id,
"user": user,
}
)
return await self.api_call("team.integrationLogs", http_verb="GET", params=kwargs)
async def team_profile_get(
self,
*,
visibility: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a team's profile.
https://api.slack.com/methods/team.profile.get
"""
kwargs.update({"visibility": visibility})
return await self.api_call("team.profile.get", http_verb="GET", params=kwargs)
async def team_preferences_list(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieve a list of a workspace's team preferences.
https://api.slack.com/methods/team.preferences.list
"""
return await self.api_call("team.preferences.list", params=kwargs)
async def usergroups_create(
self,
*,
name: str,
channels: Optional[Union[str, Sequence[str]]] = None,
description: Optional[str] = None,
handle: Optional[str] = None,
include_count: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Create a User Group
https://api.slack.com/methods/usergroups.create
"""
kwargs.update(
{
"name": name,
"description": description,
"handle": handle,
"include_count": include_count,
"team_id": team_id,
}
)
if isinstance(channels, (list, Tuple)):
kwargs.update({"channels": ",".join(channels)})
else:
kwargs.update({"channels": channels})
return await self.api_call("usergroups.create", params=kwargs)
async def usergroups_disable(
self,
*,
usergroup: str,
include_count: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Disable an existing User Group
https://api.slack.com/methods/usergroups.disable
"""
kwargs.update({"usergroup": usergroup, "include_count": include_count, "team_id": team_id})
return await self.api_call("usergroups.disable", params=kwargs)
async def usergroups_enable(
self,
*,
usergroup: str,
include_count: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Enable a User Group
https://api.slack.com/methods/usergroups.enable
"""
kwargs.update({"usergroup": usergroup, "include_count": include_count, "team_id": team_id})
return await self.api_call("usergroups.enable", params=kwargs)
async def usergroups_list(
self,
*,
include_count: Optional[bool] = None,
include_disabled: Optional[bool] = None,
include_users: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all User Groups for a team
https://api.slack.com/methods/usergroups.list
"""
kwargs.update(
{
"include_count": include_count,
"include_disabled": include_disabled,
"include_users": include_users,
"team_id": team_id,
}
)
return await self.api_call("usergroups.list", http_verb="GET", params=kwargs)
async def usergroups_update(
self,
*,
usergroup: str,
channels: Optional[Union[str, Sequence[str]]] = None,
description: Optional[str] = None,
handle: Optional[str] = None,
include_count: Optional[bool] = None,
name: Optional[str] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Update an existing User Group
https://api.slack.com/methods/usergroups.update
"""
kwargs.update(
{
"usergroup": usergroup,
"description": description,
"handle": handle,
"include_count": include_count,
"name": name,
"team_id": team_id,
}
)
if isinstance(channels, (list, Tuple)):
kwargs.update({"channels": ",".join(channels)})
else:
kwargs.update({"channels": channels})
return await self.api_call("usergroups.update", params=kwargs)
async def usergroups_users_list(
self,
*,
usergroup: str,
include_disabled: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List all users in a User Group
https://api.slack.com/methods/usergroups.users.list
"""
kwargs.update(
{
"usergroup": usergroup,
"include_disabled": include_disabled,
"team_id": team_id,
}
)
return await self.api_call("usergroups.users.list", http_verb="GET", params=kwargs)
async def usergroups_users_update(
self,
*,
usergroup: str,
users: Union[str, Sequence[str]],
include_count: Optional[bool] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Update the list of users for a User Group
https://api.slack.com/methods/usergroups.users.update
"""
kwargs.update(
{
"usergroup": usergroup,
"include_count": include_count,
"team_id": team_id,
}
)
if isinstance(users, (list, Tuple)):
kwargs.update({"users": ",".join(users)})
else:
kwargs.update({"users": users})
return await self.api_call("usergroups.users.update", params=kwargs)
async def users_conversations(
self,
*,
cursor: Optional[str] = None,
exclude_archived: Optional[bool] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
types: Optional[Union[str, Sequence[str]]] = None,
user: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""List conversations the calling user may access.
https://api.slack.com/methods/users.conversations
"""
kwargs.update(
{
"cursor": cursor,
"exclude_archived": exclude_archived,
"limit": limit,
"team_id": team_id,
"user": user,
}
)
if isinstance(types, (list, Tuple)):
kwargs.update({"types": ",".join(types)})
else:
kwargs.update({"types": types})
return await self.api_call("users.conversations", http_verb="GET", params=kwargs)
async def users_deletePhoto(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Delete the user profile photo
https://api.slack.com/methods/users.deletePhoto
"""
return await self.api_call("users.deletePhoto", http_verb="GET", params=kwargs)
async def users_getPresence(
self,
*,
user: str,
**kwargs,
) -> AsyncSlackResponse:
"""Gets user presence information.
https://api.slack.com/methods/users.getPresence
"""
kwargs.update({"user": user})
return await self.api_call("users.getPresence", http_verb="GET", params=kwargs)
async def users_identity(
self,
**kwargs,
) -> AsyncSlackResponse:
"""Get a user's identity.
https://api.slack.com/methods/users.identity
"""
return await self.api_call("users.identity", http_verb="GET", params=kwargs)
async def users_info(
self,
*,
user: str,
include_locale: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Gets information about a user.
https://api.slack.com/methods/users.info
"""
kwargs.update({"user": user, "include_locale": include_locale})
return await self.api_call("users.info", http_verb="GET", params=kwargs)
async def users_list(
self,
*,
cursor: Optional[str] = None,
include_locale: Optional[bool] = None,
limit: Optional[int] = None,
team_id: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Lists all users in a Slack team.
https://api.slack.com/methods/users.list
"""
kwargs.update(
{
"cursor": cursor,
"include_locale": include_locale,
"limit": limit,
"team_id": team_id,
}
)
return await self.api_call("users.list", http_verb="GET", params=kwargs)
async def users_lookupByEmail(
self,
*,
email: str,
**kwargs,
) -> AsyncSlackResponse:
"""Find a user with an email address.
https://api.slack.com/methods/users.lookupByEmail
"""
kwargs.update({"email": email})
return await self.api_call("users.lookupByEmail", http_verb="GET", params=kwargs)
async def users_setPhoto(
self,
*,
image: Union[str, IOBase],
crop_w: Optional[Union[int, str]] = None,
crop_x: Optional[Union[int, str]] = None,
crop_y: Optional[Union[int, str]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set the user profile photo
https://api.slack.com/methods/users.setPhoto
"""
kwargs.update({"crop_w": crop_w, "crop_x": crop_x, "crop_y": crop_y})
return await self.api_call("users.setPhoto", files={"image": image}, data=kwargs)
async def users_setPresence(
self,
*,
presence: str,
**kwargs,
) -> AsyncSlackResponse:
"""Manually sets user presence.
https://api.slack.com/methods/users.setPresence
"""
kwargs.update({"presence": presence})
return await self.api_call("users.setPresence", params=kwargs)
async def users_profile_get(
self,
*,
user: Optional[str] = None,
include_labels: Optional[bool] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Retrieves a user's profile information.
https://api.slack.com/methods/users.profile.get
"""
kwargs.update({"user": user, "include_labels": include_labels})
return await self.api_call("users.profile.get", http_verb="GET", params=kwargs)
async def users_profile_set(
self,
*,
name: Optional[str] = None,
value: Optional[str] = None,
user: Optional[str] = None,
profile: Optional[Dict] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Set the profile information for a user.
https://api.slack.com/methods/users.profile.set
"""
kwargs.update(
{
"name": name,
"profile": profile,
"user": user,
"value": value,
}
)
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "profile" parameter
return await self.api_call("users.profile.set", json=kwargs)
async def views_open(
self,
*,
trigger_id: str,
view: Union[dict, View],
**kwargs,
) -> AsyncSlackResponse:
"""Open a view for a user.
https://api.slack.com/methods/views.open
See https://api.slack.com/block-kit/surfaces/modals for details.
"""
kwargs.update({"trigger_id": trigger_id})
if isinstance(view, View):
kwargs.update({"view": view.to_dict()})
else:
kwargs.update({"view": view})
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "view" parameter
return await self.api_call("views.open", json=kwargs)
async def views_push(
self,
*,
trigger_id: str,
view: Union[dict, View],
**kwargs,
) -> AsyncSlackResponse:
"""Push a view onto the stack of a root view.
Push a new view onto the existing view stack by passing a view
payload and a valid trigger_id generated from an interaction
within the existing modal.
Read the modals documentation (https://api.slack.com/block-kit/surfaces/modals)
to learn more about the lifecycle and intricacies of views.
https://api.slack.com/methods/views.push
"""
kwargs.update({"trigger_id": trigger_id})
if isinstance(view, View):
kwargs.update({"view": view.to_dict()})
else:
kwargs.update({"view": view})
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "view" parameter
return await self.api_call("views.push", json=kwargs)
async def views_update(
self,
*,
view: Union[dict, View],
external_id: Optional[str] = None,
view_id: Optional[str] = None,
hash: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Update an existing view.
Update a view by passing a new view definition along with the
view_id returned in views.open or the external_id.
See the modals documentation (https://api.slack.com/block-kit/surfaces/modals#updating_views)
to learn more about updating views and avoiding race conditions with the hash argument.
https://api.slack.com/methods/views.update
"""
if isinstance(view, View):
kwargs.update({"view": view.to_dict()})
else:
kwargs.update({"view": view})
if external_id:
kwargs.update({"external_id": external_id})
elif view_id:
kwargs.update({"view_id": view_id})
else:
raise e.SlackRequestError("Either view_id or external_id is required.")
kwargs.update({"hash": hash})
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "view" parameter
return await self.api_call("views.update", json=kwargs)
async def views_publish(
self,
*,
user_id: str,
view: Union[dict, View],
hash: Optional[str] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Publish a static view for a User.
Create or update the view that comprises an
app's Home tab (https://api.slack.com/surfaces/tabs)
https://api.slack.com/methods/views.publish
"""
kwargs.update({"user_id": user_id, "hash": hash})
if isinstance(view, View):
kwargs.update({"view": view.to_dict()})
else:
kwargs.update({"view": view})
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "view" parameter
return await self.api_call("views.publish", json=kwargs)
async def workflows_stepCompleted(
self,
*,
workflow_step_execute_id: str,
outputs: Optional[dict] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Indicate a successful outcome of a workflow step's execution.
https://api.slack.com/methods/workflows.stepCompleted
"""
kwargs.update({"workflow_step_execute_id": workflow_step_execute_id})
if outputs is not None:
kwargs.update({"outputs": outputs})
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "outputs" parameter
return await self.api_call("workflows.stepCompleted", json=kwargs)
async def workflows_stepFailed(
self,
*,
workflow_step_execute_id: str,
error: Dict[str, str],
**kwargs,
) -> AsyncSlackResponse:
"""Indicate an unsuccessful outcome of a workflow step's execution.
https://api.slack.com/methods/workflows.stepFailed
"""
kwargs.update(
{
"workflow_step_execute_id": workflow_step_execute_id,
"error": error,
}
)
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "error" parameter
return await self.api_call("workflows.stepFailed", json=kwargs)
async def workflows_updateStep(
self,
*,
workflow_step_edit_id: str,
inputs: Optional[Dict[str, Any]] = None,
outputs: Optional[List[Dict[str, str]]] = None,
**kwargs,
) -> AsyncSlackResponse:
"""Update the configuration for a workflow extension step.
https://api.slack.com/methods/workflows.updateStep
"""
kwargs.update({"workflow_step_edit_id": workflow_step_edit_id})
if inputs is not None:
kwargs.update({"inputs": inputs})
if outputs is not None:
kwargs.update({"outputs": outputs})
kwargs = _remove_none_values(kwargs)
# NOTE: Intentionally using json for the "inputs" / "outputs" parameters
return await self.api_call("workflows.updateStep", json=kwargs)
Classes
class AsyncWebClient (token: Optional[str] = None, base_url: str = 'https://www.slack.com/api/', timeout: int = 30, ssl: Optional[ssl.SSLContext] = None, proxy: Optional[str] = None, session: Optional[aiohttp.client.ClientSession] = None, trust_env_in_session: bool = False, headers: Optional[dict] = None, user_agent_prefix: Optional[str] = None, user_agent_suffix: Optional[str] = None, team_id: Optional[str] = None, logger: Optional[logging.Logger] = None, retry_handlers: Optional[List[slack_sdk.http_retry.async_handler.AsyncRetryHandler]] = None)
-
A WebClient allows apps to communicate with the Slack Platform's Web API.
The Slack Web API is an interface for querying information from and enacting change in a Slack workspace.
This client handles constructing and sending HTTP requests to Slack as well as parsing any responses received into a
SlackResponse
.Attributes
token
:str
- A string specifying an
xoxp-*
orxoxb-*
token. base_url
:str
- A string representing the Slack API base URL.
Default is
'https://www.slack.com/api/'
timeout
:int
- The maximum number of seconds the client will wait to connect and receive a response from Slack. Default is 30 seconds.
ssl
:SSLContext
- An
ssl.SSLContext
instance, helpful for specifying your own custom certificate chain. proxy
:str
- String representing a fully-qualified URL to a proxy through
which to route all requests to the Slack API. Even if this parameter
is not specified, if any of the following environment variables are
present, they will be loaded into this parameter:
HTTPS_PROXY
,https_proxy
,HTTP_PROXY
orhttp_proxy
. headers
:dict
- Additional request headers to attach to all requests.
Methods
api_call
: Constructs a request and executes the API call to Slack.Example of recommended usage:
import os from slack_sdk.web.async_client import AsyncWebClient client = AsyncWebClient(token=os.environ['SLACK_API_TOKEN']) response = client.chat_postMessage( channel='#random', text="Hello world!") assert response["ok"] assert response["message"]["text"] == "Hello world!"
Example manually creating an API request:
import os from slack_sdk.web.async_client import AsyncWebClient client = AsyncWebClient(token=os.environ['SLACK_API_TOKEN']) response = client.api_call( api_method='chat.postMessage', json={'channel': '#random','text': "Hello world!"} ) assert response["ok"] assert response["message"]["text"] == "Hello world!"
Note
Any attributes or methods prefixed with _underscores are intended to be "private" internal use only. They may be changed or removed at anytime.
Expand source code
class AsyncWebClient(AsyncBaseClient): """A WebClient allows apps to communicate with the Slack Platform's Web API. https://api.slack.com/methods The Slack Web API is an interface for querying information from and enacting change in a Slack workspace. This client handles constructing and sending HTTP requests to Slack as well as parsing any responses received into a `SlackResponse`. Attributes: token (str): A string specifying an `xoxp-*` or `xoxb-*` token. base_url (str): A string representing the Slack API base URL. Default is `'https://www.slack.com/api/'` timeout (int): The maximum number of seconds the client will wait to connect and receive a response from Slack. Default is 30 seconds. ssl (SSLContext): An [`ssl.SSLContext`][1] instance, helpful for specifying your own custom certificate chain. proxy (str): String representing a fully-qualified URL to a proxy through which to route all requests to the Slack API. Even if this parameter is not specified, if any of the following environment variables are present, they will be loaded into this parameter: `HTTPS_PROXY`, `https_proxy`, `HTTP_PROXY` or `http_proxy`. headers (dict): Additional request headers to attach to all requests. Methods: `api_call`: Constructs a request and executes the API call to Slack. Example of recommended usage: ```python import os from slack_sdk.web.async_client import AsyncWebClient client = AsyncWebClient(token=os.environ['SLACK_API_TOKEN']) response = client.chat_postMessage( channel='#random', text="Hello world!") assert response["ok"] assert response["message"]["text"] == "Hello world!" ``` Example manually creating an API request: ```python import os from slack_sdk.web.async_client import AsyncWebClient client = AsyncWebClient(token=os.environ['SLACK_API_TOKEN']) response = client.api_call( api_method='chat.postMessage', json={'channel': '#random','text': "Hello world!"} ) assert response["ok"] assert response["message"]["text"] == "Hello world!" ``` Note: Any attributes or methods prefixed with _underscores are intended to be "private" internal use only. They may be changed or removed at anytime. [1]: https://docs.python.org/3/library/ssl.html#ssl.SSLContext """ async def admin_analytics_getFile( self, *, type: str, date: Optional[str] = None, metadata_only: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve analytics data for a given date, presented as a compressed JSON file https://api.slack.com/methods/admin.analytics.getFile """ kwargs.update({"type": type}) if date is not None: kwargs.update({"date": date}) if metadata_only is not None: kwargs.update({"metadata_only": metadata_only}) return await self.api_call("admin.analytics.getFile", params=kwargs) async def admin_apps_approve( self, *, app_id: Optional[str] = None, request_id: Optional[str] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Approve an app for installation on a workspace. Either app_id or request_id is required. These IDs can be obtained either directly via the app_requested event, or by the admin.apps.requests.list method. https://api.slack.com/methods/admin.apps.approve """ if app_id: kwargs.update({"app_id": app_id}) elif request_id: kwargs.update({"request_id": request_id}) else: raise e.SlackRequestError("The app_id or request_id argument must be specified.") kwargs.update( { "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.approve", params=kwargs) async def admin_apps_approved_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List approved apps for an org or workspace. https://api.slack.com/methods/admin.apps.approved.list """ kwargs.update( { "cursor": cursor, "limit": limit, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.approved.list", http_verb="GET", params=kwargs) async def admin_apps_clearResolution( self, *, app_id: str, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Clear an app resolution https://api.slack.com/methods/admin.apps.clearResolution """ kwargs.update( { "app_id": app_id, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.clearResolution", http_verb="POST", params=kwargs) async def admin_apps_requests_cancel( self, *, request_id: str, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List app requests for a team/workspace. https://api.slack.com/methods/admin.apps.requests.cancel """ kwargs.update( { "request_id": request_id, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.requests.cancel", http_verb="POST", params=kwargs) async def admin_apps_requests_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List app requests for a team/workspace. https://api.slack.com/methods/admin.apps.requests.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.apps.requests.list", http_verb="GET", params=kwargs) async def admin_apps_restrict( self, *, app_id: Optional[str] = None, request_id: Optional[str] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Restrict an app for installation on a workspace. Exactly one of the team_id or enterprise_id arguments is required, not both. Either app_id or request_id is required. These IDs can be obtained either directly via the app_requested event, or by the admin.apps.requests.list method. https://api.slack.com/methods/admin.apps.restrict """ if app_id: kwargs.update({"app_id": app_id}) elif request_id: kwargs.update({"request_id": request_id}) else: raise e.SlackRequestError("The app_id or request_id argument must be specified.") kwargs.update( { "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.restrict", params=kwargs) async def admin_apps_restricted_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List restricted apps for an org or workspace. https://api.slack.com/methods/admin.apps.restricted.list """ kwargs.update( { "cursor": cursor, "limit": limit, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.restricted.list", http_verb="GET", params=kwargs) async def admin_apps_uninstall( self, *, app_id: str, enterprise_id: Optional[str] = None, team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Uninstall an app from one or many workspaces, or an entire enterprise organization. With an org-level token, enterprise_id or team_ids is required. https://api.slack.com/methods/admin.apps.uninstall """ kwargs.update({"app_id": app_id}) if enterprise_id is not None: kwargs.update({"enterprise_id": enterprise_id}) if team_ids is not None: if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.apps.uninstall", http_verb="POST", params=kwargs) async def admin_apps_activities_list( self, *, app_id: Optional[str] = None, component_id: Optional[str] = None, component_type: Optional[str] = None, log_event_type: Optional[str] = None, max_date_created: Optional[int] = None, min_date_created: Optional[int] = None, min_log_level: Optional[str] = None, sort_direction: Optional[str] = None, source: Optional[str] = None, team_id: Optional[str] = None, trace_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Get logs for a specified team/org https://api.slack.com/methods/admin.apps.activities.list """ kwargs.update( { "app_id": app_id, "component_id": component_id, "component_type": component_type, "log_event_type": log_event_type, "max_date_created": max_date_created, "min_date_created": min_date_created, "min_log_level": min_log_level, "sort_direction": sort_direction, "source": source, "team_id": team_id, "trace_id": trace_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.apps.activities.list", params=kwargs) async def admin_apps_config_lookup( self, *, app_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Look up the app config for connectors by their IDs https://api.slack.com/methods/admin.apps.config.lookup """ if isinstance(app_ids, (list, Tuple)): kwargs.update({"app_ids": ",".join(app_ids)}) else: kwargs.update({"app_ids": app_ids}) return await self.api_call("admin.apps.config.lookup", params=kwargs) async def admin_apps_config_set( self, *, app_id: str, domain_restrictions: Optional[Dict[str, Any]] = None, workflow_auth_strategy: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Set the app config for a connector https://api.slack.com/methods/admin.apps.config.set """ kwargs.update( { "app_id": app_id, "workflow_auth_strategy": workflow_auth_strategy, } ) if domain_restrictions is not None: kwargs.update({"domain_restrictions": json.dumps(domain_restrictions)}) return await self.api_call("admin.apps.config.set", params=kwargs) async def admin_auth_policy_getEntities( self, *, policy_name: str, cursor: Optional[str] = None, entity_type: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Fetch all the entities assigned to a particular authentication policy by name. https://api.slack.com/methods/admin.auth.policy.getEntities """ kwargs.update({"policy_name": policy_name}) if cursor is not None: kwargs.update({"cursor": cursor}) if entity_type is not None: kwargs.update({"entity_type": entity_type}) if limit is not None: kwargs.update({"limit": limit}) return await self.api_call("admin.auth.policy.getEntities", http_verb="POST", params=kwargs) async def admin_auth_policy_assignEntities( self, *, entity_ids: Union[str, Sequence[str]], policy_name: str, entity_type: str, **kwargs, ) -> AsyncSlackResponse: """Assign entities to a particular authentication policy. https://api.slack.com/methods/admin.auth.policy.assignEntities """ if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) kwargs.update({"policy_name": policy_name}) kwargs.update({"entity_type": entity_type}) return await self.api_call("admin.auth.policy.assignEntities", http_verb="POST", params=kwargs) async def admin_auth_policy_removeEntities( self, *, entity_ids: Union[str, Sequence[str]], policy_name: str, entity_type: str, **kwargs, ) -> AsyncSlackResponse: """Remove specified entities from a specified authentication policy. https://api.slack.com/methods/admin.auth.policy.removeEntities """ if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) kwargs.update({"policy_name": policy_name}) kwargs.update({"entity_type": entity_type}) return await self.api_call("admin.auth.policy.removeEntities", http_verb="POST", params=kwargs) async def admin_barriers_create( self, *, barriered_from_usergroup_ids: Union[str, Sequence[str]], primary_usergroup_id: str, restricted_subjects: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Create an Information Barrier https://api.slack.com/methods/admin.barriers.create """ kwargs.update({"primary_usergroup_id": primary_usergroup_id}) if isinstance(barriered_from_usergroup_ids, (list, Tuple)): kwargs.update({"barriered_from_usergroup_ids": ",".join(barriered_from_usergroup_ids)}) else: kwargs.update({"barriered_from_usergroup_ids": barriered_from_usergroup_ids}) if isinstance(restricted_subjects, (list, Tuple)): kwargs.update({"restricted_subjects": ",".join(restricted_subjects)}) else: kwargs.update({"restricted_subjects": restricted_subjects}) return await self.api_call("admin.barriers.create", http_verb="POST", params=kwargs) async def admin_barriers_delete( self, *, barrier_id: str, **kwargs, ) -> AsyncSlackResponse: """Delete an existing Information Barrier https://api.slack.com/methods/admin.barriers.delete """ kwargs.update({"barrier_id": barrier_id}) return await self.api_call("admin.barriers.delete", http_verb="POST", params=kwargs) async def admin_barriers_update( self, *, barrier_id: str, barriered_from_usergroup_ids: Union[str, Sequence[str]], primary_usergroup_id: str, restricted_subjects: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Update an existing Information Barrier https://api.slack.com/methods/admin.barriers.update """ kwargs.update({"barrier_id": barrier_id, "primary_usergroup_id": primary_usergroup_id}) if isinstance(barriered_from_usergroup_ids, (list, Tuple)): kwargs.update({"barriered_from_usergroup_ids": ",".join(barriered_from_usergroup_ids)}) else: kwargs.update({"barriered_from_usergroup_ids": barriered_from_usergroup_ids}) if isinstance(restricted_subjects, (list, Tuple)): kwargs.update({"restricted_subjects": ",".join(restricted_subjects)}) else: kwargs.update({"restricted_subjects": restricted_subjects}) return await self.api_call("admin.barriers.update", http_verb="POST", params=kwargs) async def admin_barriers_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Get all Information Barriers for your organization https://api.slack.com/methods/admin.barriers.list""" kwargs.update( { "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.barriers.list", http_verb="GET", params=kwargs) async def admin_conversations_create( self, *, is_private: bool, name: str, description: Optional[str] = None, org_wide: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Create a public or private channel-based conversation. https://api.slack.com/methods/admin.conversations.create """ kwargs.update( { "is_private": is_private, "name": name, "description": description, "org_wide": org_wide, "team_id": team_id, } ) return await self.api_call("admin.conversations.create", params=kwargs) async def admin_conversations_delete( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Delete a public or private channel. https://api.slack.com/methods/admin.conversations.delete """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.delete", params=kwargs) async def admin_conversations_invite( self, *, channel_id: str, user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Invite a user to a public or private channel. https://api.slack.com/methods/admin.conversations.invite """ kwargs.update({"channel_id": channel_id}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) # NOTE: the endpoint is unable to handle Content-Type: application/json as of Sep 3, 2020. return await self.api_call("admin.conversations.invite", params=kwargs) async def admin_conversations_archive( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Archive a public or private channel. https://api.slack.com/methods/admin.conversations.archive """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.archive", params=kwargs) async def admin_conversations_unarchive( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Unarchive a public or private channel. https://api.slack.com/methods/admin.conversations.archive """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.unarchive", params=kwargs) async def admin_conversations_rename( self, *, channel_id: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Rename a public or private channel. https://api.slack.com/methods/admin.conversations.rename """ kwargs.update({"channel_id": channel_id, "name": name}) return await self.api_call("admin.conversations.rename", params=kwargs) async def admin_conversations_search( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, query: Optional[str] = None, search_channel_types: Optional[Union[str, Sequence[str]]] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Search for public or private channels in an Enterprise organization. https://api.slack.com/methods/admin.conversations.search """ kwargs.update( { "cursor": cursor, "limit": limit, "query": query, "sort": sort, "sort_dir": sort_dir, } ) if isinstance(search_channel_types, (list, Tuple)): kwargs.update({"search_channel_types": ",".join(search_channel_types)}) else: kwargs.update({"search_channel_types": search_channel_types}) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.conversations.search", params=kwargs) async def admin_conversations_convertToPrivate( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Convert a public channel to a private channel. https://api.slack.com/methods/admin.conversations.convertToPrivate """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.convertToPrivate", params=kwargs) async def admin_conversations_convertToPublic( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Convert a privte channel to a public channel. https://api.slack.com/methods/admin.conversations.convertToPublic """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.convertToPublic", params=kwargs) async def admin_conversations_setConversationPrefs( self, *, channel_id: str, prefs: Union[str, Dict[str, str]], **kwargs, ) -> AsyncSlackResponse: """Set the posting permissions for a public or private channel. https://api.slack.com/methods/admin.conversations.setConversationPrefs """ kwargs.update({"channel_id": channel_id}) if isinstance(prefs, dict): kwargs.update({"prefs": json.dumps(prefs)}) else: kwargs.update({"prefs": prefs}) return await self.api_call("admin.conversations.setConversationPrefs", params=kwargs) async def admin_conversations_getConversationPrefs( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Get conversation preferences for a public or private channel. https://api.slack.com/methods/admin.conversations.getConversationPrefs """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.getConversationPrefs", params=kwargs) async def admin_conversations_disconnectShared( self, *, channel_id: str, leaving_team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Disconnect a connected channel from one or more workspaces. https://api.slack.com/methods/admin.conversations.disconnectShared """ kwargs.update({"channel_id": channel_id}) if isinstance(leaving_team_ids, (list, Tuple)): kwargs.update({"leaving_team_ids": ",".join(leaving_team_ids)}) else: kwargs.update({"leaving_team_ids": leaving_team_ids}) return await self.api_call("admin.conversations.disconnectShared", params=kwargs) async def admin_conversations_lookup( self, *, last_message_activity_before: int, team_ids: Union[str, Sequence[str]], cursor: Optional[str] = None, limit: Optional[int] = None, max_member_count: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Returns channels on the given team using the filters. https://api.slack.com/methods/admin.conversations.lookup """ kwargs.update( { "last_message_activity_before": last_message_activity_before, "cursor": cursor, "limit": limit, "max_member_count": max_member_count, } ) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.conversations.lookup", params=kwargs) async def admin_conversations_ekm_listOriginalConnectedChannelInfo( self, *, channel_ids: Optional[Union[str, Sequence[str]]] = None, cursor: Optional[str] = None, limit: Optional[int] = None, team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """List all disconnected channels—i.e., channels that were once connected to other workspaces and then disconnected—and the corresponding original channel IDs for key revocation with EKM. https://api.slack.com/methods/admin.conversations.ekm.listOriginalConnectedChannelInfo """ kwargs.update( { "cursor": cursor, "limit": limit, } ) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.conversations.ekm.listOriginalConnectedChannelInfo", params=kwargs) async def admin_conversations_restrictAccess_addGroup( self, *, channel_id: str, group_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Add an allowlist of IDP groups for accessing a channel. https://api.slack.com/methods/admin.conversations.restrictAccess.addGroup """ kwargs.update( { "channel_id": channel_id, "group_id": group_id, "team_id": team_id, } ) return await self.api_call( "admin.conversations.restrictAccess.addGroup", http_verb="GET", params=kwargs, ) async def admin_conversations_restrictAccess_listGroups( self, *, channel_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all IDP Groups linked to a channel. https://api.slack.com/methods/admin.conversations.restrictAccess.listGroups """ kwargs.update( { "channel_id": channel_id, "team_id": team_id, } ) return await self.api_call( "admin.conversations.restrictAccess.listGroups", http_verb="GET", params=kwargs, ) async def admin_conversations_restrictAccess_removeGroup( self, *, channel_id: str, group_id: str, team_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove a linked IDP group linked from a private channel. https://api.slack.com/methods/admin.conversations.restrictAccess.removeGroup """ kwargs.update( { "channel_id": channel_id, "group_id": group_id, "team_id": team_id, } ) return await self.api_call( "admin.conversations.restrictAccess.removeGroup", http_verb="GET", params=kwargs, ) async def admin_conversations_setTeams( self, *, channel_id: str, org_channel: Optional[bool] = None, target_team_ids: Optional[Union[str, Sequence[str]]] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Set the workspaces in an Enterprise grid org that connect to a public or private channel. https://api.slack.com/methods/admin.conversations.setTeams """ kwargs.update( { "channel_id": channel_id, "org_channel": org_channel, "team_id": team_id, } ) if isinstance(target_team_ids, (list, Tuple)): kwargs.update({"target_team_ids": ",".join(target_team_ids)}) else: kwargs.update({"target_team_ids": target_team_ids}) return await self.api_call("admin.conversations.setTeams", params=kwargs) async def admin_conversations_getTeams( self, *, channel_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Set the workspaces in an Enterprise grid org that connect to a channel. https://api.slack.com/methods/admin.conversations.getTeams """ kwargs.update( { "channel_id": channel_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.conversations.getTeams", params=kwargs) async def admin_conversations_getCustomRetention( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Get a channel's retention policy https://api.slack.com/methods/admin.conversations.getCustomRetention """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.getCustomRetention", params=kwargs) async def admin_conversations_removeCustomRetention( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove a channel's retention policy https://api.slack.com/methods/admin.conversations.removeCustomRetention """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.removeCustomRetention", params=kwargs) async def admin_conversations_setCustomRetention( self, *, channel_id: str, duration_days: int, **kwargs, ) -> AsyncSlackResponse: """Set a channel's retention policy https://api.slack.com/methods/admin.conversations.setCustomRetention """ kwargs.update({"channel_id": channel_id, "duration_days": duration_days}) return await self.api_call("admin.conversations.setCustomRetention", params=kwargs) async def admin_conversations_bulkArchive( self, *, channel_ids: Union[Sequence[str], str], **kwargs, ) -> AsyncSlackResponse: """Archive public or private channels in bulk. https://api.slack.com/methods/admin.conversations.bulkArchive """ kwargs.update({"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids}) return await self.api_call("admin.conversations.bulkArchive", params=kwargs) async def admin_conversations_bulkDelete( self, *, channel_ids: Union[Sequence[str], str], **kwargs, ) -> AsyncSlackResponse: """Delete public or private channels in bulk. https://slack.com/api/admin.conversations.bulkDelete """ kwargs.update({"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids}) return await self.api_call("admin.conversations.bulkDelete", params=kwargs) async def admin_conversations_bulkMove( self, *, channel_ids: Union[Sequence[str], str], target_team_id: str, **kwargs, ) -> AsyncSlackResponse: """Move public or private channels in bulk. https://api.slack.com/methods/admin.conversations.bulkMove """ kwargs.update( { "target_team_id": target_team_id, "channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids, } ) return await self.api_call("admin.conversations.bulkMove", params=kwargs) async def admin_emoji_add( self, *, name: str, url: str, **kwargs, ) -> AsyncSlackResponse: """Add an emoji. https://api.slack.com/methods/admin.emoji.add """ kwargs.update({"name": name, "url": url}) return await self.api_call("admin.emoji.add", http_verb="GET", params=kwargs) async def admin_emoji_addAlias( self, *, alias_for: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Add an emoji alias. https://api.slack.com/methods/admin.emoji.addAlias """ kwargs.update({"alias_for": alias_for, "name": name}) return await self.api_call("admin.emoji.addAlias", http_verb="GET", params=kwargs) async def admin_emoji_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List emoji for an Enterprise Grid organization. https://api.slack.com/methods/admin.emoji.list """ kwargs.update({"cursor": cursor, "limit": limit}) return await self.api_call("admin.emoji.list", http_verb="GET", params=kwargs) async def admin_emoji_remove( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Remove an emoji across an Enterprise Grid organization. https://api.slack.com/methods/admin.emoji.remove """ kwargs.update({"name": name}) return await self.api_call("admin.emoji.remove", http_verb="GET", params=kwargs) async def admin_emoji_rename( self, *, name: str, new_name: str, **kwargs, ) -> AsyncSlackResponse: """Rename an emoji. https://api.slack.com/methods/admin.emoji.rename """ kwargs.update({"name": name, "new_name": new_name}) return await self.api_call("admin.emoji.rename", http_verb="GET", params=kwargs) async def admin_functions_list( self, *, app_ids: Union[str, Sequence[str]], team_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Look up functions by a set of apps https://api.slack.com/methods/admin.functions.list """ if isinstance(app_ids, (list, Tuple)): kwargs.update({"app_ids": ",".join(app_ids)}) else: kwargs.update({"app_ids": app_ids}) kwargs.update( { "team_id": team_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.functions.list", params=kwargs) async def admin_functions_permissions_lookup( self, *, function_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Lookup the visibility of multiple Slack functions and include the users if it is limited to particular named entities. https://api.slack.com/methods/admin.functions.permissions.lookup """ if isinstance(function_ids, (list, Tuple)): kwargs.update({"function_ids": ",".join(function_ids)}) else: kwargs.update({"function_ids": function_ids}) return await self.api_call("admin.functions.permissions.lookup", params=kwargs) async def admin_functions_permissions_set( self, *, function_id: str, visibility: str, user_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Set the visibility of a Slack function and define the users or workspaces if it is set to named_entities https://api.slack.com/methods/admin.functions.permissions.set """ kwargs.update( { "function_id": function_id, "visibility": visibility, } ) if user_ids is not None: if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.functions.permissions.set", params=kwargs) async def admin_roles_addAssignments( self, *, role_id: str, entity_ids: Union[str, Sequence[str]], user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Adds members to the specified role with the specified scopes https://api.slack.com/methods/admin.roles.addAssignments """ kwargs.update({"role_id": role_id}) if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.roles.addAssignments", params=kwargs) async def admin_roles_listAssignments( self, *, role_ids: Optional[Union[str, Sequence[str]]] = None, entity_ids: Optional[Union[str, Sequence[str]]] = None, cursor: Optional[str] = None, limit: Optional[Union[str, int]] = None, sort_dir: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists assignments for all roles across entities. Options to scope results by any combination of roles or entities https://api.slack.com/methods/admin.roles.listAssignments """ kwargs.update({"cursor": cursor, "limit": limit, "sort_dir": sort_dir}) if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) if isinstance(role_ids, (list, Tuple)): kwargs.update({"role_ids": ",".join(role_ids)}) else: kwargs.update({"role_ids": role_ids}) return await self.api_call("admin.roles.listAssignments", params=kwargs) async def admin_roles_removeAssignments( self, *, role_id: str, entity_ids: Union[str, Sequence[str]], user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Removes a set of users from a role for the given scopes and entities https://api.slack.com/methods/admin.roles.removeAssignments """ kwargs.update({"role_id": role_id}) if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.roles.removeAssignments", params=kwargs) async def admin_users_session_reset( self, *, user_id: str, mobile_only: Optional[bool] = None, web_only: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Wipes all valid sessions on all devices for a given user. https://api.slack.com/methods/admin.users.session.reset """ kwargs.update( { "user_id": user_id, "mobile_only": mobile_only, "web_only": web_only, } ) return await self.api_call("admin.users.session.reset", params=kwargs) async def admin_users_session_resetBulk( self, *, user_ids: Union[str, Sequence[str]], mobile_only: Optional[bool] = None, web_only: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Enqueues an asynchronous job to wipe all valid sessions on all devices for a given list of users https://api.slack.com/methods/admin.users.session.resetBulk """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) kwargs.update( { "mobile_only": mobile_only, "web_only": web_only, } ) return await self.api_call("admin.users.session.resetBulk", params=kwargs) async def admin_users_session_invalidate( self, *, session_id: str, team_id: str, **kwargs, ) -> AsyncSlackResponse: """Invalidate a single session for a user by session_id. https://api.slack.com/methods/admin.users.session.invalidate """ kwargs.update({"session_id": session_id, "team_id": team_id}) return await self.api_call("admin.users.session.invalidate", params=kwargs) async def admin_users_session_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, user_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all active user sessions for an organization https://api.slack.com/methods/admin.users.session.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, "user_id": user_id, } ) return await self.api_call("admin.users.session.list", params=kwargs) async def admin_teams_settings_setDefaultChannels( self, *, team_id: str, channel_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Set the default channels of a workspace. https://api.slack.com/methods/admin.teams.settings.setDefaultChannels """ kwargs.update({"team_id": team_id}) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.teams.settings.setDefaultChannels", http_verb="GET", params=kwargs) async def admin_users_session_getSettings( self, *, user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Get user-specific session settings—the session duration and what happens when the client closes—given a list of users. https://api.slack.com/methods/admin.users.session.getSettings """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.users.session.getSettings", params=kwargs) async def admin_users_session_setSettings( self, *, user_ids: Union[str, Sequence[str]], desktop_app_browser_quit: Optional[bool] = None, duration: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Configure the user-level session settings—the session duration and what happens when the client closes—for one or more users. https://api.slack.com/methods/admin.users.session.setSettings """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) kwargs.update( { "desktop_app_browser_quit": desktop_app_browser_quit, "duration": duration, } ) return await self.api_call("admin.users.session.setSettings", params=kwargs) async def admin_users_session_clearSettings( self, *, user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Clear user-specific session settings—the session duration and what happens when the client closes—for a list of users. https://api.slack.com/methods/admin.users.session.clearSettings """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.users.session.clearSettings", params=kwargs) async def admin_users_unsupportedVersions_export( self, *, date_end_of_support: Optional[Union[str, int]] = None, date_sessions_started: Optional[Union[str, int]] = None, **kwargs, ) -> AsyncSlackResponse: """Ask Slackbot to send you an export listing all workspace members using unsupported software, presented as a zipped CSV file. https://api.slack.com/methods/admin.users.unsupportedVersions.export """ kwargs.update( { "date_end_of_support": date_end_of_support, "date_sessions_started": date_sessions_started, } ) return await self.api_call("admin.users.unsupportedVersions.export", params=kwargs) async def admin_inviteRequests_approve( self, *, invite_request_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Approve a workspace invite request. https://api.slack.com/methods/admin.inviteRequests.approve """ kwargs.update({"invite_request_id": invite_request_id, "team_id": team_id}) return await self.api_call("admin.inviteRequests.approve", params=kwargs) async def admin_inviteRequests_approved_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all approved workspace invite requests. https://api.slack.com/methods/admin.inviteRequests.approved.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.inviteRequests.approved.list", params=kwargs) async def admin_inviteRequests_denied_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all denied workspace invite requests. https://api.slack.com/methods/admin.inviteRequests.denied.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.inviteRequests.denied.list", params=kwargs) async def admin_inviteRequests_deny( self, *, invite_request_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Deny a workspace invite request. https://api.slack.com/methods/admin.inviteRequests.deny """ kwargs.update({"invite_request_id": invite_request_id, "team_id": team_id}) return await self.api_call("admin.inviteRequests.deny", params=kwargs) async def admin_inviteRequests_list( self, **kwargs, ) -> AsyncSlackResponse: """List all pending workspace invite requests.""" return await self.api_call("admin.inviteRequests.list", params=kwargs) async def admin_teams_admins_list( self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List all of the admins on a given workspace. https://api.slack.com/methods/admin.inviteRequests.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.teams.admins.list", http_verb="GET", params=kwargs) async def admin_teams_create( self, *, team_domain: str, team_name: str, team_description: Optional[str] = None, team_discoverability: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Create an Enterprise team. https://api.slack.com/methods/admin.teams.create """ kwargs.update( { "team_domain": team_domain, "team_name": team_name, "team_description": team_description, "team_discoverability": team_discoverability, } ) return await self.api_call("admin.teams.create", params=kwargs) async def admin_teams_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List all teams on an Enterprise organization. https://api.slack.com/methods/admin.teams.list """ kwargs.update({"cursor": cursor, "limit": limit}) return await self.api_call("admin.teams.list", params=kwargs) async def admin_teams_owners_list( self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List all of the admins on a given workspace. https://api.slack.com/methods/admin.teams.owners.list """ kwargs.update({"team_id": team_id, "cursor": cursor, "limit": limit}) return await self.api_call("admin.teams.owners.list", http_verb="GET", params=kwargs) async def admin_teams_settings_info( self, *, team_id: str, **kwargs, ) -> AsyncSlackResponse: """Fetch information about settings in a workspace https://api.slack.com/methods/admin.teams.settings.info """ kwargs.update({"team_id": team_id}) return await self.api_call("admin.teams.settings.info", params=kwargs) async def admin_teams_settings_setDescription( self, *, team_id: str, description: str, **kwargs, ) -> AsyncSlackResponse: """Set the description of a given workspace. https://api.slack.com/methods/admin.teams.settings.setDescription """ kwargs.update({"team_id": team_id, "description": description}) return await self.api_call("admin.teams.settings.setDescription", params=kwargs) async def admin_teams_settings_setDiscoverability( self, *, team_id: str, discoverability: str, **kwargs, ) -> AsyncSlackResponse: """Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setDiscoverability """ kwargs.update({"team_id": team_id, "discoverability": discoverability}) return await self.api_call("admin.teams.settings.setDiscoverability", params=kwargs) async def admin_teams_settings_setIcon( self, *, team_id: str, image_url: str, **kwargs, ) -> AsyncSlackResponse: """Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setIcon """ kwargs.update({"team_id": team_id, "image_url": image_url}) return await self.api_call("admin.teams.settings.setIcon", http_verb="GET", params=kwargs) async def admin_teams_settings_setName( self, *, team_id: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setName """ kwargs.update({"team_id": team_id, "name": name}) return await self.api_call("admin.teams.settings.setName", params=kwargs) async def admin_usergroups_addChannels( self, *, channel_ids: Union[str, Sequence[str]], usergroup_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.addChannels """ kwargs.update({"team_id": team_id, "usergroup_id": usergroup_id}) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.usergroups.addChannels", params=kwargs) async def admin_usergroups_addTeams( self, *, usergroup_id: str, team_ids: Union[str, Sequence[str]], auto_provision: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Associate one or more default workspaces with an organization-wide IDP group. https://api.slack.com/methods/admin.usergroups.addTeams """ kwargs.update({"usergroup_id": usergroup_id, "auto_provision": auto_provision}) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.usergroups.addTeams", params=kwargs) async def admin_usergroups_listChannels( self, *, usergroup_id: str, include_num_members: Optional[bool] = None, team_id: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.listChannels """ kwargs.update( { "usergroup_id": usergroup_id, "include_num_members": include_num_members, "team_id": team_id, } ) return await self.api_call("admin.usergroups.listChannels", params=kwargs) async def admin_usergroups_removeChannels( self, *, usergroup_id: str, channel_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.removeChannels """ kwargs.update({"usergroup_id": usergroup_id}) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.usergroups.removeChannels", params=kwargs) async def admin_users_assign( self, *, team_id: str, user_id: str, channel_ids: Optional[Union[str, Sequence[str]]] = None, is_restricted: Optional[bool] = None, is_ultra_restricted: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Add an Enterprise user to a workspace. https://api.slack.com/methods/admin.users.assign """ kwargs.update( { "team_id": team_id, "user_id": user_id, "is_restricted": is_restricted, "is_ultra_restricted": is_ultra_restricted, } ) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.users.assign", params=kwargs) async def admin_users_invite( self, *, team_id: str, email: str, channel_ids: Union[str, Sequence[str]], custom_message: Optional[str] = None, email_password_policy_enabled: Optional[bool] = None, guest_expiration_ts: Optional[Union[str, float]] = None, is_restricted: Optional[bool] = None, is_ultra_restricted: Optional[bool] = None, real_name: Optional[str] = None, resend: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Invite a user to a workspace. https://api.slack.com/methods/admin.users.invite """ kwargs.update( { "team_id": team_id, "email": email, "custom_message": custom_message, "email_password_policy_enabled": email_password_policy_enabled, "guest_expiration_ts": str(guest_expiration_ts) if guest_expiration_ts is not None else None, "is_restricted": is_restricted, "is_ultra_restricted": is_ultra_restricted, "real_name": real_name, "resend": resend, } ) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.users.invite", params=kwargs) async def admin_users_list( self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List users on a workspace https://api.slack.com/methods/admin.users.list """ kwargs.update( { "team_id": team_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.users.list", params=kwargs) async def admin_users_remove( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove a user from a workspace. https://api.slack.com/methods/admin.users.remove """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.remove", params=kwargs) async def admin_users_setAdmin( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Set an existing guest, regular user, or owner to be an admin user. https://api.slack.com/methods/admin.users.setAdmin """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setAdmin", params=kwargs) async def admin_users_setExpiration( self, *, expiration_ts: int, user_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Set an expiration for a guest user. https://api.slack.com/methods/admin.users.setExpiration """ kwargs.update({"expiration_ts": expiration_ts, "team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setExpiration", params=kwargs) async def admin_users_setOwner( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Set an existing guest, regular user, or admin user to be a workspace owner. https://api.slack.com/methods/admin.users.setOwner """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setOwner", params=kwargs) async def admin_users_setRegular( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Set an existing guest user, admin user, or owner to be a regular user. https://api.slack.com/methods/admin.users.setRegular """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setRegular", params=kwargs) async def admin_workflows_search( self, *, app_id: Optional[str] = None, collaborator_ids: Optional[Union[str, Sequence[str]]] = None, cursor: Optional[str] = None, limit: Optional[int] = None, no_collaborators: Optional[bool] = None, num_trigger_ids: Optional[int] = None, query: Optional[str] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, source: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Search workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.search """ if collaborator_ids is not None: if isinstance(collaborator_ids, (list, Tuple)): kwargs.update({"collaborator_ids": ",".join(collaborator_ids)}) else: kwargs.update({"collaborator_ids": collaborator_ids}) kwargs.update( { "app_id": app_id, "cursor": cursor, "limit": limit, "no_collaborators": no_collaborators, "num_trigger_ids": num_trigger_ids, "query": query, "sort": sort, "sort_dir": sort_dir, "source": source, } ) return await self.api_call("admin.workflows.search", params=kwargs) async def admin_workflows_permissions_lookup( self, *, workflow_ids: Union[str, Sequence[str]], max_workflow_triggers: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Look up the permissions for a set of workflows https://api.slack.com/methods/admin.workflows.permissions.lookup """ if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) kwargs.update( { "max_workflow_triggers": max_workflow_triggers, } ) return await self.api_call("admin.workflows.permissions.lookup", params=kwargs) async def admin_workflows_collaborators_add( self, *, collaborator_ids: Union[str, Sequence[str]], workflow_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Add collaborators to workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.collaborators.add """ if isinstance(collaborator_ids, (list, Tuple)): kwargs.update({"collaborator_ids": ",".join(collaborator_ids)}) else: kwargs.update({"collaborator_ids": collaborator_ids}) if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) return await self.api_call("admin.workflows.collaborators.add", params=kwargs) async def admin_workflows_collaborators_remove( self, *, collaborator_ids: Union[str, Sequence[str]], workflow_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Remove collaborators from workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.collaborators.remove """ if isinstance(collaborator_ids, (list, Tuple)): kwargs.update({"collaborator_ids": ",".join(collaborator_ids)}) else: kwargs.update({"collaborator_ids": collaborator_ids}) if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) return await self.api_call("admin.workflows.collaborators.remove", params=kwargs) async def admin_workflows_unpublish( self, *, workflow_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Unpublish workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.unpublish """ if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) return await self.api_call("admin.workflows.unpublish", params=kwargs) async def api_test( self, *, error: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Checks API calling code. https://api.slack.com/methods/api.test """ kwargs.update({"error": error}) return await self.api_call("api.test", params=kwargs) async def apps_connections_open( self, *, app_token: str, **kwargs, ) -> AsyncSlackResponse: """Generate a temporary Socket Mode WebSocket URL that your app can connect to in order to receive events and interactive payloads https://api.slack.com/methods/apps.connections.open """ kwargs.update({"token": app_token}) return await self.api_call("apps.connections.open", http_verb="POST", params=kwargs) async def apps_event_authorizations_list( self, *, event_context: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Get a list of authorizations for the given event context. Each authorization represents an app installation that the event is visible to. https://api.slack.com/methods/apps.event.authorizations.list """ kwargs.update({"event_context": event_context, "cursor": cursor, "limit": limit}) return await self.api_call("apps.event.authorizations.list", params=kwargs) async def apps_uninstall( self, *, client_id: str, client_secret: str, **kwargs, ) -> AsyncSlackResponse: """Uninstalls your app from a workspace. https://api.slack.com/methods/apps.uninstall """ kwargs.update({"client_id": client_id, "client_secret": client_secret}) return await self.api_call("apps.uninstall", params=kwargs) async def auth_revoke( self, *, test: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Revokes a token. https://api.slack.com/methods/auth.revoke """ kwargs.update({"test": test}) return await self.api_call("auth.revoke", http_verb="GET", params=kwargs) async def auth_test( self, **kwargs, ) -> AsyncSlackResponse: """Checks authentication & identity. https://api.slack.com/methods/auth.test """ return await self.api_call("auth.test", params=kwargs) async def auth_teams_list( self, cursor: Optional[str] = None, limit: Optional[int] = None, include_icon: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """List the workspaces a token can access. https://api.slack.com/methods/auth.teams.list """ kwargs.update({"cursor": cursor, "limit": limit, "include_icon": include_icon}) return await self.api_call("auth.teams.list", params=kwargs) async def bookmarks_add( self, *, channel_id: str, title: str, type: str, emoji: Optional[str] = None, entity_id: Optional[str] = None, link: Optional[str] = None, # include when type is 'link' parent_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Add bookmark to a channel. https://api.slack.com/methods/bookmarks.add """ kwargs.update( { "channel_id": channel_id, "title": title, "type": type, "emoji": emoji, "entity_id": entity_id, "link": link, "parent_id": parent_id, } ) return await self.api_call("bookmarks.add", http_verb="POST", params=kwargs) async def bookmarks_edit( self, *, bookmark_id: str, channel_id: str, emoji: Optional[str] = None, link: Optional[str] = None, title: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Edit bookmark. https://api.slack.com/methods/bookmarks.edit """ kwargs.update( { "bookmark_id": bookmark_id, "channel_id": channel_id, "emoji": emoji, "link": link, "title": title, } ) return await self.api_call("bookmarks.edit", http_verb="POST", params=kwargs) async def bookmarks_list( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """List bookmark for the channel. https://api.slack.com/methods/bookmarks.list """ kwargs.update({"channel_id": channel_id}) return await self.api_call("bookmarks.list", http_verb="POST", params=kwargs) async def bookmarks_remove( self, *, bookmark_id: str, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove bookmark from the channel. https://api.slack.com/methods/bookmarks.remove """ kwargs.update({"bookmark_id": bookmark_id, "channel_id": channel_id}) return await self.api_call("bookmarks.remove", http_verb="POST", params=kwargs) async def bots_info( self, *, bot: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a bot user. https://api.slack.com/methods/bots.info """ kwargs.update({"bot": bot, "team_id": team_id}) return await self.api_call("bots.info", http_verb="GET", params=kwargs) async def calls_add( self, *, external_unique_id: str, join_url: str, created_by: Optional[str] = None, date_start: Optional[int] = None, desktop_app_join_url: Optional[str] = None, external_display_id: Optional[str] = None, title: Optional[str] = None, users: Optional[Union[str, Sequence[Dict[str, str]]]] = None, **kwargs, ) -> AsyncSlackResponse: """Registers a new Call. https://api.slack.com/methods/calls.add """ kwargs.update( { "external_unique_id": external_unique_id, "join_url": join_url, "created_by": created_by, "date_start": date_start, "desktop_app_join_url": desktop_app_join_url, "external_display_id": external_display_id, "title": title, } ) _update_call_participants( # skipcq: PTC-W0039 kwargs, users if users is not None else kwargs.get("users"), # skipcq: PTC-W0039 ) # skipcq: PTC-W0039 return await self.api_call("calls.add", http_verb="POST", params=kwargs) async def calls_end( self, *, id: str, duration: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: # skipcq: PYL-W0622 """Ends a Call. https://api.slack.com/methods/calls.end """ kwargs.update({"id": id, "duration": duration}) return await self.api_call("calls.end", http_verb="POST", params=kwargs) async def calls_info( self, *, id: str, **kwargs, ) -> AsyncSlackResponse: # skipcq: PYL-W0622 """Returns information about a Call. https://api.slack.com/methods/calls.info """ kwargs.update({"id": id}) return await self.api_call("calls.info", http_verb="POST", params=kwargs) async def calls_participants_add( self, *, id: str, # skipcq: PYL-W0622 users: Union[str, Sequence[Dict[str, str]]], **kwargs, ) -> AsyncSlackResponse: """Registers new participants added to a Call. https://api.slack.com/methods/calls.participants.add """ kwargs.update({"id": id}) _update_call_participants(kwargs, users) return await self.api_call("calls.participants.add", http_verb="POST", params=kwargs) async def calls_participants_remove( self, *, id: str, # skipcq: PYL-W0622 users: Union[str, Sequence[Dict[str, str]]], **kwargs, ) -> AsyncSlackResponse: """Registers participants removed from a Call. https://api.slack.com/methods/calls.participants.remove """ kwargs.update({"id": id}) _update_call_participants(kwargs, users) return await self.api_call("calls.participants.remove", http_verb="POST", params=kwargs) async def calls_update( self, *, id: str, desktop_app_join_url: Optional[str] = None, join_url: Optional[str] = None, title: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: # skipcq: PYL-W0622 """Updates information about a Call. https://api.slack.com/methods/calls.update """ kwargs.update( { "id": id, "desktop_app_join_url": desktop_app_join_url, "join_url": join_url, "title": title, } ) return await self.api_call("calls.update", http_verb="POST", params=kwargs) # -------------------------- # Deprecated: channels.* # You can use conversations.* APIs instead. # https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api # -------------------------- async def channels_archive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Archives a channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.archive", json=kwargs) async def channels_create( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Creates a channel.""" kwargs.update({"name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.create", json=kwargs) async def channels_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from a channel.""" kwargs.update({"channel": channel}) return await self.api_call("channels.history", http_verb="GET", params=kwargs) async def channels_info( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Gets information about a channel.""" kwargs.update({"channel": channel}) return await self.api_call("channels.info", http_verb="GET", params=kwargs) async def channels_invite( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Invites a user to a channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.invite", json=kwargs) async def channels_join( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Joins a channel, creating it if needed.""" kwargs.update({"name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.join", json=kwargs) async def channels_kick( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Removes a user from a channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.kick", json=kwargs) async def channels_leave( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Leaves a channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.leave", json=kwargs) async def channels_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists all channels in a Slack team.""" return await self.api_call("channels.list", http_verb="GET", params=kwargs) async def channels_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.mark", json=kwargs) async def channels_rename( self, *, channel: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Renames a channel.""" kwargs.update({"channel": channel, "name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.rename", json=kwargs) async def channels_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a channel""" kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("channels.replies", http_verb="GET", params=kwargs) async def channels_setPurpose( self, *, channel: str, purpose: str, **kwargs, ) -> AsyncSlackResponse: """Sets the purpose for a channel.""" kwargs.update({"channel": channel, "purpose": purpose}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.setPurpose", json=kwargs) async def channels_setTopic( self, *, channel: str, topic: str, **kwargs, ) -> AsyncSlackResponse: """Sets the topic for a channel.""" kwargs.update({"channel": channel, "topic": topic}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.setTopic", json=kwargs) async def channels_unarchive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Unarchives a channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.unarchive", json=kwargs) # -------------------------- async def chat_delete( self, *, channel: str, ts: str, as_user: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Deletes a message. https://api.slack.com/methods/chat.delete """ kwargs.update({"channel": channel, "ts": ts, "as_user": as_user}) return await self.api_call("chat.delete", params=kwargs) async def chat_deleteScheduledMessage( self, *, channel: str, scheduled_message_id: str, as_user: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Deletes a scheduled message. https://api.slack.com/methods/chat.deleteScheduledMessage """ kwargs.update( { "channel": channel, "scheduled_message_id": scheduled_message_id, "as_user": as_user, } ) return await self.api_call("chat.deleteScheduledMessage", params=kwargs) async def chat_getPermalink( self, *, channel: str, message_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a permalink URL for a specific extant message https://api.slack.com/methods/chat.getPermalink """ kwargs.update({"channel": channel, "message_ts": message_ts}) return await self.api_call("chat.getPermalink", http_verb="GET", params=kwargs) async def chat_meMessage( self, *, channel: str, text: str, **kwargs, ) -> AsyncSlackResponse: """Share a me message into a channel. https://api.slack.com/methods/chat.meMessage """ kwargs.update({"channel": channel, "text": text}) return await self.api_call("chat.meMessage", params=kwargs) async def chat_postEphemeral( self, *, channel: str, user: str, text: Optional[str] = None, as_user: Optional[bool] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, thread_ts: Optional[str] = None, icon_emoji: Optional[str] = None, icon_url: Optional[str] = None, link_names: Optional[bool] = None, username: Optional[str] = None, parse: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Sends an ephemeral message to a user in a channel. https://api.slack.com/methods/chat.postEphemeral """ kwargs.update( { "channel": channel, "user": user, "text": text, "as_user": as_user, "attachments": attachments, "blocks": blocks, "thread_ts": thread_ts, "icon_emoji": icon_emoji, "icon_url": icon_url, "link_names": link_names, "username": username, "parse": parse, } ) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.postEphemeral", kwargs) # NOTE: intentionally using json over params for the API methods using blocks/attachments return await self.api_call("chat.postEphemeral", json=kwargs) async def chat_postMessage( self, *, channel: str, text: Optional[str] = None, as_user: Optional[bool] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, thread_ts: Optional[str] = None, reply_broadcast: Optional[bool] = None, unfurl_links: Optional[bool] = None, unfurl_media: Optional[bool] = None, container_id: Optional[str] = None, icon_emoji: Optional[str] = None, icon_url: Optional[str] = None, mrkdwn: Optional[bool] = None, link_names: Optional[bool] = None, username: Optional[str] = None, parse: Optional[str] = None, # none, full metadata: Optional[Union[Dict, Metadata]] = None, **kwargs, ) -> AsyncSlackResponse: """Sends a message to a channel. https://api.slack.com/methods/chat.postMessage """ kwargs.update( { "channel": channel, "text": text, "as_user": as_user, "attachments": attachments, "blocks": blocks, "thread_ts": thread_ts, "reply_broadcast": reply_broadcast, "unfurl_links": unfurl_links, "unfurl_media": unfurl_media, "container_id": container_id, "icon_emoji": icon_emoji, "icon_url": icon_url, "mrkdwn": mrkdwn, "link_names": link_names, "username": username, "parse": parse, "metadata": metadata, } ) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.postMessage", kwargs) # NOTE: intentionally using json over params for the API methods using blocks/attachments return await self.api_call("chat.postMessage", json=kwargs) async def chat_scheduleMessage( self, *, channel: str, post_at: Union[str, int], text: str, as_user: Optional[bool] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, thread_ts: Optional[str] = None, parse: Optional[str] = None, reply_broadcast: Optional[bool] = None, unfurl_links: Optional[bool] = None, unfurl_media: Optional[bool] = None, link_names: Optional[bool] = None, metadata: Optional[Union[Dict, Metadata]] = None, **kwargs, ) -> AsyncSlackResponse: """Schedules a message. https://api.slack.com/methods/chat.scheduleMessage """ kwargs.update( { "channel": channel, "post_at": post_at, "text": text, "as_user": as_user, "attachments": attachments, "blocks": blocks, "thread_ts": thread_ts, "reply_broadcast": reply_broadcast, "parse": parse, "unfurl_links": unfurl_links, "unfurl_media": unfurl_media, "link_names": link_names, "metadata": metadata, } ) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.scheduleMessage", kwargs) # NOTE: intentionally using json over params for the API methods using blocks/attachments return await self.api_call("chat.scheduleMessage", json=kwargs) async def chat_unfurl( self, *, channel: Optional[str] = None, ts: Optional[str] = None, source: Optional[str] = None, unfurl_id: Optional[str] = None, unfurls: Optional[Dict[str, Dict]] = None, # or user_auth_* user_auth_blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, user_auth_message: Optional[str] = None, user_auth_required: Optional[bool] = None, user_auth_url: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Provide custom unfurl behavior for user-posted URLs. https://api.slack.com/methods/chat.unfurl """ kwargs.update( { "channel": channel, "ts": ts, "source": source, "unfurl_id": unfurl_id, "unfurls": unfurls, "user_auth_blocks": user_auth_blocks, "user_auth_message": user_auth_message, "user_auth_required": user_auth_required, "user_auth_url": user_auth_url, } ) _parse_web_class_objects(kwargs) # for user_auth_blocks kwargs = _remove_none_values(kwargs) # NOTE: intentionally using json over params for API methods using blocks/attachments return await self.api_call("chat.unfurl", json=kwargs) async def chat_update( self, *, channel: str, ts: str, text: Optional[str] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, as_user: Optional[bool] = None, file_ids: Optional[Union[str, Sequence[str]]] = None, link_names: Optional[bool] = None, parse: Optional[str] = None, # none, full reply_broadcast: Optional[bool] = None, metadata: Optional[Union[Dict, Metadata]] = None, **kwargs, ) -> AsyncSlackResponse: """Updates a message in a channel. https://api.slack.com/methods/chat.update """ kwargs.update( { "channel": channel, "ts": ts, "text": text, "attachments": attachments, "blocks": blocks, "as_user": as_user, "link_names": link_names, "parse": parse, "reply_broadcast": reply_broadcast, "metadata": metadata, } ) if isinstance(file_ids, (list, Tuple)): kwargs.update({"file_ids": ",".join(file_ids)}) else: kwargs.update({"file_ids": file_ids}) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.update", kwargs) # NOTE: intentionally using json over params for API methods using blocks/attachments return await self.api_call("chat.update", json=kwargs) async def chat_scheduledMessages_list( self, *, channel: Optional[str] = None, cursor: Optional[str] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all scheduled messages. https://api.slack.com/methods/chat.scheduledMessages.list """ kwargs.update( { "channel": channel, "cursor": cursor, "latest": latest, "limit": limit, "oldest": oldest, "team_id": team_id, } ) return await self.api_call("chat.scheduledMessages.list", params=kwargs) async def conversations_acceptSharedInvite( self, *, channel_name: str, channel_id: Optional[str] = None, invite_id: Optional[str] = None, free_trial_accepted: Optional[bool] = None, is_private: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Accepts an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.acceptSharedInvite """ if channel_id is None and invite_id is None: raise e.SlackRequestError("Either channel_id or invite_id must be provided.") kwargs.update( { "channel_name": channel_name, "channel_id": channel_id, "invite_id": invite_id, "free_trial_accepted": free_trial_accepted, "is_private": is_private, "team_id": team_id, } ) return await self.api_call("conversations.acceptSharedInvite", http_verb="POST", params=kwargs) async def conversations_approveSharedInvite( self, *, invite_id: str, target_team: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Approves an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.approveSharedInvite """ kwargs.update({"invite_id": invite_id, "target_team": target_team}) return await self.api_call("conversations.approveSharedInvite", http_verb="POST", params=kwargs) async def conversations_archive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Archives a conversation. https://api.slack.com/methods/conversations.archive """ kwargs.update({"channel": channel}) return await self.api_call("conversations.archive", params=kwargs) async def conversations_close( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Closes a direct message or multi-person direct message. https://api.slack.com/methods/conversations.close """ kwargs.update({"channel": channel}) return await self.api_call("conversations.close", params=kwargs) async def conversations_create( self, *, name: str, is_private: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Initiates a public or private channel-based conversation https://api.slack.com/methods/conversations.create """ kwargs.update({"name": name, "is_private": is_private, "team_id": team_id}) return await self.api_call("conversations.create", params=kwargs) async def conversations_declineSharedInvite( self, *, invite_id: str, target_team: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Declines a Slack Connect channel invite. https://api.slack.com/methods/conversations.declineSharedInvite """ kwargs.update({"invite_id": invite_id, "target_team": target_team}) return await self.api_call("conversations.declineSharedInvite", http_verb="GET", params=kwargs) async def conversations_history( self, *, channel: str, cursor: Optional[str] = None, inclusive: Optional[bool] = None, include_all_metadata: Optional[bool] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Fetches a conversation's history of messages and events. https://api.slack.com/methods/conversations.history """ kwargs.update( { "channel": channel, "cursor": cursor, "inclusive": inclusive, "include_all_metadata": include_all_metadata, "limit": limit, "latest": latest, "oldest": oldest, } ) return await self.api_call("conversations.history", http_verb="GET", params=kwargs) async def conversations_info( self, *, channel: str, include_locale: Optional[bool] = None, include_num_members: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve information about a conversation. https://api.slack.com/methods/conversations.info """ kwargs.update( { "channel": channel, "include_locale": include_locale, "include_num_members": include_num_members, } ) return await self.api_call("conversations.info", http_verb="GET", params=kwargs) async def conversations_invite( self, *, channel: str, users: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Invites users to a channel. https://api.slack.com/methods/conversations.invite """ kwargs.update({"channel": channel}) if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("conversations.invite", params=kwargs) async def conversations_inviteShared( self, *, channel: str, emails: Optional[Union[str, Sequence[str]]] = None, user_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Sends an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.inviteShared """ if emails is None and user_ids is None: raise e.SlackRequestError("Either emails or user ids must be provided.") kwargs.update({"channel": channel}) if isinstance(emails, (list, Tuple)): kwargs.update({"emails": ",".join(emails)}) else: kwargs.update({"emails": emails}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("conversations.inviteShared", http_verb="GET", params=kwargs) async def conversations_join( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Joins an existing conversation. https://api.slack.com/methods/conversations.join """ kwargs.update({"channel": channel}) return await self.api_call("conversations.join", params=kwargs) async def conversations_kick( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Removes a user from a conversation. https://api.slack.com/methods/conversations.kick """ kwargs.update({"channel": channel, "user": user}) return await self.api_call("conversations.kick", params=kwargs) async def conversations_leave( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Leaves a conversation. https://api.slack.com/methods/conversations.leave """ kwargs.update({"channel": channel}) return await self.api_call("conversations.leave", params=kwargs) async def conversations_list( self, *, cursor: Optional[str] = None, exclude_archived: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, types: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all channels in a Slack team. https://api.slack.com/methods/conversations.list """ kwargs.update( { "cursor": cursor, "exclude_archived": exclude_archived, "limit": limit, "team_id": team_id, } ) if isinstance(types, (list, Tuple)): kwargs.update({"types": ",".join(types)}) else: kwargs.update({"types": types}) return await self.api_call("conversations.list", http_verb="GET", params=kwargs) async def conversations_listConnectInvites( self, *, count: Optional[int] = None, cursor: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List shared channel invites that have been generated or received but have not yet been approved by all parties. https://api.slack.com/methods/conversations.listConnectInvites """ kwargs.update({"count": count, "cursor": cursor, "team_id": team_id}) return await self.api_call("conversations.listConnectInvites", params=kwargs) async def conversations_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a channel. https://api.slack.com/methods/conversations.mark """ kwargs.update({"channel": channel, "ts": ts}) return await self.api_call("conversations.mark", params=kwargs) async def conversations_members( self, *, channel: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve members of a conversation. https://api.slack.com/methods/conversations.members """ kwargs.update({"channel": channel, "cursor": cursor, "limit": limit}) return await self.api_call("conversations.members", http_verb="GET", params=kwargs) async def conversations_open( self, *, channel: Optional[str] = None, return_im: Optional[bool] = None, users: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Opens or resumes a direct message or multi-person direct message. https://api.slack.com/methods/conversations.open """ if channel is None and users is None: raise e.SlackRequestError("Either channel or users must be provided.") kwargs.update({"channel": channel, "return_im": return_im}) if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("conversations.open", params=kwargs) async def conversations_rename( self, *, channel: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Renames a conversation. https://api.slack.com/methods/conversations.rename """ kwargs.update({"channel": channel, "name": name}) return await self.api_call("conversations.rename", params=kwargs) async def conversations_replies( self, *, channel: str, ts: str, cursor: Optional[str] = None, inclusive: Optional[bool] = None, include_all_metadata: Optional[bool] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a conversation https://api.slack.com/methods/conversations.replies """ kwargs.update( { "channel": channel, "ts": ts, "cursor": cursor, "inclusive": inclusive, "include_all_metadata": include_all_metadata, "limit": limit, "latest": latest, "oldest": oldest, } ) return await self.api_call("conversations.replies", http_verb="GET", params=kwargs) async def conversations_setPurpose( self, *, channel: str, purpose: str, **kwargs, ) -> AsyncSlackResponse: """Sets the purpose for a conversation. https://api.slack.com/methods/conversations.setPurpose """ kwargs.update({"channel": channel, "purpose": purpose}) return await self.api_call("conversations.setPurpose", params=kwargs) async def conversations_setTopic( self, *, channel: str, topic: str, **kwargs, ) -> AsyncSlackResponse: """Sets the topic for a conversation. https://api.slack.com/methods/conversations.setTopic """ kwargs.update({"channel": channel, "topic": topic}) return await self.api_call("conversations.setTopic", params=kwargs) async def conversations_unarchive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Reverses conversation archival. https://api.slack.com/methods/conversations.unarchive """ kwargs.update({"channel": channel}) return await self.api_call("conversations.unarchive", params=kwargs) async def dialog_open( self, *, dialog: Dict[str, Any], trigger_id: str, **kwargs, ) -> AsyncSlackResponse: """Open a dialog with a user. https://api.slack.com/methods/dialog.open """ kwargs.update({"dialog": dialog, "trigger_id": trigger_id}) kwargs = _remove_none_values(kwargs) # NOTE: As the dialog can be a dict, this API call works only with json format. return await self.api_call("dialog.open", json=kwargs) async def dnd_endDnd( self, **kwargs, ) -> AsyncSlackResponse: """Ends the current user's Do Not Disturb session immediately. https://api.slack.com/methods/dnd.endDnd """ return await self.api_call("dnd.endDnd", params=kwargs) async def dnd_endSnooze( self, **kwargs, ) -> AsyncSlackResponse: """Ends the current user's snooze mode immediately. https://api.slack.com/methods/dnd.endSnooze """ return await self.api_call("dnd.endSnooze", params=kwargs) async def dnd_info( self, *, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieves a user's current Do Not Disturb status. https://api.slack.com/methods/dnd.info """ kwargs.update({"team_id": team_id, "user": user}) return await self.api_call("dnd.info", http_verb="GET", params=kwargs) async def dnd_setSnooze( self, *, num_minutes: Union[int, str], **kwargs, ) -> AsyncSlackResponse: """Turns on Do Not Disturb mode for the current user, or changes its duration. https://api.slack.com/methods/dnd.setSnooze """ kwargs.update({"num_minutes": num_minutes}) return await self.api_call("dnd.setSnooze", http_verb="GET", params=kwargs) async def dnd_teamInfo( self, users: Union[str, Sequence[str]], team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieves the Do Not Disturb status for users on a team. https://api.slack.com/methods/dnd.teamInfo """ if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) kwargs.update({"team_id": team_id}) return await self.api_call("dnd.teamInfo", http_verb="GET", params=kwargs) async def emoji_list( self, include_categories: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Lists custom emoji for a team. https://api.slack.com/methods/emoji.list """ kwargs.update({"include_categories": include_categories}) return await self.api_call("emoji.list", http_verb="GET", params=kwargs) async def files_comments_delete( self, *, file: str, id: str, **kwargs, # skipcq: PYL-W0622 ) -> AsyncSlackResponse: """Deletes an existing comment on a file. https://api.slack.com/methods/files.comments.delete """ kwargs.update({"file": file, "id": id}) return await self.api_call("files.comments.delete", params=kwargs) async def files_delete( self, *, file: str, **kwargs, ) -> AsyncSlackResponse: """Deletes a file. https://api.slack.com/methods/files.delete """ kwargs.update({"file": file}) return await self.api_call("files.delete", params=kwargs) async def files_info( self, *, file: str, count: Optional[int] = None, cursor: Optional[str] = None, limit: Optional[int] = None, page: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a team file. https://api.slack.com/methods/files.info """ kwargs.update( { "file": file, "count": count, "cursor": cursor, "limit": limit, "page": page, } ) return await self.api_call("files.info", http_verb="GET", params=kwargs) async def files_list( self, *, channel: Optional[str] = None, count: Optional[int] = None, page: Optional[int] = None, show_files_hidden_by_limit: Optional[bool] = None, team_id: Optional[str] = None, ts_from: Optional[str] = None, ts_to: Optional[str] = None, types: Optional[Union[str, Sequence[str]]] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists & filters team files. https://api.slack.com/methods/files.list """ kwargs.update( { "channel": channel, "count": count, "page": page, "show_files_hidden_by_limit": show_files_hidden_by_limit, "team_id": team_id, "ts_from": ts_from, "ts_to": ts_to, "user": user, } ) if isinstance(types, (list, Tuple)): kwargs.update({"types": ",".join(types)}) else: kwargs.update({"types": types}) return await self.api_call("files.list", http_verb="GET", params=kwargs) async def files_remote_info( self, *, external_id: Optional[str] = None, file: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve information about a remote file added to Slack. https://api.slack.com/methods/files.remote.info """ kwargs.update({"external_id": external_id, "file": file}) return await self.api_call("files.remote.info", http_verb="GET", params=kwargs) async def files_remote_list( self, *, channel: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, ts_from: Optional[str] = None, ts_to: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve information about a remote file added to Slack. https://api.slack.com/methods/files.remote.list """ kwargs.update( { "channel": channel, "cursor": cursor, "limit": limit, "ts_from": ts_from, "ts_to": ts_to, } ) return await self.api_call("files.remote.list", http_verb="GET", params=kwargs) async def files_remote_add( self, *, external_id: str, external_url: str, title: str, filetype: Optional[str] = None, indexable_file_contents: Optional[Union[str, bytes, IOBase]] = None, preview_image: Optional[Union[str, bytes, IOBase]] = None, **kwargs, ) -> AsyncSlackResponse: """Adds a file from a remote service. https://api.slack.com/methods/files.remote.add """ kwargs.update( { "external_id": external_id, "external_url": external_url, "title": title, "filetype": filetype, } ) files = None # preview_image (file): Preview of the document via multipart/form-data. if preview_image is not None or indexable_file_contents is not None: files = { "preview_image": preview_image, "indexable_file_contents": indexable_file_contents, } return await self.api_call( # Intentionally using "POST" method over "GET" here "files.remote.add", http_verb="POST", data=kwargs, files=files, ) async def files_remote_update( self, *, external_id: Optional[str] = None, external_url: Optional[str] = None, file: Optional[str] = None, title: Optional[str] = None, filetype: Optional[str] = None, indexable_file_contents: Optional[str] = None, preview_image: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Updates an existing remote file. https://api.slack.com/methods/files.remote.update """ kwargs.update( { "external_id": external_id, "external_url": external_url, "file": file, "title": title, "filetype": filetype, } ) files = None # preview_image (file): Preview of the document via multipart/form-data. if preview_image is not None or indexable_file_contents is not None: files = { "preview_image": preview_image, "indexable_file_contents": indexable_file_contents, } return await self.api_call( # Intentionally using "POST" method over "GET" here "files.remote.update", http_verb="POST", data=kwargs, files=files, ) async def files_remote_remove( self, *, external_id: Optional[str] = None, file: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Remove a remote file. https://api.slack.com/methods/files.remote.remove """ kwargs.update({"external_id": external_id, "file": file}) return await self.api_call("files.remote.remove", http_verb="POST", params=kwargs) async def files_remote_share( self, *, channels: Union[str, Sequence[str]], external_id: Optional[str] = None, file: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Share a remote file into a channel. https://api.slack.com/methods/files.remote.share """ if external_id is None and file is None: raise e.SlackRequestError("Either external_id or file must be provided.") if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) kwargs.update({"external_id": external_id, "file": file}) return await self.api_call("files.remote.share", http_verb="GET", params=kwargs) async def files_revokePublicURL( self, *, file: str, **kwargs, ) -> AsyncSlackResponse: """Revokes public/external sharing access for a file https://api.slack.com/methods/files.revokePublicURL """ kwargs.update({"file": file}) return await self.api_call("files.revokePublicURL", params=kwargs) async def files_sharedPublicURL( self, *, file: str, **kwargs, ) -> AsyncSlackResponse: """Enables a file for public/external sharing. https://api.slack.com/methods/files.sharedPublicURL """ kwargs.update({"file": file}) return await self.api_call("files.sharedPublicURL", params=kwargs) async def files_upload( self, *, file: Optional[Union[str, bytes, IOBase]] = None, content: Optional[Union[str, bytes]] = None, filename: Optional[str] = None, filetype: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, title: Optional[str] = None, channels: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Uploads or creates a file. https://api.slack.com/methods/files.upload """ _print_files_upload_v2_suggestion() if file is None and content is None: raise e.SlackRequestError("The file or content argument must be specified.") if file is not None and content is not None: raise e.SlackRequestError("You cannot specify both the file and the content argument.") if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) kwargs.update( { "filename": filename, "filetype": filetype, "initial_comment": initial_comment, "thread_ts": thread_ts, "title": title, } ) if file: if kwargs.get("filename") is None and isinstance(file, str): # use the local filename if filename is missing if kwargs.get("filename") is None: kwargs["filename"] = file.split(os.path.sep)[-1] return await self.api_call("files.upload", files={"file": file}, data=kwargs) else: kwargs["content"] = content return await self.api_call("files.upload", data=kwargs) async def files_upload_v2( self, *, # for sending a single file filename: Optional[str] = None, # you can skip this only when sending along with content parameter file: Optional[Union[str, bytes, IOBase]] = None, content: Optional[Union[str, bytes]] = None, title: Optional[str] = None, alt_txt: Optional[str] = None, snippet_type: Optional[str] = None, # To upload multiple files at a time file_uploads: Optional[List[Dict[str, Any]]] = None, channel: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, request_file_info: bool = True, **kwargs, ) -> AsyncSlackResponse: """This wrapper method provides an easy way to upload files using the following endpoints: - step1: https://api.slack.com/methods/files.getUploadURLExternal - step2: "https://files.slack.com/upload/v1/..." URLs returned from files.getUploadURLExternal API - step3: https://api.slack.com/methods/files.completeUploadExternal and https://api.slack.com/methods/files.info """ if file is None and content is None and file_uploads is None: raise e.SlackRequestError("Any of file, content, and file_uploads must be specified.") if file is not None and content is not None: raise e.SlackRequestError("You cannot specify both the file and the content argument.") # deprecated arguments: channels, filetype = kwargs.get("channels"), kwargs.get("filetype") if channels is not None: warnings.warn( "Although the channels parameter is still supported for smooth migration from legacy files.upload, " "we recommend using the new channel parameter with a single str value instead for more clarity." ) if (isinstance(channels, (list, Tuple)) and len(channels) > 1) or ( isinstance(channels, str) and len(channels.split(",")) > 1 ): raise e.SlackRequestError( "Sharing files with multiple channels is no longer supported in v2. " "Share files in each channel separately instead." ) if filetype is not None: warnings.warn("The filetype parameter is no longer supported. Please remove it from the arguments.") # step1: files.getUploadURLExternal per file files: List[Dict[str, Any]] = [] if file_uploads is not None: for f in file_uploads: files.append(_to_v2_file_upload_item(f)) else: f = _to_v2_file_upload_item( { "filename": filename, "file": file, "content": content, "title": title, "alt_txt": alt_txt, "snippet_type": snippet_type, } ) files.append(f) for f in files: url_response = await self.files_getUploadURLExternal( filename=f.get("filename"), length=f.get("length"), alt_txt=f.get("alt_txt"), snippet_type=f.get("snippet_type"), token=kwargs.get("token"), ) _validate_for_legacy_client(url_response) f["file_id"] = url_response.get("file_id") # type: ignore f["upload_url"] = url_response.get("upload_url") # type: ignore # step2: "https://files.slack.com/upload/v1/..." per file for f in files: upload_result = _upload_file_via_v2_url( url=f["upload_url"], data=f["data"], logger=self._logger, timeout=self.timeout, proxy=self.proxy, ssl=self.ssl, ) if upload_result.get("status") != 200: status = upload_result.get("status") body = upload_result.get("body") message = ( "Failed to upload a file " f"(status: {status}, body: {body}, filename: {f.get('filename')}, title: {f.get('title')})" ) raise e.SlackRequestError(message) # step3: files.completeUploadExternal with all the sets of (file_id + title) channel_to_share = channel if channels is not None: if isinstance(channels, str): channel_to_share = channels.split(",")[0] else: channel_to_share = channels[0] completion = await self.files_completeUploadExternal( files=[{"id": f["file_id"], "title": f["title"]} for f in files], channel_id=channel_to_share, initial_comment=initial_comment, thread_ts=thread_ts, token=kwargs.get("token"), **kwargs, ) if request_file_info is True: await _attach_full_file_metadata_async( client=self, token_as_arg=kwargs.get("token"), completion=completion, ) return completion async def files_getUploadURLExternal( self, *, filename: str, length: int, alt_txt: Optional[str] = None, snippet_type: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets a URL for an edge external upload. https://api.slack.com/methods/files.getUploadURLExternal """ kwargs.update( { "filename": filename, "length": length, "alt_txt": alt_txt, "snippet_type": snippet_type, } ) return await self.api_call("files.getUploadURLExternal", params=kwargs) async def files_completeUploadExternal( self, *, files: List[Dict[str, str]], channel_id: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Finishes an upload started with files.getUploadURLExternal. https://api.slack.com/methods/files.completeUploadExternal """ _files = [{k: v for k, v in f.items() if v is not None} for f in files] kwargs.update( { "files": json.dumps(_files), "channel_id": channel_id, "initial_comment": initial_comment, "thread_ts": thread_ts, } ) return await self.api_call("files.completeUploadExternal", params=kwargs) # -------------------------- # Deprecated: groups.* # You can use conversations.* APIs instead. # https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api # -------------------------- async def groups_archive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Archives a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.archive", json=kwargs) async def groups_create( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Creates a private channel.""" kwargs.update({"name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.create", json=kwargs) async def groups_createChild( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Clones and archives a private channel.""" kwargs.update({"channel": channel}) return await self.api_call("groups.createChild", http_verb="GET", params=kwargs) async def groups_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from a private channel.""" kwargs.update({"channel": channel}) return await self.api_call("groups.history", http_verb="GET", params=kwargs) async def groups_info( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Gets information about a private channel.""" kwargs.update({"channel": channel}) return await self.api_call("groups.info", http_verb="GET", params=kwargs) async def groups_invite( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Invites a user to a private channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.invite", json=kwargs) async def groups_kick( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Removes a user from a private channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.kick", json=kwargs) async def groups_leave( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Leaves a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.leave", json=kwargs) async def groups_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists private channels that the calling user has access to.""" return await self.api_call("groups.list", http_verb="GET", params=kwargs) async def groups_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a private channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.mark", json=kwargs) async def groups_open( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Opens a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.open", json=kwargs) async def groups_rename( self, *, channel: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Renames a private channel.""" kwargs.update({"channel": channel, "name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.rename", json=kwargs) async def groups_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a private channel""" kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("groups.replies", http_verb="GET", params=kwargs) async def groups_setPurpose( self, *, channel: str, purpose: str, **kwargs, ) -> AsyncSlackResponse: """Sets the purpose for a private channel.""" kwargs.update({"channel": channel, "purpose": purpose}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.setPurpose", json=kwargs) async def groups_setTopic( self, *, channel: str, topic: str, **kwargs, ) -> AsyncSlackResponse: """Sets the topic for a private channel.""" kwargs.update({"channel": channel, "topic": topic}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.setTopic", json=kwargs) async def groups_unarchive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Unarchives a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.unarchive", json=kwargs) # -------------------------- # Deprecated: im.* # You can use conversations.* APIs instead. # https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api # -------------------------- async def im_close( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Close a direct message channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("im.close", json=kwargs) async def im_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from direct message channel.""" kwargs.update({"channel": channel}) return await self.api_call("im.history", http_verb="GET", params=kwargs) async def im_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists direct message channels for the calling user.""" return await self.api_call("im.list", http_verb="GET", params=kwargs) async def im_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a direct message channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("im.mark", json=kwargs) async def im_open( self, *, user: str, **kwargs, ) -> AsyncSlackResponse: """Opens a direct message channel.""" kwargs.update({"user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("im.open", json=kwargs) async def im_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a direct message conversation""" kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("im.replies", http_verb="GET", params=kwargs) # -------------------------- async def migration_exchange( self, *, users: Union[str, Sequence[str]], team_id: Optional[str] = None, to_old: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """For Enterprise Grid workspaces, map local user IDs to global user IDs https://api.slack.com/methods/migration.exchange """ if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) kwargs.update({"team_id": team_id, "to_old": to_old}) return await self.api_call("migration.exchange", http_verb="GET", params=kwargs) # -------------------------- # Deprecated: mpim.* # You can use conversations.* APIs instead. # https://api.slack.com/changelog/2020-01-deprecating-antecedents-to-the-conversations-api # -------------------------- async def mpim_close( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Closes a multiparty direct message channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("mpim.close", json=kwargs) async def mpim_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from a multiparty direct message.""" kwargs.update({"channel": channel}) return await self.api_call("mpim.history", http_verb="GET", params=kwargs) async def mpim_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists multiparty direct message channels for the calling user.""" return await self.api_call("mpim.list", http_verb="GET", params=kwargs) async def mpim_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a multiparty direct message channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("mpim.mark", json=kwargs) async def mpim_open( self, *, users: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """This method opens a multiparty direct message.""" if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("mpim.open", params=kwargs) async def mpim_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a direct message conversation from a multiparty direct message. """ kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("mpim.replies", http_verb="GET", params=kwargs) # -------------------------- async def oauth_v2_access( self, *, client_id: str, client_secret: str, # This field is required when processing the OAuth redirect URL requests # while it's absent for token rotation code: Optional[str] = None, redirect_uri: Optional[str] = None, # This field is required for token rotation grant_type: Optional[str] = None, # This field is required for token rotation refresh_token: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Exchanges a temporary OAuth verifier code for an access token. https://api.slack.com/methods/oauth.v2.access """ if redirect_uri is not None: kwargs.update({"redirect_uri": redirect_uri}) if code is not None: kwargs.update({"code": code}) if grant_type is not None: kwargs.update({"grant_type": grant_type}) if refresh_token is not None: kwargs.update({"refresh_token": refresh_token}) return await self.api_call( "oauth.v2.access", data=kwargs, auth={"client_id": client_id, "client_secret": client_secret}, ) async def oauth_access( self, *, client_id: str, client_secret: str, code: str, redirect_uri: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Exchanges a temporary OAuth verifier code for an access token. https://api.slack.com/methods/oauth.access """ if redirect_uri is not None: kwargs.update({"redirect_uri": redirect_uri}) kwargs.update({"code": code}) return await self.api_call( "oauth.access", data=kwargs, auth={"client_id": client_id, "client_secret": client_secret}, ) async def oauth_v2_exchange( self, *, token: str, client_id: str, client_secret: str, **kwargs, ) -> AsyncSlackResponse: """Exchanges a legacy access token for a new expiring access token and refresh token https://api.slack.com/methods/oauth.v2.exchange """ kwargs.update({"client_id": client_id, "client_secret": client_secret, "token": token}) return await self.api_call("oauth.v2.exchange", params=kwargs) async def openid_connect_token( self, client_id: str, client_secret: str, code: Optional[str] = None, redirect_uri: Optional[str] = None, grant_type: Optional[str] = None, refresh_token: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Exchanges a temporary OAuth verifier code for an access token for Sign in with Slack. https://api.slack.com/methods/openid.connect.token """ if redirect_uri is not None: kwargs.update({"redirect_uri": redirect_uri}) if code is not None: kwargs.update({"code": code}) if grant_type is not None: kwargs.update({"grant_type": grant_type}) if refresh_token is not None: kwargs.update({"refresh_token": refresh_token}) return await self.api_call( "openid.connect.token", data=kwargs, auth={"client_id": client_id, "client_secret": client_secret}, ) async def openid_connect_userInfo( self, **kwargs, ) -> AsyncSlackResponse: """Get the identity of a user who has authorized Sign in with Slack. https://api.slack.com/methods/openid.connect.userInfo """ return await self.api_call("openid.connect.userInfo", params=kwargs) async def pins_add( self, *, channel: str, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Pins an item to a channel. https://api.slack.com/methods/pins.add """ kwargs.update({"channel": channel, "timestamp": timestamp}) return await self.api_call("pins.add", params=kwargs) async def pins_list( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Lists items pinned to a channel. https://api.slack.com/methods/pins.list """ kwargs.update({"channel": channel}) return await self.api_call("pins.list", http_verb="GET", params=kwargs) async def pins_remove( self, *, channel: str, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Un-pins an item from a channel. https://api.slack.com/methods/pins.remove """ kwargs.update({"channel": channel, "timestamp": timestamp}) return await self.api_call("pins.remove", params=kwargs) async def reactions_add( self, *, channel: str, name: str, timestamp: str, **kwargs, ) -> AsyncSlackResponse: """Adds a reaction to an item. https://api.slack.com/methods/reactions.add """ kwargs.update({"channel": channel, "name": name, "timestamp": timestamp}) return await self.api_call("reactions.add", params=kwargs) async def reactions_get( self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, full: Optional[bool] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets reactions for an item. https://api.slack.com/methods/reactions.get """ kwargs.update( { "channel": channel, "file": file, "file_comment": file_comment, "full": full, "timestamp": timestamp, } ) return await self.api_call("reactions.get", http_verb="GET", params=kwargs) async def reactions_list( self, *, count: Optional[int] = None, cursor: Optional[str] = None, full: Optional[bool] = None, limit: Optional[int] = None, page: Optional[int] = None, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists reactions made by a user. https://api.slack.com/methods/reactions.list """ kwargs.update( { "count": count, "cursor": cursor, "full": full, "limit": limit, "page": page, "team_id": team_id, "user": user, } ) return await self.api_call("reactions.list", http_verb="GET", params=kwargs) async def reactions_remove( self, *, name: str, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Removes a reaction from an item. https://api.slack.com/methods/reactions.remove """ kwargs.update( { "name": name, "channel": channel, "file": file, "file_comment": file_comment, "timestamp": timestamp, } ) return await self.api_call("reactions.remove", params=kwargs) async def reminders_add( self, *, text: str, time: str, team_id: Optional[str] = None, user: Optional[str] = None, recurrence: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Creates a reminder. https://api.slack.com/methods/reminders.add """ kwargs.update( { "text": text, "time": time, "team_id": team_id, "user": user, "recurrence": recurrence, } ) return await self.api_call("reminders.add", params=kwargs) async def reminders_complete( self, *, reminder: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Marks a reminder as complete. https://api.slack.com/methods/reminders.complete """ kwargs.update({"reminder": reminder, "team_id": team_id}) return await self.api_call("reminders.complete", params=kwargs) async def reminders_delete( self, *, reminder: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Deletes a reminder. https://api.slack.com/methods/reminders.delete """ kwargs.update({"reminder": reminder, "team_id": team_id}) return await self.api_call("reminders.delete", params=kwargs) async def reminders_info( self, *, reminder: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a reminder. https://api.slack.com/methods/reminders.info """ kwargs.update({"reminder": reminder, "team_id": team_id}) return await self.api_call("reminders.info", http_verb="GET", params=kwargs) async def reminders_list( self, *, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all reminders created by or for a given user. https://api.slack.com/methods/reminders.list """ kwargs.update({"team_id": team_id}) return await self.api_call("reminders.list", http_verb="GET", params=kwargs) async def rtm_connect( self, *, batch_presence_aware: Optional[bool] = None, presence_sub: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Starts a Real Time Messaging session. https://api.slack.com/methods/rtm.connect """ kwargs.update({"batch_presence_aware": batch_presence_aware, "presence_sub": presence_sub}) return await self.api_call("rtm.connect", http_verb="GET", params=kwargs) async def rtm_start( self, *, batch_presence_aware: Optional[bool] = None, include_locale: Optional[bool] = None, mpim_aware: Optional[bool] = None, no_latest: Optional[bool] = None, no_unreads: Optional[bool] = None, presence_sub: Optional[bool] = None, simple_latest: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Starts a Real Time Messaging session. https://api.slack.com/methods/rtm.start """ kwargs.update( { "batch_presence_aware": batch_presence_aware, "include_locale": include_locale, "mpim_aware": mpim_aware, "no_latest": no_latest, "no_unreads": no_unreads, "presence_sub": presence_sub, "simple_latest": simple_latest, } ) return await self.api_call("rtm.start", http_verb="GET", params=kwargs) async def search_all( self, *, query: str, count: Optional[int] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Searches for messages and files matching a query. https://api.slack.com/methods/search.all """ kwargs.update( { "query": query, "count": count, "highlight": highlight, "page": page, "sort": sort, "sort_dir": sort_dir, "team_id": team_id, } ) return await self.api_call("search.all", http_verb="GET", params=kwargs) async def search_files( self, *, query: str, count: Optional[int] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Searches for files matching a query. https://api.slack.com/methods/search.files """ kwargs.update( { "query": query, "count": count, "highlight": highlight, "page": page, "sort": sort, "sort_dir": sort_dir, "team_id": team_id, } ) return await self.api_call("search.files", http_verb="GET", params=kwargs) async def search_messages( self, *, query: str, count: Optional[int] = None, cursor: Optional[str] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Searches for messages matching a query. https://api.slack.com/methods/search.messages """ kwargs.update( { "query": query, "count": count, "cursor": cursor, "highlight": highlight, "page": page, "sort": sort, "sort_dir": sort_dir, "team_id": team_id, } ) return await self.api_call("search.messages", http_verb="GET", params=kwargs) async def stars_add( self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Adds a star to an item. https://api.slack.com/methods/stars.add """ kwargs.update( { "channel": channel, "file": file, "file_comment": file_comment, "timestamp": timestamp, } ) return await self.api_call("stars.add", params=kwargs) async def stars_list( self, *, count: Optional[int] = None, cursor: Optional[str] = None, limit: Optional[int] = None, page: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists stars for a user. https://api.slack.com/methods/stars.list """ kwargs.update( { "count": count, "cursor": cursor, "limit": limit, "page": page, "team_id": team_id, } ) return await self.api_call("stars.list", http_verb="GET", params=kwargs) async def stars_remove( self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Removes a star from an item. https://api.slack.com/methods/stars.remove """ kwargs.update( { "channel": channel, "file": file, "file_comment": file_comment, "timestamp": timestamp, } ) return await self.api_call("stars.remove", params=kwargs) async def team_accessLogs( self, *, before: Optional[Union[int, str]] = None, count: Optional[Union[int, str]] = None, page: Optional[Union[int, str]] = None, team_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Gets the access logs for the current team. https://api.slack.com/methods/team.accessLogs """ kwargs.update( { "before": before, "count": count, "page": page, "team_id": team_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("team.accessLogs", http_verb="GET", params=kwargs) async def team_billableInfo( self, *, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets billable users information for the current team. https://api.slack.com/methods/team.billableInfo """ kwargs.update({"team_id": team_id, "user": user}) return await self.api_call("team.billableInfo", http_verb="GET", params=kwargs) async def team_billing_info( self, **kwargs, ) -> AsyncSlackResponse: """Reads a workspace's billing plan information. https://api.slack.com/methods/team.billing.info """ return await self.api_call("team.billing.info", params=kwargs) async def team_info( self, *, team: Optional[str] = None, domain: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about the current team. https://api.slack.com/methods/team.info """ kwargs.update({"team": team, "domain": domain}) return await self.api_call("team.info", http_verb="GET", params=kwargs) async def team_integrationLogs( self, *, app_id: Optional[str] = None, change_type: Optional[str] = None, count: Optional[Union[int, str]] = None, page: Optional[Union[int, str]] = None, service_id: Optional[str] = None, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets the integration logs for the current team. https://api.slack.com/methods/team.integrationLogs """ kwargs.update( { "app_id": app_id, "change_type": change_type, "count": count, "page": page, "service_id": service_id, "team_id": team_id, "user": user, } ) return await self.api_call("team.integrationLogs", http_verb="GET", params=kwargs) async def team_profile_get( self, *, visibility: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve a team's profile. https://api.slack.com/methods/team.profile.get """ kwargs.update({"visibility": visibility}) return await self.api_call("team.profile.get", http_verb="GET", params=kwargs) async def team_preferences_list( self, **kwargs, ) -> AsyncSlackResponse: """Retrieve a list of a workspace's team preferences. https://api.slack.com/methods/team.preferences.list """ return await self.api_call("team.preferences.list", params=kwargs) async def usergroups_create( self, *, name: str, channels: Optional[Union[str, Sequence[str]]] = None, description: Optional[str] = None, handle: Optional[str] = None, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Create a User Group https://api.slack.com/methods/usergroups.create """ kwargs.update( { "name": name, "description": description, "handle": handle, "include_count": include_count, "team_id": team_id, } ) if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) return await self.api_call("usergroups.create", params=kwargs) async def usergroups_disable( self, *, usergroup: str, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Disable an existing User Group https://api.slack.com/methods/usergroups.disable """ kwargs.update({"usergroup": usergroup, "include_count": include_count, "team_id": team_id}) return await self.api_call("usergroups.disable", params=kwargs) async def usergroups_enable( self, *, usergroup: str, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Enable a User Group https://api.slack.com/methods/usergroups.enable """ kwargs.update({"usergroup": usergroup, "include_count": include_count, "team_id": team_id}) return await self.api_call("usergroups.enable", params=kwargs) async def usergroups_list( self, *, include_count: Optional[bool] = None, include_disabled: Optional[bool] = None, include_users: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all User Groups for a team https://api.slack.com/methods/usergroups.list """ kwargs.update( { "include_count": include_count, "include_disabled": include_disabled, "include_users": include_users, "team_id": team_id, } ) return await self.api_call("usergroups.list", http_verb="GET", params=kwargs) async def usergroups_update( self, *, usergroup: str, channels: Optional[Union[str, Sequence[str]]] = None, description: Optional[str] = None, handle: Optional[str] = None, include_count: Optional[bool] = None, name: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Update an existing User Group https://api.slack.com/methods/usergroups.update """ kwargs.update( { "usergroup": usergroup, "description": description, "handle": handle, "include_count": include_count, "name": name, "team_id": team_id, } ) if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) return await self.api_call("usergroups.update", params=kwargs) async def usergroups_users_list( self, *, usergroup: str, include_disabled: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all users in a User Group https://api.slack.com/methods/usergroups.users.list """ kwargs.update( { "usergroup": usergroup, "include_disabled": include_disabled, "team_id": team_id, } ) return await self.api_call("usergroups.users.list", http_verb="GET", params=kwargs) async def usergroups_users_update( self, *, usergroup: str, users: Union[str, Sequence[str]], include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Update the list of users for a User Group https://api.slack.com/methods/usergroups.users.update """ kwargs.update( { "usergroup": usergroup, "include_count": include_count, "team_id": team_id, } ) if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("usergroups.users.update", params=kwargs) async def users_conversations( self, *, cursor: Optional[str] = None, exclude_archived: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, types: Optional[Union[str, Sequence[str]]] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List conversations the calling user may access. https://api.slack.com/methods/users.conversations """ kwargs.update( { "cursor": cursor, "exclude_archived": exclude_archived, "limit": limit, "team_id": team_id, "user": user, } ) if isinstance(types, (list, Tuple)): kwargs.update({"types": ",".join(types)}) else: kwargs.update({"types": types}) return await self.api_call("users.conversations", http_verb="GET", params=kwargs) async def users_deletePhoto( self, **kwargs, ) -> AsyncSlackResponse: """Delete the user profile photo https://api.slack.com/methods/users.deletePhoto """ return await self.api_call("users.deletePhoto", http_verb="GET", params=kwargs) async def users_getPresence( self, *, user: str, **kwargs, ) -> AsyncSlackResponse: """Gets user presence information. https://api.slack.com/methods/users.getPresence """ kwargs.update({"user": user}) return await self.api_call("users.getPresence", http_verb="GET", params=kwargs) async def users_identity( self, **kwargs, ) -> AsyncSlackResponse: """Get a user's identity. https://api.slack.com/methods/users.identity """ return await self.api_call("users.identity", http_verb="GET", params=kwargs) async def users_info( self, *, user: str, include_locale: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a user. https://api.slack.com/methods/users.info """ kwargs.update({"user": user, "include_locale": include_locale}) return await self.api_call("users.info", http_verb="GET", params=kwargs) async def users_list( self, *, cursor: Optional[str] = None, include_locale: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all users in a Slack team. https://api.slack.com/methods/users.list """ kwargs.update( { "cursor": cursor, "include_locale": include_locale, "limit": limit, "team_id": team_id, } ) return await self.api_call("users.list", http_verb="GET", params=kwargs) async def users_lookupByEmail( self, *, email: str, **kwargs, ) -> AsyncSlackResponse: """Find a user with an email address. https://api.slack.com/methods/users.lookupByEmail """ kwargs.update({"email": email}) return await self.api_call("users.lookupByEmail", http_verb="GET", params=kwargs) async def users_setPhoto( self, *, image: Union[str, IOBase], crop_w: Optional[Union[int, str]] = None, crop_x: Optional[Union[int, str]] = None, crop_y: Optional[Union[int, str]] = None, **kwargs, ) -> AsyncSlackResponse: """Set the user profile photo https://api.slack.com/methods/users.setPhoto """ kwargs.update({"crop_w": crop_w, "crop_x": crop_x, "crop_y": crop_y}) return await self.api_call("users.setPhoto", files={"image": image}, data=kwargs) async def users_setPresence( self, *, presence: str, **kwargs, ) -> AsyncSlackResponse: """Manually sets user presence. https://api.slack.com/methods/users.setPresence """ kwargs.update({"presence": presence}) return await self.api_call("users.setPresence", params=kwargs) async def users_profile_get( self, *, user: Optional[str] = None, include_labels: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieves a user's profile information. https://api.slack.com/methods/users.profile.get """ kwargs.update({"user": user, "include_labels": include_labels}) return await self.api_call("users.profile.get", http_verb="GET", params=kwargs) async def users_profile_set( self, *, name: Optional[str] = None, value: Optional[str] = None, user: Optional[str] = None, profile: Optional[Dict] = None, **kwargs, ) -> AsyncSlackResponse: """Set the profile information for a user. https://api.slack.com/methods/users.profile.set """ kwargs.update( { "name": name, "profile": profile, "user": user, "value": value, } ) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "profile" parameter return await self.api_call("users.profile.set", json=kwargs) async def views_open( self, *, trigger_id: str, view: Union[dict, View], **kwargs, ) -> AsyncSlackResponse: """Open a view for a user. https://api.slack.com/methods/views.open See https://api.slack.com/block-kit/surfaces/modals for details. """ kwargs.update({"trigger_id": trigger_id}) if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.open", json=kwargs) async def views_push( self, *, trigger_id: str, view: Union[dict, View], **kwargs, ) -> AsyncSlackResponse: """Push a view onto the stack of a root view. Push a new view onto the existing view stack by passing a view payload and a valid trigger_id generated from an interaction within the existing modal. Read the modals documentation (https://api.slack.com/block-kit/surfaces/modals) to learn more about the lifecycle and intricacies of views. https://api.slack.com/methods/views.push """ kwargs.update({"trigger_id": trigger_id}) if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.push", json=kwargs) async def views_update( self, *, view: Union[dict, View], external_id: Optional[str] = None, view_id: Optional[str] = None, hash: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Update an existing view. Update a view by passing a new view definition along with the view_id returned in views.open or the external_id. See the modals documentation (https://api.slack.com/block-kit/surfaces/modals#updating_views) to learn more about updating views and avoiding race conditions with the hash argument. https://api.slack.com/methods/views.update """ if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) if external_id: kwargs.update({"external_id": external_id}) elif view_id: kwargs.update({"view_id": view_id}) else: raise e.SlackRequestError("Either view_id or external_id is required.") kwargs.update({"hash": hash}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.update", json=kwargs) async def views_publish( self, *, user_id: str, view: Union[dict, View], hash: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Publish a static view for a User. Create or update the view that comprises an app's Home tab (https://api.slack.com/surfaces/tabs) https://api.slack.com/methods/views.publish """ kwargs.update({"user_id": user_id, "hash": hash}) if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.publish", json=kwargs) async def workflows_stepCompleted( self, *, workflow_step_execute_id: str, outputs: Optional[dict] = None, **kwargs, ) -> AsyncSlackResponse: """Indicate a successful outcome of a workflow step's execution. https://api.slack.com/methods/workflows.stepCompleted """ kwargs.update({"workflow_step_execute_id": workflow_step_execute_id}) if outputs is not None: kwargs.update({"outputs": outputs}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "outputs" parameter return await self.api_call("workflows.stepCompleted", json=kwargs) async def workflows_stepFailed( self, *, workflow_step_execute_id: str, error: Dict[str, str], **kwargs, ) -> AsyncSlackResponse: """Indicate an unsuccessful outcome of a workflow step's execution. https://api.slack.com/methods/workflows.stepFailed """ kwargs.update( { "workflow_step_execute_id": workflow_step_execute_id, "error": error, } ) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "error" parameter return await self.api_call("workflows.stepFailed", json=kwargs) async def workflows_updateStep( self, *, workflow_step_edit_id: str, inputs: Optional[Dict[str, Any]] = None, outputs: Optional[List[Dict[str, str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Update the configuration for a workflow extension step. https://api.slack.com/methods/workflows.updateStep """ kwargs.update({"workflow_step_edit_id": workflow_step_edit_id}) if inputs is not None: kwargs.update({"inputs": inputs}) if outputs is not None: kwargs.update({"outputs": outputs}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "inputs" / "outputs" parameters return await self.api_call("workflows.updateStep", json=kwargs)
Ancestors
Methods
async def admin_analytics_getFile(self, *, type: str, date: Optional[str] = None, metadata_only: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve analytics data for a given date, presented as a compressed JSON file https://api.slack.com/methods/admin.analytics.getFile
Expand source code
async def admin_analytics_getFile( self, *, type: str, date: Optional[str] = None, metadata_only: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve analytics data for a given date, presented as a compressed JSON file https://api.slack.com/methods/admin.analytics.getFile """ kwargs.update({"type": type}) if date is not None: kwargs.update({"date": date}) if metadata_only is not None: kwargs.update({"metadata_only": metadata_only}) return await self.api_call("admin.analytics.getFile", params=kwargs)
async def admin_apps_activities_list(self, *, app_id: Optional[str] = None, component_id: Optional[str] = None, component_type: Optional[str] = None, log_event_type: Optional[str] = None, max_date_created: Optional[int] = None, min_date_created: Optional[int] = None, min_log_level: Optional[str] = None, sort_direction: Optional[str] = None, source: Optional[str] = None, team_id: Optional[str] = None, trace_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Get logs for a specified team/org https://api.slack.com/methods/admin.apps.activities.list
Expand source code
async def admin_apps_activities_list( self, *, app_id: Optional[str] = None, component_id: Optional[str] = None, component_type: Optional[str] = None, log_event_type: Optional[str] = None, max_date_created: Optional[int] = None, min_date_created: Optional[int] = None, min_log_level: Optional[str] = None, sort_direction: Optional[str] = None, source: Optional[str] = None, team_id: Optional[str] = None, trace_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Get logs for a specified team/org https://api.slack.com/methods/admin.apps.activities.list """ kwargs.update( { "app_id": app_id, "component_id": component_id, "component_type": component_type, "log_event_type": log_event_type, "max_date_created": max_date_created, "min_date_created": min_date_created, "min_log_level": min_log_level, "sort_direction": sort_direction, "source": source, "team_id": team_id, "trace_id": trace_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.apps.activities.list", params=kwargs)
async def admin_apps_approve(self, *, app_id: Optional[str] = None, request_id: Optional[str] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Approve an app for installation on a workspace. Either app_id or request_id is required. These IDs can be obtained either directly via the app_requested event, or by the admin.apps.requests.list method. https://api.slack.com/methods/admin.apps.approve
Expand source code
async def admin_apps_approve( self, *, app_id: Optional[str] = None, request_id: Optional[str] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Approve an app for installation on a workspace. Either app_id or request_id is required. These IDs can be obtained either directly via the app_requested event, or by the admin.apps.requests.list method. https://api.slack.com/methods/admin.apps.approve """ if app_id: kwargs.update({"app_id": app_id}) elif request_id: kwargs.update({"request_id": request_id}) else: raise e.SlackRequestError("The app_id or request_id argument must be specified.") kwargs.update( { "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.approve", params=kwargs)
async def admin_apps_approved_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List approved apps for an org or workspace. https://api.slack.com/methods/admin.apps.approved.list
Expand source code
async def admin_apps_approved_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List approved apps for an org or workspace. https://api.slack.com/methods/admin.apps.approved.list """ kwargs.update( { "cursor": cursor, "limit": limit, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.approved.list", http_verb="GET", params=kwargs)
async def admin_apps_clearResolution(self, *, app_id: str, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Clear an app resolution https://api.slack.com/methods/admin.apps.clearResolution
Expand source code
async def admin_apps_clearResolution( self, *, app_id: str, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Clear an app resolution https://api.slack.com/methods/admin.apps.clearResolution """ kwargs.update( { "app_id": app_id, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.clearResolution", http_verb="POST", params=kwargs)
async def admin_apps_config_lookup(self, *, app_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Look up the app config for connectors by their IDs https://api.slack.com/methods/admin.apps.config.lookup
Expand source code
async def admin_apps_config_lookup( self, *, app_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Look up the app config for connectors by their IDs https://api.slack.com/methods/admin.apps.config.lookup """ if isinstance(app_ids, (list, Tuple)): kwargs.update({"app_ids": ",".join(app_ids)}) else: kwargs.update({"app_ids": app_ids}) return await self.api_call("admin.apps.config.lookup", params=kwargs)
async def admin_apps_config_set(self, *, app_id: str, domain_restrictions: Optional[Dict[str, Any]] = None, workflow_auth_strategy: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Set the app config for a connector https://api.slack.com/methods/admin.apps.config.set
Expand source code
async def admin_apps_config_set( self, *, app_id: str, domain_restrictions: Optional[Dict[str, Any]] = None, workflow_auth_strategy: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Set the app config for a connector https://api.slack.com/methods/admin.apps.config.set """ kwargs.update( { "app_id": app_id, "workflow_auth_strategy": workflow_auth_strategy, } ) if domain_restrictions is not None: kwargs.update({"domain_restrictions": json.dumps(domain_restrictions)}) return await self.api_call("admin.apps.config.set", params=kwargs)
async def admin_apps_requests_cancel(self, *, request_id: str, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List app requests for a team/workspace. https://api.slack.com/methods/admin.apps.requests.cancel
Expand source code
async def admin_apps_requests_cancel( self, *, request_id: str, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List app requests for a team/workspace. https://api.slack.com/methods/admin.apps.requests.cancel """ kwargs.update( { "request_id": request_id, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.requests.cancel", http_verb="POST", params=kwargs)
async def admin_apps_requests_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List app requests for a team/workspace. https://api.slack.com/methods/admin.apps.requests.list
Expand source code
async def admin_apps_requests_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List app requests for a team/workspace. https://api.slack.com/methods/admin.apps.requests.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.apps.requests.list", http_verb="GET", params=kwargs)
async def admin_apps_restrict(self, *, app_id: Optional[str] = None, request_id: Optional[str] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Restrict an app for installation on a workspace. Exactly one of the team_id or enterprise_id arguments is required, not both. Either app_id or request_id is required. These IDs can be obtained either directly via the app_requested event, or by the admin.apps.requests.list method. https://api.slack.com/methods/admin.apps.restrict
Expand source code
async def admin_apps_restrict( self, *, app_id: Optional[str] = None, request_id: Optional[str] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Restrict an app for installation on a workspace. Exactly one of the team_id or enterprise_id arguments is required, not both. Either app_id or request_id is required. These IDs can be obtained either directly via the app_requested event, or by the admin.apps.requests.list method. https://api.slack.com/methods/admin.apps.restrict """ if app_id: kwargs.update({"app_id": app_id}) elif request_id: kwargs.update({"request_id": request_id}) else: raise e.SlackRequestError("The app_id or request_id argument must be specified.") kwargs.update( { "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.restrict", params=kwargs)
async def admin_apps_restricted_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List restricted apps for an org or workspace. https://api.slack.com/methods/admin.apps.restricted.list
Expand source code
async def admin_apps_restricted_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, enterprise_id: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List restricted apps for an org or workspace. https://api.slack.com/methods/admin.apps.restricted.list """ kwargs.update( { "cursor": cursor, "limit": limit, "enterprise_id": enterprise_id, "team_id": team_id, } ) return await self.api_call("admin.apps.restricted.list", http_verb="GET", params=kwargs)
async def admin_apps_uninstall(self, *, app_id: str, enterprise_id: Optional[str] = None, team_ids: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Uninstall an app from one or many workspaces, or an entire enterprise organization. With an org-level token, enterprise_id or team_ids is required. https://api.slack.com/methods/admin.apps.uninstall
Expand source code
async def admin_apps_uninstall( self, *, app_id: str, enterprise_id: Optional[str] = None, team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Uninstall an app from one or many workspaces, or an entire enterprise organization. With an org-level token, enterprise_id or team_ids is required. https://api.slack.com/methods/admin.apps.uninstall """ kwargs.update({"app_id": app_id}) if enterprise_id is not None: kwargs.update({"enterprise_id": enterprise_id}) if team_ids is not None: if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.apps.uninstall", http_verb="POST", params=kwargs)
async def admin_auth_policy_assignEntities(self, *, entity_ids: Union[str, Sequence[str]], policy_name: str, entity_type: str, **kwargs) ‑> AsyncSlackResponse
-
Assign entities to a particular authentication policy. https://api.slack.com/methods/admin.auth.policy.assignEntities
Expand source code
async def admin_auth_policy_assignEntities( self, *, entity_ids: Union[str, Sequence[str]], policy_name: str, entity_type: str, **kwargs, ) -> AsyncSlackResponse: """Assign entities to a particular authentication policy. https://api.slack.com/methods/admin.auth.policy.assignEntities """ if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) kwargs.update({"policy_name": policy_name}) kwargs.update({"entity_type": entity_type}) return await self.api_call("admin.auth.policy.assignEntities", http_verb="POST", params=kwargs)
async def admin_auth_policy_getEntities(self, *, policy_name: str, cursor: Optional[str] = None, entity_type: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Fetch all the entities assigned to a particular authentication policy by name. https://api.slack.com/methods/admin.auth.policy.getEntities
Expand source code
async def admin_auth_policy_getEntities( self, *, policy_name: str, cursor: Optional[str] = None, entity_type: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Fetch all the entities assigned to a particular authentication policy by name. https://api.slack.com/methods/admin.auth.policy.getEntities """ kwargs.update({"policy_name": policy_name}) if cursor is not None: kwargs.update({"cursor": cursor}) if entity_type is not None: kwargs.update({"entity_type": entity_type}) if limit is not None: kwargs.update({"limit": limit}) return await self.api_call("admin.auth.policy.getEntities", http_verb="POST", params=kwargs)
async def admin_auth_policy_removeEntities(self, *, entity_ids: Union[str, Sequence[str]], policy_name: str, entity_type: str, **kwargs) ‑> AsyncSlackResponse
-
Remove specified entities from a specified authentication policy. https://api.slack.com/methods/admin.auth.policy.removeEntities
Expand source code
async def admin_auth_policy_removeEntities( self, *, entity_ids: Union[str, Sequence[str]], policy_name: str, entity_type: str, **kwargs, ) -> AsyncSlackResponse: """Remove specified entities from a specified authentication policy. https://api.slack.com/methods/admin.auth.policy.removeEntities """ if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) kwargs.update({"policy_name": policy_name}) kwargs.update({"entity_type": entity_type}) return await self.api_call("admin.auth.policy.removeEntities", http_verb="POST", params=kwargs)
async def admin_barriers_create(self, *, barriered_from_usergroup_ids: Union[str, Sequence[str]], primary_usergroup_id: str, restricted_subjects: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Create an Information Barrier https://api.slack.com/methods/admin.barriers.create
Expand source code
async def admin_barriers_create( self, *, barriered_from_usergroup_ids: Union[str, Sequence[str]], primary_usergroup_id: str, restricted_subjects: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Create an Information Barrier https://api.slack.com/methods/admin.barriers.create """ kwargs.update({"primary_usergroup_id": primary_usergroup_id}) if isinstance(barriered_from_usergroup_ids, (list, Tuple)): kwargs.update({"barriered_from_usergroup_ids": ",".join(barriered_from_usergroup_ids)}) else: kwargs.update({"barriered_from_usergroup_ids": barriered_from_usergroup_ids}) if isinstance(restricted_subjects, (list, Tuple)): kwargs.update({"restricted_subjects": ",".join(restricted_subjects)}) else: kwargs.update({"restricted_subjects": restricted_subjects}) return await self.api_call("admin.barriers.create", http_verb="POST", params=kwargs)
async def admin_barriers_delete(self, *, barrier_id: str, **kwargs) ‑> AsyncSlackResponse
-
Delete an existing Information Barrier https://api.slack.com/methods/admin.barriers.delete
Expand source code
async def admin_barriers_delete( self, *, barrier_id: str, **kwargs, ) -> AsyncSlackResponse: """Delete an existing Information Barrier https://api.slack.com/methods/admin.barriers.delete """ kwargs.update({"barrier_id": barrier_id}) return await self.api_call("admin.barriers.delete", http_verb="POST", params=kwargs)
async def admin_barriers_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Get all Information Barriers for your organization https://api.slack.com/methods/admin.barriers.list
Expand source code
async def admin_barriers_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Get all Information Barriers for your organization https://api.slack.com/methods/admin.barriers.list""" kwargs.update( { "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.barriers.list", http_verb="GET", params=kwargs)
async def admin_barriers_update(self, *, barrier_id: str, barriered_from_usergroup_ids: Union[str, Sequence[str]], primary_usergroup_id: str, restricted_subjects: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Update an existing Information Barrier https://api.slack.com/methods/admin.barriers.update
Expand source code
async def admin_barriers_update( self, *, barrier_id: str, barriered_from_usergroup_ids: Union[str, Sequence[str]], primary_usergroup_id: str, restricted_subjects: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Update an existing Information Barrier https://api.slack.com/methods/admin.barriers.update """ kwargs.update({"barrier_id": barrier_id, "primary_usergroup_id": primary_usergroup_id}) if isinstance(barriered_from_usergroup_ids, (list, Tuple)): kwargs.update({"barriered_from_usergroup_ids": ",".join(barriered_from_usergroup_ids)}) else: kwargs.update({"barriered_from_usergroup_ids": barriered_from_usergroup_ids}) if isinstance(restricted_subjects, (list, Tuple)): kwargs.update({"restricted_subjects": ",".join(restricted_subjects)}) else: kwargs.update({"restricted_subjects": restricted_subjects}) return await self.api_call("admin.barriers.update", http_verb="POST", params=kwargs)
async def admin_conversations_archive(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Archive a public or private channel. https://api.slack.com/methods/admin.conversations.archive
Expand source code
async def admin_conversations_archive( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Archive a public or private channel. https://api.slack.com/methods/admin.conversations.archive """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.archive", params=kwargs)
async def admin_conversations_bulkArchive(self, *, channel_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Archive public or private channels in bulk. https://api.slack.com/methods/admin.conversations.bulkArchive
Expand source code
async def admin_conversations_bulkArchive( self, *, channel_ids: Union[Sequence[str], str], **kwargs, ) -> AsyncSlackResponse: """Archive public or private channels in bulk. https://api.slack.com/methods/admin.conversations.bulkArchive """ kwargs.update({"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids}) return await self.api_call("admin.conversations.bulkArchive", params=kwargs)
async def admin_conversations_bulkDelete(self, *, channel_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Delete public or private channels in bulk. https://slack.com/api/admin.conversations.bulkDelete
Expand source code
async def admin_conversations_bulkDelete( self, *, channel_ids: Union[Sequence[str], str], **kwargs, ) -> AsyncSlackResponse: """Delete public or private channels in bulk. https://slack.com/api/admin.conversations.bulkDelete """ kwargs.update({"channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids}) return await self.api_call("admin.conversations.bulkDelete", params=kwargs)
async def admin_conversations_bulkMove(self, *, channel_ids: Union[str, Sequence[str]], target_team_id: str, **kwargs) ‑> AsyncSlackResponse
-
Move public or private channels in bulk. https://api.slack.com/methods/admin.conversations.bulkMove
Expand source code
async def admin_conversations_bulkMove( self, *, channel_ids: Union[Sequence[str], str], target_team_id: str, **kwargs, ) -> AsyncSlackResponse: """Move public or private channels in bulk. https://api.slack.com/methods/admin.conversations.bulkMove """ kwargs.update( { "target_team_id": target_team_id, "channel_ids": ",".join(channel_ids) if isinstance(channel_ids, (list, tuple)) else channel_ids, } ) return await self.api_call("admin.conversations.bulkMove", params=kwargs)
async def admin_conversations_convertToPrivate(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Convert a public channel to a private channel. https://api.slack.com/methods/admin.conversations.convertToPrivate
Expand source code
async def admin_conversations_convertToPrivate( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Convert a public channel to a private channel. https://api.slack.com/methods/admin.conversations.convertToPrivate """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.convertToPrivate", params=kwargs)
async def admin_conversations_convertToPublic(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Convert a privte channel to a public channel. https://api.slack.com/methods/admin.conversations.convertToPublic
Expand source code
async def admin_conversations_convertToPublic( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Convert a privte channel to a public channel. https://api.slack.com/methods/admin.conversations.convertToPublic """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.convertToPublic", params=kwargs)
async def admin_conversations_create(self, *, is_private: bool, name: str, description: Optional[str] = None, org_wide: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Create a public or private channel-based conversation. https://api.slack.com/methods/admin.conversations.create
Expand source code
async def admin_conversations_create( self, *, is_private: bool, name: str, description: Optional[str] = None, org_wide: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Create a public or private channel-based conversation. https://api.slack.com/methods/admin.conversations.create """ kwargs.update( { "is_private": is_private, "name": name, "description": description, "org_wide": org_wide, "team_id": team_id, } ) return await self.api_call("admin.conversations.create", params=kwargs)
async def admin_conversations_delete(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Delete a public or private channel. https://api.slack.com/methods/admin.conversations.delete
Expand source code
async def admin_conversations_delete( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Delete a public or private channel. https://api.slack.com/methods/admin.conversations.delete """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.delete", params=kwargs)
-
Disconnect a connected channel from one or more workspaces. https://api.slack.com/methods/admin.conversations.disconnectShared
Expand source code
async def admin_conversations_disconnectShared( self, *, channel_id: str, leaving_team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Disconnect a connected channel from one or more workspaces. https://api.slack.com/methods/admin.conversations.disconnectShared """ kwargs.update({"channel_id": channel_id}) if isinstance(leaving_team_ids, (list, Tuple)): kwargs.update({"leaving_team_ids": ",".join(leaving_team_ids)}) else: kwargs.update({"leaving_team_ids": leaving_team_ids}) return await self.api_call("admin.conversations.disconnectShared", params=kwargs)
async def admin_conversations_ekm_listOriginalConnectedChannelInfo(self, *, channel_ids: Union[str, Sequence[str], ForwardRef(None)] = None, cursor: Optional[str] = None, limit: Optional[int] = None, team_ids: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
List all disconnected channels—i.e., channels that were once connected to other workspaces and then disconnected—and the corresponding original channel IDs for key revocation with EKM. https://api.slack.com/methods/admin.conversations.ekm.listOriginalConnectedChannelInfo
Expand source code
async def admin_conversations_ekm_listOriginalConnectedChannelInfo( self, *, channel_ids: Optional[Union[str, Sequence[str]]] = None, cursor: Optional[str] = None, limit: Optional[int] = None, team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """List all disconnected channels—i.e., channels that were once connected to other workspaces and then disconnected—and the corresponding original channel IDs for key revocation with EKM. https://api.slack.com/methods/admin.conversations.ekm.listOriginalConnectedChannelInfo """ kwargs.update( { "cursor": cursor, "limit": limit, } ) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.conversations.ekm.listOriginalConnectedChannelInfo", params=kwargs)
async def admin_conversations_getConversationPrefs(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Get conversation preferences for a public or private channel. https://api.slack.com/methods/admin.conversations.getConversationPrefs
Expand source code
async def admin_conversations_getConversationPrefs( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Get conversation preferences for a public or private channel. https://api.slack.com/methods/admin.conversations.getConversationPrefs """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.getConversationPrefs", params=kwargs)
async def admin_conversations_getCustomRetention(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Get a channel's retention policy https://api.slack.com/methods/admin.conversations.getCustomRetention
Expand source code
async def admin_conversations_getCustomRetention( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Get a channel's retention policy https://api.slack.com/methods/admin.conversations.getCustomRetention """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.getCustomRetention", params=kwargs)
async def admin_conversations_getTeams(self, *, channel_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Set the workspaces in an Enterprise grid org that connect to a channel. https://api.slack.com/methods/admin.conversations.getTeams
Expand source code
async def admin_conversations_getTeams( self, *, channel_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Set the workspaces in an Enterprise grid org that connect to a channel. https://api.slack.com/methods/admin.conversations.getTeams """ kwargs.update( { "channel_id": channel_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.conversations.getTeams", params=kwargs)
async def admin_conversations_invite(self, *, channel_id: str, user_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Invite a user to a public or private channel. https://api.slack.com/methods/admin.conversations.invite
Expand source code
async def admin_conversations_invite( self, *, channel_id: str, user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Invite a user to a public or private channel. https://api.slack.com/methods/admin.conversations.invite """ kwargs.update({"channel_id": channel_id}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) # NOTE: the endpoint is unable to handle Content-Type: application/json as of Sep 3, 2020. return await self.api_call("admin.conversations.invite", params=kwargs)
async def admin_conversations_lookup(self, *, last_message_activity_before: int, team_ids: Union[str, Sequence[str]], cursor: Optional[str] = None, limit: Optional[int] = None, max_member_count: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Returns channels on the given team using the filters. https://api.slack.com/methods/admin.conversations.lookup
Expand source code
async def admin_conversations_lookup( self, *, last_message_activity_before: int, team_ids: Union[str, Sequence[str]], cursor: Optional[str] = None, limit: Optional[int] = None, max_member_count: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Returns channels on the given team using the filters. https://api.slack.com/methods/admin.conversations.lookup """ kwargs.update( { "last_message_activity_before": last_message_activity_before, "cursor": cursor, "limit": limit, "max_member_count": max_member_count, } ) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.conversations.lookup", params=kwargs)
async def admin_conversations_removeCustomRetention(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Remove a channel's retention policy https://api.slack.com/methods/admin.conversations.removeCustomRetention
Expand source code
async def admin_conversations_removeCustomRetention( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove a channel's retention policy https://api.slack.com/methods/admin.conversations.removeCustomRetention """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.removeCustomRetention", params=kwargs)
async def admin_conversations_rename(self, *, channel_id: str, name: str, **kwargs) ‑> AsyncSlackResponse
-
Rename a public or private channel. https://api.slack.com/methods/admin.conversations.rename
Expand source code
async def admin_conversations_rename( self, *, channel_id: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Rename a public or private channel. https://api.slack.com/methods/admin.conversations.rename """ kwargs.update({"channel_id": channel_id, "name": name}) return await self.api_call("admin.conversations.rename", params=kwargs)
async def admin_conversations_restrictAccess_addGroup(self, *, channel_id: str, group_id: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Add an allowlist of IDP groups for accessing a channel. https://api.slack.com/methods/admin.conversations.restrictAccess.addGroup
Expand source code
async def admin_conversations_restrictAccess_addGroup( self, *, channel_id: str, group_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Add an allowlist of IDP groups for accessing a channel. https://api.slack.com/methods/admin.conversations.restrictAccess.addGroup """ kwargs.update( { "channel_id": channel_id, "group_id": group_id, "team_id": team_id, } ) return await self.api_call( "admin.conversations.restrictAccess.addGroup", http_verb="GET", params=kwargs, )
async def admin_conversations_restrictAccess_listGroups(self, *, channel_id: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List all IDP Groups linked to a channel. https://api.slack.com/methods/admin.conversations.restrictAccess.listGroups
Expand source code
async def admin_conversations_restrictAccess_listGroups( self, *, channel_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all IDP Groups linked to a channel. https://api.slack.com/methods/admin.conversations.restrictAccess.listGroups """ kwargs.update( { "channel_id": channel_id, "team_id": team_id, } ) return await self.api_call( "admin.conversations.restrictAccess.listGroups", http_verb="GET", params=kwargs, )
async def admin_conversations_restrictAccess_removeGroup(self, *, channel_id: str, group_id: str, team_id: str, **kwargs) ‑> AsyncSlackResponse
-
Remove a linked IDP group linked from a private channel. https://api.slack.com/methods/admin.conversations.restrictAccess.removeGroup
Expand source code
async def admin_conversations_restrictAccess_removeGroup( self, *, channel_id: str, group_id: str, team_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove a linked IDP group linked from a private channel. https://api.slack.com/methods/admin.conversations.restrictAccess.removeGroup """ kwargs.update( { "channel_id": channel_id, "group_id": group_id, "team_id": team_id, } ) return await self.api_call( "admin.conversations.restrictAccess.removeGroup", http_verb="GET", params=kwargs, )
async def admin_conversations_search(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, query: Optional[str] = None, search_channel_types: Union[str, Sequence[str], ForwardRef(None)] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_ids: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Search for public or private channels in an Enterprise organization. https://api.slack.com/methods/admin.conversations.search
Expand source code
async def admin_conversations_search( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, query: Optional[str] = None, search_channel_types: Optional[Union[str, Sequence[str]]] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Search for public or private channels in an Enterprise organization. https://api.slack.com/methods/admin.conversations.search """ kwargs.update( { "cursor": cursor, "limit": limit, "query": query, "sort": sort, "sort_dir": sort_dir, } ) if isinstance(search_channel_types, (list, Tuple)): kwargs.update({"search_channel_types": ",".join(search_channel_types)}) else: kwargs.update({"search_channel_types": search_channel_types}) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.conversations.search", params=kwargs)
async def admin_conversations_setConversationPrefs(self, *, channel_id: str, prefs: Union[str, Dict[str, str]], **kwargs) ‑> AsyncSlackResponse
-
Set the posting permissions for a public or private channel. https://api.slack.com/methods/admin.conversations.setConversationPrefs
Expand source code
async def admin_conversations_setConversationPrefs( self, *, channel_id: str, prefs: Union[str, Dict[str, str]], **kwargs, ) -> AsyncSlackResponse: """Set the posting permissions for a public or private channel. https://api.slack.com/methods/admin.conversations.setConversationPrefs """ kwargs.update({"channel_id": channel_id}) if isinstance(prefs, dict): kwargs.update({"prefs": json.dumps(prefs)}) else: kwargs.update({"prefs": prefs}) return await self.api_call("admin.conversations.setConversationPrefs", params=kwargs)
async def admin_conversations_setCustomRetention(self, *, channel_id: str, duration_days: int, **kwargs) ‑> AsyncSlackResponse
-
Set a channel's retention policy https://api.slack.com/methods/admin.conversations.setCustomRetention
Expand source code
async def admin_conversations_setCustomRetention( self, *, channel_id: str, duration_days: int, **kwargs, ) -> AsyncSlackResponse: """Set a channel's retention policy https://api.slack.com/methods/admin.conversations.setCustomRetention """ kwargs.update({"channel_id": channel_id, "duration_days": duration_days}) return await self.api_call("admin.conversations.setCustomRetention", params=kwargs)
async def admin_conversations_setTeams(self, *, channel_id: str, org_channel: Optional[bool] = None, target_team_ids: Union[str, Sequence[str], ForwardRef(None)] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Set the workspaces in an Enterprise grid org that connect to a public or private channel. https://api.slack.com/methods/admin.conversations.setTeams
Expand source code
async def admin_conversations_setTeams( self, *, channel_id: str, org_channel: Optional[bool] = None, target_team_ids: Optional[Union[str, Sequence[str]]] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Set the workspaces in an Enterprise grid org that connect to a public or private channel. https://api.slack.com/methods/admin.conversations.setTeams """ kwargs.update( { "channel_id": channel_id, "org_channel": org_channel, "team_id": team_id, } ) if isinstance(target_team_ids, (list, Tuple)): kwargs.update({"target_team_ids": ",".join(target_team_ids)}) else: kwargs.update({"target_team_ids": target_team_ids}) return await self.api_call("admin.conversations.setTeams", params=kwargs)
async def admin_conversations_unarchive(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Unarchive a public or private channel. https://api.slack.com/methods/admin.conversations.archive
Expand source code
async def admin_conversations_unarchive( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Unarchive a public or private channel. https://api.slack.com/methods/admin.conversations.archive """ kwargs.update({"channel_id": channel_id}) return await self.api_call("admin.conversations.unarchive", params=kwargs)
async def admin_emoji_add(self, *, name: str, url: str, **kwargs) ‑> AsyncSlackResponse
-
Add an emoji. https://api.slack.com/methods/admin.emoji.add
Expand source code
async def admin_emoji_add( self, *, name: str, url: str, **kwargs, ) -> AsyncSlackResponse: """Add an emoji. https://api.slack.com/methods/admin.emoji.add """ kwargs.update({"name": name, "url": url}) return await self.api_call("admin.emoji.add", http_verb="GET", params=kwargs)
async def admin_emoji_addAlias(self, *, alias_for: str, name: str, **kwargs) ‑> AsyncSlackResponse
-
Add an emoji alias. https://api.slack.com/methods/admin.emoji.addAlias
Expand source code
async def admin_emoji_addAlias( self, *, alias_for: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Add an emoji alias. https://api.slack.com/methods/admin.emoji.addAlias """ kwargs.update({"alias_for": alias_for, "name": name}) return await self.api_call("admin.emoji.addAlias", http_verb="GET", params=kwargs)
async def admin_emoji_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
List emoji for an Enterprise Grid organization. https://api.slack.com/methods/admin.emoji.list
Expand source code
async def admin_emoji_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List emoji for an Enterprise Grid organization. https://api.slack.com/methods/admin.emoji.list """ kwargs.update({"cursor": cursor, "limit": limit}) return await self.api_call("admin.emoji.list", http_verb="GET", params=kwargs)
async def admin_emoji_remove(self, *, name: str, **kwargs) ‑> AsyncSlackResponse
-
Remove an emoji across an Enterprise Grid organization. https://api.slack.com/methods/admin.emoji.remove
Expand source code
async def admin_emoji_remove( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Remove an emoji across an Enterprise Grid organization. https://api.slack.com/methods/admin.emoji.remove """ kwargs.update({"name": name}) return await self.api_call("admin.emoji.remove", http_verb="GET", params=kwargs)
async def admin_emoji_rename(self, *, name: str, new_name: str, **kwargs) ‑> AsyncSlackResponse
-
Rename an emoji. https://api.slack.com/methods/admin.emoji.rename
Expand source code
async def admin_emoji_rename( self, *, name: str, new_name: str, **kwargs, ) -> AsyncSlackResponse: """Rename an emoji. https://api.slack.com/methods/admin.emoji.rename """ kwargs.update({"name": name, "new_name": new_name}) return await self.api_call("admin.emoji.rename", http_verb="GET", params=kwargs)
async def admin_functions_list(self, *, app_ids: Union[str, Sequence[str]], team_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Look up functions by a set of apps https://api.slack.com/methods/admin.functions.list
Expand source code
async def admin_functions_list( self, *, app_ids: Union[str, Sequence[str]], team_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Look up functions by a set of apps https://api.slack.com/methods/admin.functions.list """ if isinstance(app_ids, (list, Tuple)): kwargs.update({"app_ids": ",".join(app_ids)}) else: kwargs.update({"app_ids": app_ids}) kwargs.update( { "team_id": team_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.functions.list", params=kwargs)
async def admin_functions_permissions_lookup(self, *, function_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Lookup the visibility of multiple Slack functions and include the users if it is limited to particular named entities. https://api.slack.com/methods/admin.functions.permissions.lookup
Expand source code
async def admin_functions_permissions_lookup( self, *, function_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Lookup the visibility of multiple Slack functions and include the users if it is limited to particular named entities. https://api.slack.com/methods/admin.functions.permissions.lookup """ if isinstance(function_ids, (list, Tuple)): kwargs.update({"function_ids": ",".join(function_ids)}) else: kwargs.update({"function_ids": function_ids}) return await self.api_call("admin.functions.permissions.lookup", params=kwargs)
async def admin_functions_permissions_set(self, *, function_id: str, visibility: str, user_ids: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Set the visibility of a Slack function and define the users or workspaces if it is set to named_entities https://api.slack.com/methods/admin.functions.permissions.set
Expand source code
async def admin_functions_permissions_set( self, *, function_id: str, visibility: str, user_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Set the visibility of a Slack function and define the users or workspaces if it is set to named_entities https://api.slack.com/methods/admin.functions.permissions.set """ kwargs.update( { "function_id": function_id, "visibility": visibility, } ) if user_ids is not None: if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.functions.permissions.set", params=kwargs)
async def admin_inviteRequests_approve(self, *, invite_request_id: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Approve a workspace invite request. https://api.slack.com/methods/admin.inviteRequests.approve
Expand source code
async def admin_inviteRequests_approve( self, *, invite_request_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Approve a workspace invite request. https://api.slack.com/methods/admin.inviteRequests.approve """ kwargs.update({"invite_request_id": invite_request_id, "team_id": team_id}) return await self.api_call("admin.inviteRequests.approve", params=kwargs)
async def admin_inviteRequests_approved_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List all approved workspace invite requests. https://api.slack.com/methods/admin.inviteRequests.approved.list
Expand source code
async def admin_inviteRequests_approved_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all approved workspace invite requests. https://api.slack.com/methods/admin.inviteRequests.approved.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.inviteRequests.approved.list", params=kwargs)
async def admin_inviteRequests_denied_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List all denied workspace invite requests. https://api.slack.com/methods/admin.inviteRequests.denied.list
Expand source code
async def admin_inviteRequests_denied_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all denied workspace invite requests. https://api.slack.com/methods/admin.inviteRequests.denied.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.inviteRequests.denied.list", params=kwargs)
async def admin_inviteRequests_deny(self, *, invite_request_id: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Deny a workspace invite request. https://api.slack.com/methods/admin.inviteRequests.deny
Expand source code
async def admin_inviteRequests_deny( self, *, invite_request_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Deny a workspace invite request. https://api.slack.com/methods/admin.inviteRequests.deny """ kwargs.update({"invite_request_id": invite_request_id, "team_id": team_id}) return await self.api_call("admin.inviteRequests.deny", params=kwargs)
async def admin_inviteRequests_list(self, **kwargs) ‑> AsyncSlackResponse
-
List all pending workspace invite requests.
Expand source code
async def admin_inviteRequests_list( self, **kwargs, ) -> AsyncSlackResponse: """List all pending workspace invite requests.""" return await self.api_call("admin.inviteRequests.list", params=kwargs)
async def admin_roles_addAssignments(self, *, role_id: str, entity_ids: Union[str, Sequence[str]], user_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Adds members to the specified role with the specified scopes https://api.slack.com/methods/admin.roles.addAssignments
Expand source code
async def admin_roles_addAssignments( self, *, role_id: str, entity_ids: Union[str, Sequence[str]], user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Adds members to the specified role with the specified scopes https://api.slack.com/methods/admin.roles.addAssignments """ kwargs.update({"role_id": role_id}) if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.roles.addAssignments", params=kwargs)
async def admin_roles_listAssignments(self, *, role_ids: Union[str, Sequence[str], ForwardRef(None)] = None, entity_ids: Union[str, Sequence[str], ForwardRef(None)] = None, cursor: Optional[str] = None, limit: Union[str, int, ForwardRef(None)] = None, sort_dir: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists assignments for all roles across entities. Options to scope results by any combination of roles or entities https://api.slack.com/methods/admin.roles.listAssignments
Expand source code
async def admin_roles_listAssignments( self, *, role_ids: Optional[Union[str, Sequence[str]]] = None, entity_ids: Optional[Union[str, Sequence[str]]] = None, cursor: Optional[str] = None, limit: Optional[Union[str, int]] = None, sort_dir: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists assignments for all roles across entities. Options to scope results by any combination of roles or entities https://api.slack.com/methods/admin.roles.listAssignments """ kwargs.update({"cursor": cursor, "limit": limit, "sort_dir": sort_dir}) if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) if isinstance(role_ids, (list, Tuple)): kwargs.update({"role_ids": ",".join(role_ids)}) else: kwargs.update({"role_ids": role_ids}) return await self.api_call("admin.roles.listAssignments", params=kwargs)
async def admin_roles_removeAssignments(self, *, role_id: str, entity_ids: Union[str, Sequence[str]], user_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Removes a set of users from a role for the given scopes and entities https://api.slack.com/methods/admin.roles.removeAssignments
Expand source code
async def admin_roles_removeAssignments( self, *, role_id: str, entity_ids: Union[str, Sequence[str]], user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Removes a set of users from a role for the given scopes and entities https://api.slack.com/methods/admin.roles.removeAssignments """ kwargs.update({"role_id": role_id}) if isinstance(entity_ids, (list, Tuple)): kwargs.update({"entity_ids": ",".join(entity_ids)}) else: kwargs.update({"entity_ids": entity_ids}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.roles.removeAssignments", params=kwargs)
async def admin_teams_admins_list(self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
List all of the admins on a given workspace. https://api.slack.com/methods/admin.inviteRequests.list
Expand source code
async def admin_teams_admins_list( self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List all of the admins on a given workspace. https://api.slack.com/methods/admin.inviteRequests.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, } ) return await self.api_call("admin.teams.admins.list", http_verb="GET", params=kwargs)
async def admin_teams_create(self, *, team_domain: str, team_name: str, team_description: Optional[str] = None, team_discoverability: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Create an Enterprise team. https://api.slack.com/methods/admin.teams.create
Expand source code
async def admin_teams_create( self, *, team_domain: str, team_name: str, team_description: Optional[str] = None, team_discoverability: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Create an Enterprise team. https://api.slack.com/methods/admin.teams.create """ kwargs.update( { "team_domain": team_domain, "team_name": team_name, "team_description": team_description, "team_discoverability": team_discoverability, } ) return await self.api_call("admin.teams.create", params=kwargs)
async def admin_teams_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
List all teams on an Enterprise organization. https://api.slack.com/methods/admin.teams.list
Expand source code
async def admin_teams_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List all teams on an Enterprise organization. https://api.slack.com/methods/admin.teams.list """ kwargs.update({"cursor": cursor, "limit": limit}) return await self.api_call("admin.teams.list", params=kwargs)
async def admin_teams_owners_list(self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
List all of the admins on a given workspace. https://api.slack.com/methods/admin.teams.owners.list
Expand source code
async def admin_teams_owners_list( self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List all of the admins on a given workspace. https://api.slack.com/methods/admin.teams.owners.list """ kwargs.update({"team_id": team_id, "cursor": cursor, "limit": limit}) return await self.api_call("admin.teams.owners.list", http_verb="GET", params=kwargs)
async def admin_teams_settings_info(self, *, team_id: str, **kwargs) ‑> AsyncSlackResponse
-
Fetch information about settings in a workspace https://api.slack.com/methods/admin.teams.settings.info
Expand source code
async def admin_teams_settings_info( self, *, team_id: str, **kwargs, ) -> AsyncSlackResponse: """Fetch information about settings in a workspace https://api.slack.com/methods/admin.teams.settings.info """ kwargs.update({"team_id": team_id}) return await self.api_call("admin.teams.settings.info", params=kwargs)
async def admin_teams_settings_setDefaultChannels(self, *, team_id: str, channel_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Set the default channels of a workspace. https://api.slack.com/methods/admin.teams.settings.setDefaultChannels
Expand source code
async def admin_teams_settings_setDefaultChannels( self, *, team_id: str, channel_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Set the default channels of a workspace. https://api.slack.com/methods/admin.teams.settings.setDefaultChannels """ kwargs.update({"team_id": team_id}) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.teams.settings.setDefaultChannels", http_verb="GET", params=kwargs)
async def admin_teams_settings_setDescription(self, *, team_id: str, description: str, **kwargs) ‑> AsyncSlackResponse
-
Set the description of a given workspace. https://api.slack.com/methods/admin.teams.settings.setDescription
Expand source code
async def admin_teams_settings_setDescription( self, *, team_id: str, description: str, **kwargs, ) -> AsyncSlackResponse: """Set the description of a given workspace. https://api.slack.com/methods/admin.teams.settings.setDescription """ kwargs.update({"team_id": team_id, "description": description}) return await self.api_call("admin.teams.settings.setDescription", params=kwargs)
async def admin_teams_settings_setDiscoverability(self, *, team_id: str, discoverability: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setDiscoverability
Expand source code
async def admin_teams_settings_setDiscoverability( self, *, team_id: str, discoverability: str, **kwargs, ) -> AsyncSlackResponse: """Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setDiscoverability """ kwargs.update({"team_id": team_id, "discoverability": discoverability}) return await self.api_call("admin.teams.settings.setDiscoverability", params=kwargs)
async def admin_teams_settings_setIcon(self, *, team_id: str, image_url: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setIcon
Expand source code
async def admin_teams_settings_setIcon( self, *, team_id: str, image_url: str, **kwargs, ) -> AsyncSlackResponse: """Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setIcon """ kwargs.update({"team_id": team_id, "image_url": image_url}) return await self.api_call("admin.teams.settings.setIcon", http_verb="GET", params=kwargs)
async def admin_teams_settings_setName(self, *, team_id: str, name: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setName
Expand source code
async def admin_teams_settings_setName( self, *, team_id: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Sets the icon of a workspace. https://api.slack.com/methods/admin.teams.settings.setName """ kwargs.update({"team_id": team_id, "name": name}) return await self.api_call("admin.teams.settings.setName", params=kwargs)
async def admin_usergroups_addChannels(self, *, channel_ids: Union[str, Sequence[str]], usergroup_id: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.addChannels
Expand source code
async def admin_usergroups_addChannels( self, *, channel_ids: Union[str, Sequence[str]], usergroup_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.addChannels """ kwargs.update({"team_id": team_id, "usergroup_id": usergroup_id}) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.usergroups.addChannels", params=kwargs)
async def admin_usergroups_addTeams(self, *, usergroup_id: str, team_ids: Union[str, Sequence[str]], auto_provision: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Associate one or more default workspaces with an organization-wide IDP group. https://api.slack.com/methods/admin.usergroups.addTeams
Expand source code
async def admin_usergroups_addTeams( self, *, usergroup_id: str, team_ids: Union[str, Sequence[str]], auto_provision: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Associate one or more default workspaces with an organization-wide IDP group. https://api.slack.com/methods/admin.usergroups.addTeams """ kwargs.update({"usergroup_id": usergroup_id, "auto_provision": auto_provision}) if isinstance(team_ids, (list, Tuple)): kwargs.update({"team_ids": ",".join(team_ids)}) else: kwargs.update({"team_ids": team_ids}) return await self.api_call("admin.usergroups.addTeams", params=kwargs)
async def admin_usergroups_listChannels(self, *, usergroup_id: str, include_num_members: Optional[bool] = None, team_id: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.listChannels
Expand source code
async def admin_usergroups_listChannels( self, *, usergroup_id: str, include_num_members: Optional[bool] = None, team_id: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.listChannels """ kwargs.update( { "usergroup_id": usergroup_id, "include_num_members": include_num_members, "team_id": team_id, } ) return await self.api_call("admin.usergroups.listChannels", params=kwargs)
async def admin_usergroups_removeChannels(self, *, usergroup_id: str, channel_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.removeChannels
Expand source code
async def admin_usergroups_removeChannels( self, *, usergroup_id: str, channel_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Add one or more default channels to an IDP group. https://api.slack.com/methods/admin.usergroups.removeChannels """ kwargs.update({"usergroup_id": usergroup_id}) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.usergroups.removeChannels", params=kwargs)
async def admin_users_assign(self, *, team_id: str, user_id: str, channel_ids: Union[str, Sequence[str], ForwardRef(None)] = None, is_restricted: Optional[bool] = None, is_ultra_restricted: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Add an Enterprise user to a workspace. https://api.slack.com/methods/admin.users.assign
Expand source code
async def admin_users_assign( self, *, team_id: str, user_id: str, channel_ids: Optional[Union[str, Sequence[str]]] = None, is_restricted: Optional[bool] = None, is_ultra_restricted: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Add an Enterprise user to a workspace. https://api.slack.com/methods/admin.users.assign """ kwargs.update( { "team_id": team_id, "user_id": user_id, "is_restricted": is_restricted, "is_ultra_restricted": is_ultra_restricted, } ) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.users.assign", params=kwargs)
async def admin_users_invite(self, *, team_id: str, email: str, channel_ids: Union[str, Sequence[str]], custom_message: Optional[str] = None, email_password_policy_enabled: Optional[bool] = None, guest_expiration_ts: Union[str, float, ForwardRef(None)] = None, is_restricted: Optional[bool] = None, is_ultra_restricted: Optional[bool] = None, real_name: Optional[str] = None, resend: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Invite a user to a workspace. https://api.slack.com/methods/admin.users.invite
Expand source code
async def admin_users_invite( self, *, team_id: str, email: str, channel_ids: Union[str, Sequence[str]], custom_message: Optional[str] = None, email_password_policy_enabled: Optional[bool] = None, guest_expiration_ts: Optional[Union[str, float]] = None, is_restricted: Optional[bool] = None, is_ultra_restricted: Optional[bool] = None, real_name: Optional[str] = None, resend: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Invite a user to a workspace. https://api.slack.com/methods/admin.users.invite """ kwargs.update( { "team_id": team_id, "email": email, "custom_message": custom_message, "email_password_policy_enabled": email_password_policy_enabled, "guest_expiration_ts": str(guest_expiration_ts) if guest_expiration_ts is not None else None, "is_restricted": is_restricted, "is_ultra_restricted": is_ultra_restricted, "real_name": real_name, "resend": resend, } ) if isinstance(channel_ids, (list, Tuple)): kwargs.update({"channel_ids": ",".join(channel_ids)}) else: kwargs.update({"channel_ids": channel_ids}) return await self.api_call("admin.users.invite", params=kwargs)
async def admin_users_list(self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
List users on a workspace https://api.slack.com/methods/admin.users.list
Expand source code
async def admin_users_list( self, *, team_id: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """List users on a workspace https://api.slack.com/methods/admin.users.list """ kwargs.update( { "team_id": team_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("admin.users.list", params=kwargs)
async def admin_users_remove(self, *, team_id: str, user_id: str, **kwargs) ‑> AsyncSlackResponse
-
Remove a user from a workspace. https://api.slack.com/methods/admin.users.remove
Expand source code
async def admin_users_remove( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove a user from a workspace. https://api.slack.com/methods/admin.users.remove """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.remove", params=kwargs)
async def admin_users_session_clearSettings(self, *, user_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Clear user-specific session settings—the session duration and what happens when the client closes—for a list of users. https://api.slack.com/methods/admin.users.session.clearSettings
Expand source code
async def admin_users_session_clearSettings( self, *, user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Clear user-specific session settings—the session duration and what happens when the client closes—for a list of users. https://api.slack.com/methods/admin.users.session.clearSettings """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.users.session.clearSettings", params=kwargs)
async def admin_users_session_getSettings(self, *, user_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Get user-specific session settings—the session duration and what happens when the client closes—given a list of users. https://api.slack.com/methods/admin.users.session.getSettings
Expand source code
async def admin_users_session_getSettings( self, *, user_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Get user-specific session settings—the session duration and what happens when the client closes—given a list of users. https://api.slack.com/methods/admin.users.session.getSettings """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("admin.users.session.getSettings", params=kwargs)
async def admin_users_session_invalidate(self, *, session_id: str, team_id: str, **kwargs) ‑> AsyncSlackResponse
-
Invalidate a single session for a user by session_id. https://api.slack.com/methods/admin.users.session.invalidate
Expand source code
async def admin_users_session_invalidate( self, *, session_id: str, team_id: str, **kwargs, ) -> AsyncSlackResponse: """Invalidate a single session for a user by session_id. https://api.slack.com/methods/admin.users.session.invalidate """ kwargs.update({"session_id": session_id, "team_id": team_id}) return await self.api_call("admin.users.session.invalidate", params=kwargs)
async def admin_users_session_list(self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, user_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists all active user sessions for an organization https://api.slack.com/methods/admin.users.session.list
Expand source code
async def admin_users_session_list( self, *, cursor: Optional[str] = None, limit: Optional[int] = None, team_id: Optional[str] = None, user_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all active user sessions for an organization https://api.slack.com/methods/admin.users.session.list """ kwargs.update( { "cursor": cursor, "limit": limit, "team_id": team_id, "user_id": user_id, } ) return await self.api_call("admin.users.session.list", params=kwargs)
async def admin_users_session_reset(self, *, user_id: str, mobile_only: Optional[bool] = None, web_only: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Wipes all valid sessions on all devices for a given user. https://api.slack.com/methods/admin.users.session.reset
Expand source code
async def admin_users_session_reset( self, *, user_id: str, mobile_only: Optional[bool] = None, web_only: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Wipes all valid sessions on all devices for a given user. https://api.slack.com/methods/admin.users.session.reset """ kwargs.update( { "user_id": user_id, "mobile_only": mobile_only, "web_only": web_only, } ) return await self.api_call("admin.users.session.reset", params=kwargs)
async def admin_users_session_resetBulk(self, *, user_ids: Union[str, Sequence[str]], mobile_only: Optional[bool] = None, web_only: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Enqueues an asynchronous job to wipe all valid sessions on all devices for a given list of users https://api.slack.com/methods/admin.users.session.resetBulk
Expand source code
async def admin_users_session_resetBulk( self, *, user_ids: Union[str, Sequence[str]], mobile_only: Optional[bool] = None, web_only: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Enqueues an asynchronous job to wipe all valid sessions on all devices for a given list of users https://api.slack.com/methods/admin.users.session.resetBulk """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) kwargs.update( { "mobile_only": mobile_only, "web_only": web_only, } ) return await self.api_call("admin.users.session.resetBulk", params=kwargs)
async def admin_users_session_setSettings(self, *, user_ids: Union[str, Sequence[str]], desktop_app_browser_quit: Optional[bool] = None, duration: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Configure the user-level session settings—the session duration and what happens when the client closes—for one or more users. https://api.slack.com/methods/admin.users.session.setSettings
Expand source code
async def admin_users_session_setSettings( self, *, user_ids: Union[str, Sequence[str]], desktop_app_browser_quit: Optional[bool] = None, duration: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Configure the user-level session settings—the session duration and what happens when the client closes—for one or more users. https://api.slack.com/methods/admin.users.session.setSettings """ if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) kwargs.update( { "desktop_app_browser_quit": desktop_app_browser_quit, "duration": duration, } ) return await self.api_call("admin.users.session.setSettings", params=kwargs)
async def admin_users_setAdmin(self, *, team_id: str, user_id: str, **kwargs) ‑> AsyncSlackResponse
-
Set an existing guest, regular user, or owner to be an admin user. https://api.slack.com/methods/admin.users.setAdmin
Expand source code
async def admin_users_setAdmin( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Set an existing guest, regular user, or owner to be an admin user. https://api.slack.com/methods/admin.users.setAdmin """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setAdmin", params=kwargs)
async def admin_users_setExpiration(self, *, expiration_ts: int, user_id: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Set an expiration for a guest user. https://api.slack.com/methods/admin.users.setExpiration
Expand source code
async def admin_users_setExpiration( self, *, expiration_ts: int, user_id: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Set an expiration for a guest user. https://api.slack.com/methods/admin.users.setExpiration """ kwargs.update({"expiration_ts": expiration_ts, "team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setExpiration", params=kwargs)
async def admin_users_setOwner(self, *, team_id: str, user_id: str, **kwargs) ‑> AsyncSlackResponse
-
Set an existing guest, regular user, or admin user to be a workspace owner. https://api.slack.com/methods/admin.users.setOwner
Expand source code
async def admin_users_setOwner( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Set an existing guest, regular user, or admin user to be a workspace owner. https://api.slack.com/methods/admin.users.setOwner """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setOwner", params=kwargs)
async def admin_users_setRegular(self, *, team_id: str, user_id: str, **kwargs) ‑> AsyncSlackResponse
-
Set an existing guest user, admin user, or owner to be a regular user. https://api.slack.com/methods/admin.users.setRegular
Expand source code
async def admin_users_setRegular( self, *, team_id: str, user_id: str, **kwargs, ) -> AsyncSlackResponse: """Set an existing guest user, admin user, or owner to be a regular user. https://api.slack.com/methods/admin.users.setRegular """ kwargs.update({"team_id": team_id, "user_id": user_id}) return await self.api_call("admin.users.setRegular", params=kwargs)
async def admin_users_unsupportedVersions_export(self, *, date_end_of_support: Union[str, int, ForwardRef(None)] = None, date_sessions_started: Union[str, int, ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Ask Slackbot to send you an export listing all workspace members using unsupported software, presented as a zipped CSV file. https://api.slack.com/methods/admin.users.unsupportedVersions.export
Expand source code
async def admin_users_unsupportedVersions_export( self, *, date_end_of_support: Optional[Union[str, int]] = None, date_sessions_started: Optional[Union[str, int]] = None, **kwargs, ) -> AsyncSlackResponse: """Ask Slackbot to send you an export listing all workspace members using unsupported software, presented as a zipped CSV file. https://api.slack.com/methods/admin.users.unsupportedVersions.export """ kwargs.update( { "date_end_of_support": date_end_of_support, "date_sessions_started": date_sessions_started, } ) return await self.api_call("admin.users.unsupportedVersions.export", params=kwargs)
async def admin_workflows_collaborators_add(self, *, collaborator_ids: Union[str, Sequence[str]], workflow_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Add collaborators to workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.collaborators.add
Expand source code
async def admin_workflows_collaborators_add( self, *, collaborator_ids: Union[str, Sequence[str]], workflow_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Add collaborators to workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.collaborators.add """ if isinstance(collaborator_ids, (list, Tuple)): kwargs.update({"collaborator_ids": ",".join(collaborator_ids)}) else: kwargs.update({"collaborator_ids": collaborator_ids}) if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) return await self.api_call("admin.workflows.collaborators.add", params=kwargs)
async def admin_workflows_collaborators_remove(self, *, collaborator_ids: Union[str, Sequence[str]], workflow_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Remove collaborators from workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.collaborators.remove
Expand source code
async def admin_workflows_collaborators_remove( self, *, collaborator_ids: Union[str, Sequence[str]], workflow_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Remove collaborators from workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.collaborators.remove """ if isinstance(collaborator_ids, (list, Tuple)): kwargs.update({"collaborator_ids": ",".join(collaborator_ids)}) else: kwargs.update({"collaborator_ids": collaborator_ids}) if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) return await self.api_call("admin.workflows.collaborators.remove", params=kwargs)
async def admin_workflows_permissions_lookup(self, *, workflow_ids: Union[str, Sequence[str]], max_workflow_triggers: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Look up the permissions for a set of workflows https://api.slack.com/methods/admin.workflows.permissions.lookup
Expand source code
async def admin_workflows_permissions_lookup( self, *, workflow_ids: Union[str, Sequence[str]], max_workflow_triggers: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Look up the permissions for a set of workflows https://api.slack.com/methods/admin.workflows.permissions.lookup """ if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) kwargs.update( { "max_workflow_triggers": max_workflow_triggers, } ) return await self.api_call("admin.workflows.permissions.lookup", params=kwargs)
async def admin_workflows_search(self, *, app_id: Optional[str] = None, collaborator_ids: Union[str, Sequence[str], ForwardRef(None)] = None, cursor: Optional[str] = None, limit: Optional[int] = None, no_collaborators: Optional[bool] = None, num_trigger_ids: Optional[int] = None, query: Optional[str] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, source: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Search workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.search
Expand source code
async def admin_workflows_search( self, *, app_id: Optional[str] = None, collaborator_ids: Optional[Union[str, Sequence[str]]] = None, cursor: Optional[str] = None, limit: Optional[int] = None, no_collaborators: Optional[bool] = None, num_trigger_ids: Optional[int] = None, query: Optional[str] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, source: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Search workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.search """ if collaborator_ids is not None: if isinstance(collaborator_ids, (list, Tuple)): kwargs.update({"collaborator_ids": ",".join(collaborator_ids)}) else: kwargs.update({"collaborator_ids": collaborator_ids}) kwargs.update( { "app_id": app_id, "cursor": cursor, "limit": limit, "no_collaborators": no_collaborators, "num_trigger_ids": num_trigger_ids, "query": query, "sort": sort, "sort_dir": sort_dir, "source": source, } ) return await self.api_call("admin.workflows.search", params=kwargs)
async def admin_workflows_unpublish(self, *, workflow_ids: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Unpublish workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.unpublish
Expand source code
async def admin_workflows_unpublish( self, *, workflow_ids: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Unpublish workflows within the team or enterprise https://api.slack.com/methods/admin.workflows.unpublish """ if isinstance(workflow_ids, (list, Tuple)): kwargs.update({"workflow_ids": ",".join(workflow_ids)}) else: kwargs.update({"workflow_ids": workflow_ids}) return await self.api_call("admin.workflows.unpublish", params=kwargs)
async def api_test(self, *, error: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Checks API calling code. https://api.slack.com/methods/api.test
Expand source code
async def api_test( self, *, error: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Checks API calling code. https://api.slack.com/methods/api.test """ kwargs.update({"error": error}) return await self.api_call("api.test", params=kwargs)
async def apps_connections_open(self, *, app_token: str, **kwargs) ‑> AsyncSlackResponse
-
Generate a temporary Socket Mode WebSocket URL that your app can connect to in order to receive events and interactive payloads https://api.slack.com/methods/apps.connections.open
Expand source code
async def apps_connections_open( self, *, app_token: str, **kwargs, ) -> AsyncSlackResponse: """Generate a temporary Socket Mode WebSocket URL that your app can connect to in order to receive events and interactive payloads https://api.slack.com/methods/apps.connections.open """ kwargs.update({"token": app_token}) return await self.api_call("apps.connections.open", http_verb="POST", params=kwargs)
-
Get a list of authorizations for the given event context. Each authorization represents an app installation that the event is visible to. https://api.slack.com/methods/apps.event.authorizations.list
Expand source code
async def apps_event_authorizations_list( self, *, event_context: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Get a list of authorizations for the given event context. Each authorization represents an app installation that the event is visible to. https://api.slack.com/methods/apps.event.authorizations.list """ kwargs.update({"event_context": event_context, "cursor": cursor, "limit": limit}) return await self.api_call("apps.event.authorizations.list", params=kwargs)
async def apps_uninstall(self, *, client_id: str, client_secret: str, **kwargs) ‑> AsyncSlackResponse
-
Uninstalls your app from a workspace. https://api.slack.com/methods/apps.uninstall
Expand source code
async def apps_uninstall( self, *, client_id: str, client_secret: str, **kwargs, ) -> AsyncSlackResponse: """Uninstalls your app from a workspace. https://api.slack.com/methods/apps.uninstall """ kwargs.update({"client_id": client_id, "client_secret": client_secret}) return await self.api_call("apps.uninstall", params=kwargs)
async def auth_revoke(self, *, test: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Revokes a token. https://api.slack.com/methods/auth.revoke
Expand source code
async def auth_revoke( self, *, test: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Revokes a token. https://api.slack.com/methods/auth.revoke """ kwargs.update({"test": test}) return await self.api_call("auth.revoke", http_verb="GET", params=kwargs)
async def auth_teams_list(self, cursor: Optional[str] = None, limit: Optional[int] = None, include_icon: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
List the workspaces a token can access. https://api.slack.com/methods/auth.teams.list
Expand source code
async def auth_teams_list( self, cursor: Optional[str] = None, limit: Optional[int] = None, include_icon: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """List the workspaces a token can access. https://api.slack.com/methods/auth.teams.list """ kwargs.update({"cursor": cursor, "limit": limit, "include_icon": include_icon}) return await self.api_call("auth.teams.list", params=kwargs)
async def auth_test(self, **kwargs) ‑> AsyncSlackResponse
-
Checks authentication & identity. https://api.slack.com/methods/auth.test
Expand source code
async def auth_test( self, **kwargs, ) -> AsyncSlackResponse: """Checks authentication & identity. https://api.slack.com/methods/auth.test """ return await self.api_call("auth.test", params=kwargs)
async def bookmarks_add(self, *, channel_id: str, title: str, type: str, emoji: Optional[str] = None, entity_id: Optional[str] = None, link: Optional[str] = None, parent_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Add bookmark to a channel. https://api.slack.com/methods/bookmarks.add
Expand source code
async def bookmarks_add( self, *, channel_id: str, title: str, type: str, emoji: Optional[str] = None, entity_id: Optional[str] = None, link: Optional[str] = None, # include when type is 'link' parent_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Add bookmark to a channel. https://api.slack.com/methods/bookmarks.add """ kwargs.update( { "channel_id": channel_id, "title": title, "type": type, "emoji": emoji, "entity_id": entity_id, "link": link, "parent_id": parent_id, } ) return await self.api_call("bookmarks.add", http_verb="POST", params=kwargs)
async def bookmarks_edit(self, *, bookmark_id: str, channel_id: str, emoji: Optional[str] = None, link: Optional[str] = None, title: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Edit bookmark. https://api.slack.com/methods/bookmarks.edit
Expand source code
async def bookmarks_edit( self, *, bookmark_id: str, channel_id: str, emoji: Optional[str] = None, link: Optional[str] = None, title: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Edit bookmark. https://api.slack.com/methods/bookmarks.edit """ kwargs.update( { "bookmark_id": bookmark_id, "channel_id": channel_id, "emoji": emoji, "link": link, "title": title, } ) return await self.api_call("bookmarks.edit", http_verb="POST", params=kwargs)
async def bookmarks_list(self, *, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
List bookmark for the channel. https://api.slack.com/methods/bookmarks.list
Expand source code
async def bookmarks_list( self, *, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """List bookmark for the channel. https://api.slack.com/methods/bookmarks.list """ kwargs.update({"channel_id": channel_id}) return await self.api_call("bookmarks.list", http_verb="POST", params=kwargs)
async def bookmarks_remove(self, *, bookmark_id: str, channel_id: str, **kwargs) ‑> AsyncSlackResponse
-
Remove bookmark from the channel. https://api.slack.com/methods/bookmarks.remove
Expand source code
async def bookmarks_remove( self, *, bookmark_id: str, channel_id: str, **kwargs, ) -> AsyncSlackResponse: """Remove bookmark from the channel. https://api.slack.com/methods/bookmarks.remove """ kwargs.update({"bookmark_id": bookmark_id, "channel_id": channel_id}) return await self.api_call("bookmarks.remove", http_verb="POST", params=kwargs)
async def bots_info(self, *, bot: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets information about a bot user. https://api.slack.com/methods/bots.info
Expand source code
async def bots_info( self, *, bot: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a bot user. https://api.slack.com/methods/bots.info """ kwargs.update({"bot": bot, "team_id": team_id}) return await self.api_call("bots.info", http_verb="GET", params=kwargs)
async def calls_add(self, *, external_unique_id: str, join_url: str, created_by: Optional[str] = None, date_start: Optional[int] = None, desktop_app_join_url: Optional[str] = None, external_display_id: Optional[str] = None, title: Optional[str] = None, users: Union[str, Sequence[Dict[str, str]], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Registers a new Call. https://api.slack.com/methods/calls.add
Expand source code
async def calls_add( self, *, external_unique_id: str, join_url: str, created_by: Optional[str] = None, date_start: Optional[int] = None, desktop_app_join_url: Optional[str] = None, external_display_id: Optional[str] = None, title: Optional[str] = None, users: Optional[Union[str, Sequence[Dict[str, str]]]] = None, **kwargs, ) -> AsyncSlackResponse: """Registers a new Call. https://api.slack.com/methods/calls.add """ kwargs.update( { "external_unique_id": external_unique_id, "join_url": join_url, "created_by": created_by, "date_start": date_start, "desktop_app_join_url": desktop_app_join_url, "external_display_id": external_display_id, "title": title, } ) _update_call_participants( # skipcq: PTC-W0039 kwargs, users if users is not None else kwargs.get("users"), # skipcq: PTC-W0039 ) # skipcq: PTC-W0039 return await self.api_call("calls.add", http_verb="POST", params=kwargs)
async def calls_end(self, *, id: str, duration: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Ends a Call. https://api.slack.com/methods/calls.end
Expand source code
async def calls_end( self, *, id: str, duration: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: # skipcq: PYL-W0622 """Ends a Call. https://api.slack.com/methods/calls.end """ kwargs.update({"id": id, "duration": duration}) return await self.api_call("calls.end", http_verb="POST", params=kwargs)
async def calls_info(self, *, id: str, **kwargs) ‑> AsyncSlackResponse
-
Returns information about a Call. https://api.slack.com/methods/calls.info
Expand source code
async def calls_info( self, *, id: str, **kwargs, ) -> AsyncSlackResponse: # skipcq: PYL-W0622 """Returns information about a Call. https://api.slack.com/methods/calls.info """ kwargs.update({"id": id}) return await self.api_call("calls.info", http_verb="POST", params=kwargs)
async def calls_participants_add(self, *, id: str, users: Union[str, Sequence[Dict[str, str]]], **kwargs) ‑> AsyncSlackResponse
-
Registers new participants added to a Call. https://api.slack.com/methods/calls.participants.add
Expand source code
async def calls_participants_add( self, *, id: str, # skipcq: PYL-W0622 users: Union[str, Sequence[Dict[str, str]]], **kwargs, ) -> AsyncSlackResponse: """Registers new participants added to a Call. https://api.slack.com/methods/calls.participants.add """ kwargs.update({"id": id}) _update_call_participants(kwargs, users) return await self.api_call("calls.participants.add", http_verb="POST", params=kwargs)
async def calls_participants_remove(self, *, id: str, users: Union[str, Sequence[Dict[str, str]]], **kwargs) ‑> AsyncSlackResponse
-
Registers participants removed from a Call. https://api.slack.com/methods/calls.participants.remove
Expand source code
async def calls_participants_remove( self, *, id: str, # skipcq: PYL-W0622 users: Union[str, Sequence[Dict[str, str]]], **kwargs, ) -> AsyncSlackResponse: """Registers participants removed from a Call. https://api.slack.com/methods/calls.participants.remove """ kwargs.update({"id": id}) _update_call_participants(kwargs, users) return await self.api_call("calls.participants.remove", http_verb="POST", params=kwargs)
async def calls_update(self, *, id: str, desktop_app_join_url: Optional[str] = None, join_url: Optional[str] = None, title: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Updates information about a Call. https://api.slack.com/methods/calls.update
Expand source code
async def calls_update( self, *, id: str, desktop_app_join_url: Optional[str] = None, join_url: Optional[str] = None, title: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: # skipcq: PYL-W0622 """Updates information about a Call. https://api.slack.com/methods/calls.update """ kwargs.update( { "id": id, "desktop_app_join_url": desktop_app_join_url, "join_url": join_url, "title": title, } ) return await self.api_call("calls.update", http_verb="POST", params=kwargs)
async def channels_archive(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Archives a channel.
Expand source code
async def channels_archive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Archives a channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.archive", json=kwargs)
async def channels_create(self, *, name: str, **kwargs) ‑> AsyncSlackResponse
-
Creates a channel.
Expand source code
async def channels_create( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Creates a channel.""" kwargs.update({"name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.create", json=kwargs)
async def channels_history(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Fetches history of messages and events from a channel.
Expand source code
async def channels_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from a channel.""" kwargs.update({"channel": channel}) return await self.api_call("channels.history", http_verb="GET", params=kwargs)
async def channels_info(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Gets information about a channel.
Expand source code
async def channels_info( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Gets information about a channel.""" kwargs.update({"channel": channel}) return await self.api_call("channels.info", http_verb="GET", params=kwargs)
async def channels_invite(self, *, channel: str, user: str, **kwargs) ‑> AsyncSlackResponse
-
Invites a user to a channel.
Expand source code
async def channels_invite( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Invites a user to a channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.invite", json=kwargs)
async def channels_join(self, *, name: str, **kwargs) ‑> AsyncSlackResponse
-
Joins a channel, creating it if needed.
Expand source code
async def channels_join( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Joins a channel, creating it if needed.""" kwargs.update({"name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.join", json=kwargs)
async def channels_kick(self, *, channel: str, user: str, **kwargs) ‑> AsyncSlackResponse
-
Removes a user from a channel.
Expand source code
async def channels_kick( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Removes a user from a channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.kick", json=kwargs)
async def channels_leave(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Leaves a channel.
Expand source code
async def channels_leave( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Leaves a channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.leave", json=kwargs)
async def channels_list(self, **kwargs) ‑> AsyncSlackResponse
-
Lists all channels in a Slack team.
Expand source code
async def channels_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists all channels in a Slack team.""" return await self.api_call("channels.list", http_verb="GET", params=kwargs)
async def channels_mark(self, *, channel: str, ts: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the read cursor in a channel.
Expand source code
async def channels_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.mark", json=kwargs)
async def channels_rename(self, *, channel: str, name: str, **kwargs) ‑> AsyncSlackResponse
-
Renames a channel.
Expand source code
async def channels_rename( self, *, channel: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Renames a channel.""" kwargs.update({"channel": channel, "name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.rename", json=kwargs)
async def channels_replies(self, *, channel: str, thread_ts: str, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a thread of messages posted to a channel
Expand source code
async def channels_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a channel""" kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("channels.replies", http_verb="GET", params=kwargs)
async def channels_setPurpose(self, *, channel: str, purpose: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the purpose for a channel.
Expand source code
async def channels_setPurpose( self, *, channel: str, purpose: str, **kwargs, ) -> AsyncSlackResponse: """Sets the purpose for a channel.""" kwargs.update({"channel": channel, "purpose": purpose}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.setPurpose", json=kwargs)
async def channels_setTopic(self, *, channel: str, topic: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the topic for a channel.
Expand source code
async def channels_setTopic( self, *, channel: str, topic: str, **kwargs, ) -> AsyncSlackResponse: """Sets the topic for a channel.""" kwargs.update({"channel": channel, "topic": topic}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.setTopic", json=kwargs)
async def channels_unarchive(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Unarchives a channel.
Expand source code
async def channels_unarchive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Unarchives a channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("channels.unarchive", json=kwargs)
async def chat_delete(self, *, channel: str, ts: str, as_user: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Deletes a message. https://api.slack.com/methods/chat.delete
Expand source code
async def chat_delete( self, *, channel: str, ts: str, as_user: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Deletes a message. https://api.slack.com/methods/chat.delete """ kwargs.update({"channel": channel, "ts": ts, "as_user": as_user}) return await self.api_call("chat.delete", params=kwargs)
async def chat_deleteScheduledMessage(self, *, channel: str, scheduled_message_id: str, as_user: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Deletes a scheduled message. https://api.slack.com/methods/chat.deleteScheduledMessage
Expand source code
async def chat_deleteScheduledMessage( self, *, channel: str, scheduled_message_id: str, as_user: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Deletes a scheduled message. https://api.slack.com/methods/chat.deleteScheduledMessage """ kwargs.update( { "channel": channel, "scheduled_message_id": scheduled_message_id, "as_user": as_user, } ) return await self.api_call("chat.deleteScheduledMessage", params=kwargs)
async def chat_getPermalink(self, *, channel: str, message_ts: str, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a permalink URL for a specific extant message https://api.slack.com/methods/chat.getPermalink
Expand source code
async def chat_getPermalink( self, *, channel: str, message_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a permalink URL for a specific extant message https://api.slack.com/methods/chat.getPermalink """ kwargs.update({"channel": channel, "message_ts": message_ts}) return await self.api_call("chat.getPermalink", http_verb="GET", params=kwargs)
async def chat_meMessage(self, *, channel: str, text: str, **kwargs) ‑> AsyncSlackResponse
-
Share a me message into a channel. https://api.slack.com/methods/chat.meMessage
Expand source code
async def chat_meMessage( self, *, channel: str, text: str, **kwargs, ) -> AsyncSlackResponse: """Share a me message into a channel. https://api.slack.com/methods/chat.meMessage """ kwargs.update({"channel": channel, "text": text}) return await self.api_call("chat.meMessage", params=kwargs)
async def chat_postEphemeral(self, *, channel: str, user: str, text: Optional[str] = None, as_user: Optional[bool] = None, attachments: Union[str, Sequence[Union[Dict, Attachment]], ForwardRef(None)] = None, blocks: Union[str, Sequence[Union[Dict, Block]], ForwardRef(None)] = None, thread_ts: Optional[str] = None, icon_emoji: Optional[str] = None, icon_url: Optional[str] = None, link_names: Optional[bool] = None, username: Optional[str] = None, parse: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Sends an ephemeral message to a user in a channel. https://api.slack.com/methods/chat.postEphemeral
Expand source code
async def chat_postEphemeral( self, *, channel: str, user: str, text: Optional[str] = None, as_user: Optional[bool] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, thread_ts: Optional[str] = None, icon_emoji: Optional[str] = None, icon_url: Optional[str] = None, link_names: Optional[bool] = None, username: Optional[str] = None, parse: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Sends an ephemeral message to a user in a channel. https://api.slack.com/methods/chat.postEphemeral """ kwargs.update( { "channel": channel, "user": user, "text": text, "as_user": as_user, "attachments": attachments, "blocks": blocks, "thread_ts": thread_ts, "icon_emoji": icon_emoji, "icon_url": icon_url, "link_names": link_names, "username": username, "parse": parse, } ) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.postEphemeral", kwargs) # NOTE: intentionally using json over params for the API methods using blocks/attachments return await self.api_call("chat.postEphemeral", json=kwargs)
async def chat_postMessage(self, *, channel: str, text: Optional[str] = None, as_user: Optional[bool] = None, attachments: Union[str, Sequence[Union[Dict, Attachment]], ForwardRef(None)] = None, blocks: Union[str, Sequence[Union[Dict, Block]], ForwardRef(None)] = None, thread_ts: Optional[str] = None, reply_broadcast: Optional[bool] = None, unfurl_links: Optional[bool] = None, unfurl_media: Optional[bool] = None, container_id: Optional[str] = None, icon_emoji: Optional[str] = None, icon_url: Optional[str] = None, mrkdwn: Optional[bool] = None, link_names: Optional[bool] = None, username: Optional[str] = None, parse: Optional[str] = None, metadata: Union[Dict, Metadata, ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Sends a message to a channel. https://api.slack.com/methods/chat.postMessage
Expand source code
async def chat_postMessage( self, *, channel: str, text: Optional[str] = None, as_user: Optional[bool] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, thread_ts: Optional[str] = None, reply_broadcast: Optional[bool] = None, unfurl_links: Optional[bool] = None, unfurl_media: Optional[bool] = None, container_id: Optional[str] = None, icon_emoji: Optional[str] = None, icon_url: Optional[str] = None, mrkdwn: Optional[bool] = None, link_names: Optional[bool] = None, username: Optional[str] = None, parse: Optional[str] = None, # none, full metadata: Optional[Union[Dict, Metadata]] = None, **kwargs, ) -> AsyncSlackResponse: """Sends a message to a channel. https://api.slack.com/methods/chat.postMessage """ kwargs.update( { "channel": channel, "text": text, "as_user": as_user, "attachments": attachments, "blocks": blocks, "thread_ts": thread_ts, "reply_broadcast": reply_broadcast, "unfurl_links": unfurl_links, "unfurl_media": unfurl_media, "container_id": container_id, "icon_emoji": icon_emoji, "icon_url": icon_url, "mrkdwn": mrkdwn, "link_names": link_names, "username": username, "parse": parse, "metadata": metadata, } ) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.postMessage", kwargs) # NOTE: intentionally using json over params for the API methods using blocks/attachments return await self.api_call("chat.postMessage", json=kwargs)
async def chat_scheduleMessage(self, *, channel: str, post_at: Union[str, int], text: str, as_user: Optional[bool] = None, attachments: Union[str, Sequence[Union[Dict, Attachment]], ForwardRef(None)] = None, blocks: Union[str, Sequence[Union[Dict, Block]], ForwardRef(None)] = None, thread_ts: Optional[str] = None, parse: Optional[str] = None, reply_broadcast: Optional[bool] = None, unfurl_links: Optional[bool] = None, unfurl_media: Optional[bool] = None, link_names: Optional[bool] = None, metadata: Union[Dict, Metadata, ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Schedules a message. https://api.slack.com/methods/chat.scheduleMessage
Expand source code
async def chat_scheduleMessage( self, *, channel: str, post_at: Union[str, int], text: str, as_user: Optional[bool] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, thread_ts: Optional[str] = None, parse: Optional[str] = None, reply_broadcast: Optional[bool] = None, unfurl_links: Optional[bool] = None, unfurl_media: Optional[bool] = None, link_names: Optional[bool] = None, metadata: Optional[Union[Dict, Metadata]] = None, **kwargs, ) -> AsyncSlackResponse: """Schedules a message. https://api.slack.com/methods/chat.scheduleMessage """ kwargs.update( { "channel": channel, "post_at": post_at, "text": text, "as_user": as_user, "attachments": attachments, "blocks": blocks, "thread_ts": thread_ts, "reply_broadcast": reply_broadcast, "parse": parse, "unfurl_links": unfurl_links, "unfurl_media": unfurl_media, "link_names": link_names, "metadata": metadata, } ) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.scheduleMessage", kwargs) # NOTE: intentionally using json over params for the API methods using blocks/attachments return await self.api_call("chat.scheduleMessage", json=kwargs)
async def chat_scheduledMessages_list(self, *, channel: Optional[str] = None, cursor: Optional[str] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists all scheduled messages. https://api.slack.com/methods/chat.scheduledMessages.list
Expand source code
async def chat_scheduledMessages_list( self, *, channel: Optional[str] = None, cursor: Optional[str] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all scheduled messages. https://api.slack.com/methods/chat.scheduledMessages.list """ kwargs.update( { "channel": channel, "cursor": cursor, "latest": latest, "limit": limit, "oldest": oldest, "team_id": team_id, } ) return await self.api_call("chat.scheduledMessages.list", params=kwargs)
async def chat_unfurl(self, *, channel: Optional[str] = None, ts: Optional[str] = None, source: Optional[str] = None, unfurl_id: Optional[str] = None, unfurls: Optional[Dict[str, Dict]] = None, user_auth_blocks: Union[str, Sequence[Union[Dict, Block]], ForwardRef(None)] = None, user_auth_message: Optional[str] = None, user_auth_required: Optional[bool] = None, user_auth_url: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Provide custom unfurl behavior for user-posted URLs. https://api.slack.com/methods/chat.unfurl
Expand source code
async def chat_unfurl( self, *, channel: Optional[str] = None, ts: Optional[str] = None, source: Optional[str] = None, unfurl_id: Optional[str] = None, unfurls: Optional[Dict[str, Dict]] = None, # or user_auth_* user_auth_blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, user_auth_message: Optional[str] = None, user_auth_required: Optional[bool] = None, user_auth_url: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Provide custom unfurl behavior for user-posted URLs. https://api.slack.com/methods/chat.unfurl """ kwargs.update( { "channel": channel, "ts": ts, "source": source, "unfurl_id": unfurl_id, "unfurls": unfurls, "user_auth_blocks": user_auth_blocks, "user_auth_message": user_auth_message, "user_auth_required": user_auth_required, "user_auth_url": user_auth_url, } ) _parse_web_class_objects(kwargs) # for user_auth_blocks kwargs = _remove_none_values(kwargs) # NOTE: intentionally using json over params for API methods using blocks/attachments return await self.api_call("chat.unfurl", json=kwargs)
async def chat_update(self, *, channel: str, ts: str, text: Optional[str] = None, attachments: Union[str, Sequence[Union[Dict, Attachment]], ForwardRef(None)] = None, blocks: Union[str, Sequence[Union[Dict, Block]], ForwardRef(None)] = None, as_user: Optional[bool] = None, file_ids: Union[str, Sequence[str], ForwardRef(None)] = None, link_names: Optional[bool] = None, parse: Optional[str] = None, reply_broadcast: Optional[bool] = None, metadata: Union[Dict, Metadata, ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Updates a message in a channel. https://api.slack.com/methods/chat.update
Expand source code
async def chat_update( self, *, channel: str, ts: str, text: Optional[str] = None, attachments: Optional[Union[str, Sequence[Union[Dict, Attachment]]]] = None, blocks: Optional[Union[str, Sequence[Union[Dict, Block]]]] = None, as_user: Optional[bool] = None, file_ids: Optional[Union[str, Sequence[str]]] = None, link_names: Optional[bool] = None, parse: Optional[str] = None, # none, full reply_broadcast: Optional[bool] = None, metadata: Optional[Union[Dict, Metadata]] = None, **kwargs, ) -> AsyncSlackResponse: """Updates a message in a channel. https://api.slack.com/methods/chat.update """ kwargs.update( { "channel": channel, "ts": ts, "text": text, "attachments": attachments, "blocks": blocks, "as_user": as_user, "link_names": link_names, "parse": parse, "reply_broadcast": reply_broadcast, "metadata": metadata, } ) if isinstance(file_ids, (list, Tuple)): kwargs.update({"file_ids": ",".join(file_ids)}) else: kwargs.update({"file_ids": file_ids}) _parse_web_class_objects(kwargs) kwargs = _remove_none_values(kwargs) _warn_if_text_or_attachment_fallback_is_missing("chat.update", kwargs) # NOTE: intentionally using json over params for API methods using blocks/attachments return await self.api_call("chat.update", json=kwargs)
-
Accepts an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.acceptSharedInvite
Expand source code
async def conversations_acceptSharedInvite( self, *, channel_name: str, channel_id: Optional[str] = None, invite_id: Optional[str] = None, free_trial_accepted: Optional[bool] = None, is_private: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Accepts an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.acceptSharedInvite """ if channel_id is None and invite_id is None: raise e.SlackRequestError("Either channel_id or invite_id must be provided.") kwargs.update( { "channel_name": channel_name, "channel_id": channel_id, "invite_id": invite_id, "free_trial_accepted": free_trial_accepted, "is_private": is_private, "team_id": team_id, } ) return await self.api_call("conversations.acceptSharedInvite", http_verb="POST", params=kwargs)
-
Approves an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.approveSharedInvite
Expand source code
async def conversations_approveSharedInvite( self, *, invite_id: str, target_team: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Approves an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.approveSharedInvite """ kwargs.update({"invite_id": invite_id, "target_team": target_team}) return await self.api_call("conversations.approveSharedInvite", http_verb="POST", params=kwargs)
async def conversations_archive(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Archives a conversation. https://api.slack.com/methods/conversations.archive
Expand source code
async def conversations_archive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Archives a conversation. https://api.slack.com/methods/conversations.archive """ kwargs.update({"channel": channel}) return await self.api_call("conversations.archive", params=kwargs)
async def conversations_close(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Closes a direct message or multi-person direct message. https://api.slack.com/methods/conversations.close
Expand source code
async def conversations_close( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Closes a direct message or multi-person direct message. https://api.slack.com/methods/conversations.close """ kwargs.update({"channel": channel}) return await self.api_call("conversations.close", params=kwargs)
async def conversations_create(self, *, name: str, is_private: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Initiates a public or private channel-based conversation https://api.slack.com/methods/conversations.create
Expand source code
async def conversations_create( self, *, name: str, is_private: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Initiates a public or private channel-based conversation https://api.slack.com/methods/conversations.create """ kwargs.update({"name": name, "is_private": is_private, "team_id": team_id}) return await self.api_call("conversations.create", params=kwargs)
-
Declines a Slack Connect channel invite. https://api.slack.com/methods/conversations.declineSharedInvite
Expand source code
async def conversations_declineSharedInvite( self, *, invite_id: str, target_team: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Declines a Slack Connect channel invite. https://api.slack.com/methods/conversations.declineSharedInvite """ kwargs.update({"invite_id": invite_id, "target_team": target_team}) return await self.api_call("conversations.declineSharedInvite", http_verb="GET", params=kwargs)
async def conversations_history(self, *, channel: str, cursor: Optional[str] = None, inclusive: Optional[bool] = None, include_all_metadata: Optional[bool] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Fetches a conversation's history of messages and events. https://api.slack.com/methods/conversations.history
Expand source code
async def conversations_history( self, *, channel: str, cursor: Optional[str] = None, inclusive: Optional[bool] = None, include_all_metadata: Optional[bool] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Fetches a conversation's history of messages and events. https://api.slack.com/methods/conversations.history """ kwargs.update( { "channel": channel, "cursor": cursor, "inclusive": inclusive, "include_all_metadata": include_all_metadata, "limit": limit, "latest": latest, "oldest": oldest, } ) return await self.api_call("conversations.history", http_verb="GET", params=kwargs)
async def conversations_info(self, *, channel: str, include_locale: Optional[bool] = None, include_num_members: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve information about a conversation. https://api.slack.com/methods/conversations.info
Expand source code
async def conversations_info( self, *, channel: str, include_locale: Optional[bool] = None, include_num_members: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve information about a conversation. https://api.slack.com/methods/conversations.info """ kwargs.update( { "channel": channel, "include_locale": include_locale, "include_num_members": include_num_members, } ) return await self.api_call("conversations.info", http_verb="GET", params=kwargs)
async def conversations_invite(self, *, channel: str, users: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
Invites users to a channel. https://api.slack.com/methods/conversations.invite
Expand source code
async def conversations_invite( self, *, channel: str, users: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """Invites users to a channel. https://api.slack.com/methods/conversations.invite """ kwargs.update({"channel": channel}) if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("conversations.invite", params=kwargs)
-
Sends an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.inviteShared
Expand source code
async def conversations_inviteShared( self, *, channel: str, emails: Optional[Union[str, Sequence[str]]] = None, user_ids: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Sends an invitation to a Slack Connect channel. https://api.slack.com/methods/conversations.inviteShared """ if emails is None and user_ids is None: raise e.SlackRequestError("Either emails or user ids must be provided.") kwargs.update({"channel": channel}) if isinstance(emails, (list, Tuple)): kwargs.update({"emails": ",".join(emails)}) else: kwargs.update({"emails": emails}) if isinstance(user_ids, (list, Tuple)): kwargs.update({"user_ids": ",".join(user_ids)}) else: kwargs.update({"user_ids": user_ids}) return await self.api_call("conversations.inviteShared", http_verb="GET", params=kwargs)
async def conversations_join(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Joins an existing conversation. https://api.slack.com/methods/conversations.join
Expand source code
async def conversations_join( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Joins an existing conversation. https://api.slack.com/methods/conversations.join """ kwargs.update({"channel": channel}) return await self.api_call("conversations.join", params=kwargs)
async def conversations_kick(self, *, channel: str, user: str, **kwargs) ‑> AsyncSlackResponse
-
Removes a user from a conversation. https://api.slack.com/methods/conversations.kick
Expand source code
async def conversations_kick( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Removes a user from a conversation. https://api.slack.com/methods/conversations.kick """ kwargs.update({"channel": channel, "user": user}) return await self.api_call("conversations.kick", params=kwargs)
async def conversations_leave(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Leaves a conversation. https://api.slack.com/methods/conversations.leave
Expand source code
async def conversations_leave( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Leaves a conversation. https://api.slack.com/methods/conversations.leave """ kwargs.update({"channel": channel}) return await self.api_call("conversations.leave", params=kwargs)
async def conversations_list(self, *, cursor: Optional[str] = None, exclude_archived: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, types: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists all channels in a Slack team. https://api.slack.com/methods/conversations.list
Expand source code
async def conversations_list( self, *, cursor: Optional[str] = None, exclude_archived: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, types: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all channels in a Slack team. https://api.slack.com/methods/conversations.list """ kwargs.update( { "cursor": cursor, "exclude_archived": exclude_archived, "limit": limit, "team_id": team_id, } ) if isinstance(types, (list, Tuple)): kwargs.update({"types": ",".join(types)}) else: kwargs.update({"types": types}) return await self.api_call("conversations.list", http_verb="GET", params=kwargs)
async def conversations_listConnectInvites(self, *, count: Optional[int] = None, cursor: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List shared channel invites that have been generated or received but have not yet been approved by all parties. https://api.slack.com/methods/conversations.listConnectInvites
Expand source code
async def conversations_listConnectInvites( self, *, count: Optional[int] = None, cursor: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List shared channel invites that have been generated or received but have not yet been approved by all parties. https://api.slack.com/methods/conversations.listConnectInvites """ kwargs.update({"count": count, "cursor": cursor, "team_id": team_id}) return await self.api_call("conversations.listConnectInvites", params=kwargs)
async def conversations_mark(self, *, channel: str, ts: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the read cursor in a channel. https://api.slack.com/methods/conversations.mark
Expand source code
async def conversations_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a channel. https://api.slack.com/methods/conversations.mark """ kwargs.update({"channel": channel, "ts": ts}) return await self.api_call("conversations.mark", params=kwargs)
async def conversations_members(self, *, channel: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve members of a conversation. https://api.slack.com/methods/conversations.members
Expand source code
async def conversations_members( self, *, channel: str, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve members of a conversation. https://api.slack.com/methods/conversations.members """ kwargs.update({"channel": channel, "cursor": cursor, "limit": limit}) return await self.api_call("conversations.members", http_verb="GET", params=kwargs)
async def conversations_open(self, *, channel: Optional[str] = None, return_im: Optional[bool] = None, users: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Opens or resumes a direct message or multi-person direct message. https://api.slack.com/methods/conversations.open
Expand source code
async def conversations_open( self, *, channel: Optional[str] = None, return_im: Optional[bool] = None, users: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Opens or resumes a direct message or multi-person direct message. https://api.slack.com/methods/conversations.open """ if channel is None and users is None: raise e.SlackRequestError("Either channel or users must be provided.") kwargs.update({"channel": channel, "return_im": return_im}) if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("conversations.open", params=kwargs)
async def conversations_rename(self, *, channel: str, name: str, **kwargs) ‑> AsyncSlackResponse
-
Renames a conversation. https://api.slack.com/methods/conversations.rename
Expand source code
async def conversations_rename( self, *, channel: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Renames a conversation. https://api.slack.com/methods/conversations.rename """ kwargs.update({"channel": channel, "name": name}) return await self.api_call("conversations.rename", params=kwargs)
async def conversations_replies(self, *, channel: str, ts: str, cursor: Optional[str] = None, inclusive: Optional[bool] = None, include_all_metadata: Optional[bool] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a thread of messages posted to a conversation https://api.slack.com/methods/conversations.replies
Expand source code
async def conversations_replies( self, *, channel: str, ts: str, cursor: Optional[str] = None, inclusive: Optional[bool] = None, include_all_metadata: Optional[bool] = None, latest: Optional[str] = None, limit: Optional[int] = None, oldest: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a conversation https://api.slack.com/methods/conversations.replies """ kwargs.update( { "channel": channel, "ts": ts, "cursor": cursor, "inclusive": inclusive, "include_all_metadata": include_all_metadata, "limit": limit, "latest": latest, "oldest": oldest, } ) return await self.api_call("conversations.replies", http_verb="GET", params=kwargs)
async def conversations_setPurpose(self, *, channel: str, purpose: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the purpose for a conversation. https://api.slack.com/methods/conversations.setPurpose
Expand source code
async def conversations_setPurpose( self, *, channel: str, purpose: str, **kwargs, ) -> AsyncSlackResponse: """Sets the purpose for a conversation. https://api.slack.com/methods/conversations.setPurpose """ kwargs.update({"channel": channel, "purpose": purpose}) return await self.api_call("conversations.setPurpose", params=kwargs)
async def conversations_setTopic(self, *, channel: str, topic: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the topic for a conversation. https://api.slack.com/methods/conversations.setTopic
Expand source code
async def conversations_setTopic( self, *, channel: str, topic: str, **kwargs, ) -> AsyncSlackResponse: """Sets the topic for a conversation. https://api.slack.com/methods/conversations.setTopic """ kwargs.update({"channel": channel, "topic": topic}) return await self.api_call("conversations.setTopic", params=kwargs)
async def conversations_unarchive(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Reverses conversation archival. https://api.slack.com/methods/conversations.unarchive
Expand source code
async def conversations_unarchive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Reverses conversation archival. https://api.slack.com/methods/conversations.unarchive """ kwargs.update({"channel": channel}) return await self.api_call("conversations.unarchive", params=kwargs)
async def dialog_open(self, *, dialog: Dict[str, Any], trigger_id: str, **kwargs) ‑> AsyncSlackResponse
-
Open a dialog with a user. https://api.slack.com/methods/dialog.open
Expand source code
async def dialog_open( self, *, dialog: Dict[str, Any], trigger_id: str, **kwargs, ) -> AsyncSlackResponse: """Open a dialog with a user. https://api.slack.com/methods/dialog.open """ kwargs.update({"dialog": dialog, "trigger_id": trigger_id}) kwargs = _remove_none_values(kwargs) # NOTE: As the dialog can be a dict, this API call works only with json format. return await self.api_call("dialog.open", json=kwargs)
async def dnd_endDnd(self, **kwargs) ‑> AsyncSlackResponse
-
Ends the current user's Do Not Disturb session immediately. https://api.slack.com/methods/dnd.endDnd
Expand source code
async def dnd_endDnd( self, **kwargs, ) -> AsyncSlackResponse: """Ends the current user's Do Not Disturb session immediately. https://api.slack.com/methods/dnd.endDnd """ return await self.api_call("dnd.endDnd", params=kwargs)
async def dnd_endSnooze(self, **kwargs) ‑> AsyncSlackResponse
-
Ends the current user's snooze mode immediately. https://api.slack.com/methods/dnd.endSnooze
Expand source code
async def dnd_endSnooze( self, **kwargs, ) -> AsyncSlackResponse: """Ends the current user's snooze mode immediately. https://api.slack.com/methods/dnd.endSnooze """ return await self.api_call("dnd.endSnooze", params=kwargs)
async def dnd_info(self, *, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieves a user's current Do Not Disturb status. https://api.slack.com/methods/dnd.info
Expand source code
async def dnd_info( self, *, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieves a user's current Do Not Disturb status. https://api.slack.com/methods/dnd.info """ kwargs.update({"team_id": team_id, "user": user}) return await self.api_call("dnd.info", http_verb="GET", params=kwargs)
async def dnd_setSnooze(self, *, num_minutes: Union[str, int], **kwargs) ‑> AsyncSlackResponse
-
Turns on Do Not Disturb mode for the current user, or changes its duration. https://api.slack.com/methods/dnd.setSnooze
Expand source code
async def dnd_setSnooze( self, *, num_minutes: Union[int, str], **kwargs, ) -> AsyncSlackResponse: """Turns on Do Not Disturb mode for the current user, or changes its duration. https://api.slack.com/methods/dnd.setSnooze """ kwargs.update({"num_minutes": num_minutes}) return await self.api_call("dnd.setSnooze", http_verb="GET", params=kwargs)
async def dnd_teamInfo(self, users: Union[str, Sequence[str]], team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieves the Do Not Disturb status for users on a team. https://api.slack.com/methods/dnd.teamInfo
Expand source code
async def dnd_teamInfo( self, users: Union[str, Sequence[str]], team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieves the Do Not Disturb status for users on a team. https://api.slack.com/methods/dnd.teamInfo """ if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) kwargs.update({"team_id": team_id}) return await self.api_call("dnd.teamInfo", http_verb="GET", params=kwargs)
async def emoji_list(self, include_categories: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists custom emoji for a team. https://api.slack.com/methods/emoji.list
Expand source code
async def emoji_list( self, include_categories: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Lists custom emoji for a team. https://api.slack.com/methods/emoji.list """ kwargs.update({"include_categories": include_categories}) return await self.api_call("emoji.list", http_verb="GET", params=kwargs)
async def files_comments_delete(self, *, file: str, id: str, **kwargs) ‑> AsyncSlackResponse
-
Deletes an existing comment on a file. https://api.slack.com/methods/files.comments.delete
Expand source code
async def files_comments_delete( self, *, file: str, id: str, **kwargs, # skipcq: PYL-W0622 ) -> AsyncSlackResponse: """Deletes an existing comment on a file. https://api.slack.com/methods/files.comments.delete """ kwargs.update({"file": file, "id": id}) return await self.api_call("files.comments.delete", params=kwargs)
async def files_completeUploadExternal(self, *, files: List[Dict[str, str]], channel_id: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Finishes an upload started with files.getUploadURLExternal. https://api.slack.com/methods/files.completeUploadExternal
Expand source code
async def files_completeUploadExternal( self, *, files: List[Dict[str, str]], channel_id: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Finishes an upload started with files.getUploadURLExternal. https://api.slack.com/methods/files.completeUploadExternal """ _files = [{k: v for k, v in f.items() if v is not None} for f in files] kwargs.update( { "files": json.dumps(_files), "channel_id": channel_id, "initial_comment": initial_comment, "thread_ts": thread_ts, } ) return await self.api_call("files.completeUploadExternal", params=kwargs)
async def files_delete(self, *, file: str, **kwargs) ‑> AsyncSlackResponse
-
Deletes a file. https://api.slack.com/methods/files.delete
Expand source code
async def files_delete( self, *, file: str, **kwargs, ) -> AsyncSlackResponse: """Deletes a file. https://api.slack.com/methods/files.delete """ kwargs.update({"file": file}) return await self.api_call("files.delete", params=kwargs)
async def files_getUploadURLExternal(self, *, filename: str, length: int, alt_txt: Optional[str] = None, snippet_type: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets a URL for an edge external upload. https://api.slack.com/methods/files.getUploadURLExternal
Expand source code
async def files_getUploadURLExternal( self, *, filename: str, length: int, alt_txt: Optional[str] = None, snippet_type: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets a URL for an edge external upload. https://api.slack.com/methods/files.getUploadURLExternal """ kwargs.update( { "filename": filename, "length": length, "alt_txt": alt_txt, "snippet_type": snippet_type, } ) return await self.api_call("files.getUploadURLExternal", params=kwargs)
async def files_info(self, *, file: str, count: Optional[int] = None, cursor: Optional[str] = None, limit: Optional[int] = None, page: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets information about a team file. https://api.slack.com/methods/files.info
Expand source code
async def files_info( self, *, file: str, count: Optional[int] = None, cursor: Optional[str] = None, limit: Optional[int] = None, page: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a team file. https://api.slack.com/methods/files.info """ kwargs.update( { "file": file, "count": count, "cursor": cursor, "limit": limit, "page": page, } ) return await self.api_call("files.info", http_verb="GET", params=kwargs)
async def files_list(self, *, channel: Optional[str] = None, count: Optional[int] = None, page: Optional[int] = None, show_files_hidden_by_limit: Optional[bool] = None, team_id: Optional[str] = None, ts_from: Optional[str] = None, ts_to: Optional[str] = None, types: Union[str, Sequence[str], ForwardRef(None)] = None, user: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists & filters team files. https://api.slack.com/methods/files.list
Expand source code
async def files_list( self, *, channel: Optional[str] = None, count: Optional[int] = None, page: Optional[int] = None, show_files_hidden_by_limit: Optional[bool] = None, team_id: Optional[str] = None, ts_from: Optional[str] = None, ts_to: Optional[str] = None, types: Optional[Union[str, Sequence[str]]] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists & filters team files. https://api.slack.com/methods/files.list """ kwargs.update( { "channel": channel, "count": count, "page": page, "show_files_hidden_by_limit": show_files_hidden_by_limit, "team_id": team_id, "ts_from": ts_from, "ts_to": ts_to, "user": user, } ) if isinstance(types, (list, Tuple)): kwargs.update({"types": ",".join(types)}) else: kwargs.update({"types": types}) return await self.api_call("files.list", http_verb="GET", params=kwargs)
async def files_remote_add(self, *, external_id: str, external_url: str, title: str, filetype: Optional[str] = None, indexable_file_contents: Union[str, bytes, io.IOBase, ForwardRef(None)] = None, preview_image: Union[str, bytes, io.IOBase, ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Adds a file from a remote service. https://api.slack.com/methods/files.remote.add
Expand source code
async def files_remote_add( self, *, external_id: str, external_url: str, title: str, filetype: Optional[str] = None, indexable_file_contents: Optional[Union[str, bytes, IOBase]] = None, preview_image: Optional[Union[str, bytes, IOBase]] = None, **kwargs, ) -> AsyncSlackResponse: """Adds a file from a remote service. https://api.slack.com/methods/files.remote.add """ kwargs.update( { "external_id": external_id, "external_url": external_url, "title": title, "filetype": filetype, } ) files = None # preview_image (file): Preview of the document via multipart/form-data. if preview_image is not None or indexable_file_contents is not None: files = { "preview_image": preview_image, "indexable_file_contents": indexable_file_contents, } return await self.api_call( # Intentionally using "POST" method over "GET" here "files.remote.add", http_verb="POST", data=kwargs, files=files, )
async def files_remote_info(self, *, external_id: Optional[str] = None, file: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve information about a remote file added to Slack. https://api.slack.com/methods/files.remote.info
Expand source code
async def files_remote_info( self, *, external_id: Optional[str] = None, file: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve information about a remote file added to Slack. https://api.slack.com/methods/files.remote.info """ kwargs.update({"external_id": external_id, "file": file}) return await self.api_call("files.remote.info", http_verb="GET", params=kwargs)
async def files_remote_list(self, *, channel: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, ts_from: Optional[str] = None, ts_to: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve information about a remote file added to Slack. https://api.slack.com/methods/files.remote.list
Expand source code
async def files_remote_list( self, *, channel: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, ts_from: Optional[str] = None, ts_to: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve information about a remote file added to Slack. https://api.slack.com/methods/files.remote.list """ kwargs.update( { "channel": channel, "cursor": cursor, "limit": limit, "ts_from": ts_from, "ts_to": ts_to, } ) return await self.api_call("files.remote.list", http_verb="GET", params=kwargs)
async def files_remote_remove(self, *, external_id: Optional[str] = None, file: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Remove a remote file. https://api.slack.com/methods/files.remote.remove
Expand source code
async def files_remote_remove( self, *, external_id: Optional[str] = None, file: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Remove a remote file. https://api.slack.com/methods/files.remote.remove """ kwargs.update({"external_id": external_id, "file": file}) return await self.api_call("files.remote.remove", http_verb="POST", params=kwargs)
-
Share a remote file into a channel. https://api.slack.com/methods/files.remote.share
Expand source code
async def files_remote_share( self, *, channels: Union[str, Sequence[str]], external_id: Optional[str] = None, file: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Share a remote file into a channel. https://api.slack.com/methods/files.remote.share """ if external_id is None and file is None: raise e.SlackRequestError("Either external_id or file must be provided.") if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) kwargs.update({"external_id": external_id, "file": file}) return await self.api_call("files.remote.share", http_verb="GET", params=kwargs)
async def files_remote_update(self, *, external_id: Optional[str] = None, external_url: Optional[str] = None, file: Optional[str] = None, title: Optional[str] = None, filetype: Optional[str] = None, indexable_file_contents: Optional[str] = None, preview_image: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Updates an existing remote file. https://api.slack.com/methods/files.remote.update
Expand source code
async def files_remote_update( self, *, external_id: Optional[str] = None, external_url: Optional[str] = None, file: Optional[str] = None, title: Optional[str] = None, filetype: Optional[str] = None, indexable_file_contents: Optional[str] = None, preview_image: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Updates an existing remote file. https://api.slack.com/methods/files.remote.update """ kwargs.update( { "external_id": external_id, "external_url": external_url, "file": file, "title": title, "filetype": filetype, } ) files = None # preview_image (file): Preview of the document via multipart/form-data. if preview_image is not None or indexable_file_contents is not None: files = { "preview_image": preview_image, "indexable_file_contents": indexable_file_contents, } return await self.api_call( # Intentionally using "POST" method over "GET" here "files.remote.update", http_verb="POST", data=kwargs, files=files, )
async def files_revokePublicURL(self, *, file: str, **kwargs) ‑> AsyncSlackResponse
-
Revokes public/external sharing access for a file https://api.slack.com/methods/files.revokePublicURL
Expand source code
async def files_revokePublicURL( self, *, file: str, **kwargs, ) -> AsyncSlackResponse: """Revokes public/external sharing access for a file https://api.slack.com/methods/files.revokePublicURL """ kwargs.update({"file": file}) return await self.api_call("files.revokePublicURL", params=kwargs)
-
Enables a file for public/external sharing. https://api.slack.com/methods/files.sharedPublicURL
Expand source code
async def files_sharedPublicURL( self, *, file: str, **kwargs, ) -> AsyncSlackResponse: """Enables a file for public/external sharing. https://api.slack.com/methods/files.sharedPublicURL """ kwargs.update({"file": file}) return await self.api_call("files.sharedPublicURL", params=kwargs)
async def files_upload(self, *, file: Union[str, bytes, io.IOBase, ForwardRef(None)] = None, content: Union[str, bytes, ForwardRef(None)] = None, filename: Optional[str] = None, filetype: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, title: Optional[str] = None, channels: Union[str, Sequence[str], ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Uploads or creates a file. https://api.slack.com/methods/files.upload
Expand source code
async def files_upload( self, *, file: Optional[Union[str, bytes, IOBase]] = None, content: Optional[Union[str, bytes]] = None, filename: Optional[str] = None, filetype: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, title: Optional[str] = None, channels: Optional[Union[str, Sequence[str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Uploads or creates a file. https://api.slack.com/methods/files.upload """ _print_files_upload_v2_suggestion() if file is None and content is None: raise e.SlackRequestError("The file or content argument must be specified.") if file is not None and content is not None: raise e.SlackRequestError("You cannot specify both the file and the content argument.") if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) kwargs.update( { "filename": filename, "filetype": filetype, "initial_comment": initial_comment, "thread_ts": thread_ts, "title": title, } ) if file: if kwargs.get("filename") is None and isinstance(file, str): # use the local filename if filename is missing if kwargs.get("filename") is None: kwargs["filename"] = file.split(os.path.sep)[-1] return await self.api_call("files.upload", files={"file": file}, data=kwargs) else: kwargs["content"] = content return await self.api_call("files.upload", data=kwargs)
async def files_upload_v2(self, *, filename: Optional[str] = None, file: Union[str, bytes, io.IOBase, ForwardRef(None)] = None, content: Union[str, bytes, ForwardRef(None)] = None, title: Optional[str] = None, alt_txt: Optional[str] = None, snippet_type: Optional[str] = None, file_uploads: Optional[List[Dict[str, Any]]] = None, channel: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, request_file_info: bool = True, **kwargs) ‑> AsyncSlackResponse
-
This wrapper method provides an easy way to upload files using the following endpoints:
-
step1: https://api.slack.com/methods/files.getUploadURLExternal
-
step2: "https://files.slack.com/upload/v1/…" URLs returned from files.getUploadURLExternal API
-
step3: https://api.slack.com/methods/files.completeUploadExternal and https://api.slack.com/methods/files.info
Expand source code
async def files_upload_v2( self, *, # for sending a single file filename: Optional[str] = None, # you can skip this only when sending along with content parameter file: Optional[Union[str, bytes, IOBase]] = None, content: Optional[Union[str, bytes]] = None, title: Optional[str] = None, alt_txt: Optional[str] = None, snippet_type: Optional[str] = None, # To upload multiple files at a time file_uploads: Optional[List[Dict[str, Any]]] = None, channel: Optional[str] = None, initial_comment: Optional[str] = None, thread_ts: Optional[str] = None, request_file_info: bool = True, **kwargs, ) -> AsyncSlackResponse: """This wrapper method provides an easy way to upload files using the following endpoints: - step1: https://api.slack.com/methods/files.getUploadURLExternal - step2: "https://files.slack.com/upload/v1/..." URLs returned from files.getUploadURLExternal API - step3: https://api.slack.com/methods/files.completeUploadExternal and https://api.slack.com/methods/files.info """ if file is None and content is None and file_uploads is None: raise e.SlackRequestError("Any of file, content, and file_uploads must be specified.") if file is not None and content is not None: raise e.SlackRequestError("You cannot specify both the file and the content argument.") # deprecated arguments: channels, filetype = kwargs.get("channels"), kwargs.get("filetype") if channels is not None: warnings.warn( "Although the channels parameter is still supported for smooth migration from legacy files.upload, " "we recommend using the new channel parameter with a single str value instead for more clarity." ) if (isinstance(channels, (list, Tuple)) and len(channels) > 1) or ( isinstance(channels, str) and len(channels.split(",")) > 1 ): raise e.SlackRequestError( "Sharing files with multiple channels is no longer supported in v2. " "Share files in each channel separately instead." ) if filetype is not None: warnings.warn("The filetype parameter is no longer supported. Please remove it from the arguments.") # step1: files.getUploadURLExternal per file files: List[Dict[str, Any]] = [] if file_uploads is not None: for f in file_uploads: files.append(_to_v2_file_upload_item(f)) else: f = _to_v2_file_upload_item( { "filename": filename, "file": file, "content": content, "title": title, "alt_txt": alt_txt, "snippet_type": snippet_type, } ) files.append(f) for f in files: url_response = await self.files_getUploadURLExternal( filename=f.get("filename"), length=f.get("length"), alt_txt=f.get("alt_txt"), snippet_type=f.get("snippet_type"), token=kwargs.get("token"), ) _validate_for_legacy_client(url_response) f["file_id"] = url_response.get("file_id") # type: ignore f["upload_url"] = url_response.get("upload_url") # type: ignore # step2: "https://files.slack.com/upload/v1/..." per file for f in files: upload_result = _upload_file_via_v2_url( url=f["upload_url"], data=f["data"], logger=self._logger, timeout=self.timeout, proxy=self.proxy, ssl=self.ssl, ) if upload_result.get("status") != 200: status = upload_result.get("status") body = upload_result.get("body") message = ( "Failed to upload a file " f"(status: {status}, body: {body}, filename: {f.get('filename')}, title: {f.get('title')})" ) raise e.SlackRequestError(message) # step3: files.completeUploadExternal with all the sets of (file_id + title) channel_to_share = channel if channels is not None: if isinstance(channels, str): channel_to_share = channels.split(",")[0] else: channel_to_share = channels[0] completion = await self.files_completeUploadExternal( files=[{"id": f["file_id"], "title": f["title"]} for f in files], channel_id=channel_to_share, initial_comment=initial_comment, thread_ts=thread_ts, token=kwargs.get("token"), **kwargs, ) if request_file_info is True: await _attach_full_file_metadata_async( client=self, token_as_arg=kwargs.get("token"), completion=completion, ) return completion
-
async def groups_archive(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Archives a private channel.
Expand source code
async def groups_archive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Archives a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.archive", json=kwargs)
async def groups_create(self, *, name: str, **kwargs) ‑> AsyncSlackResponse
-
Creates a private channel.
Expand source code
async def groups_create( self, *, name: str, **kwargs, ) -> AsyncSlackResponse: """Creates a private channel.""" kwargs.update({"name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.create", json=kwargs)
async def groups_createChild(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Clones and archives a private channel.
Expand source code
async def groups_createChild( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Clones and archives a private channel.""" kwargs.update({"channel": channel}) return await self.api_call("groups.createChild", http_verb="GET", params=kwargs)
async def groups_history(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Fetches history of messages and events from a private channel.
Expand source code
async def groups_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from a private channel.""" kwargs.update({"channel": channel}) return await self.api_call("groups.history", http_verb="GET", params=kwargs)
async def groups_info(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Gets information about a private channel.
Expand source code
async def groups_info( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Gets information about a private channel.""" kwargs.update({"channel": channel}) return await self.api_call("groups.info", http_verb="GET", params=kwargs)
async def groups_invite(self, *, channel: str, user: str, **kwargs) ‑> AsyncSlackResponse
-
Invites a user to a private channel.
Expand source code
async def groups_invite( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Invites a user to a private channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.invite", json=kwargs)
async def groups_kick(self, *, channel: str, user: str, **kwargs) ‑> AsyncSlackResponse
-
Removes a user from a private channel.
Expand source code
async def groups_kick( self, *, channel: str, user: str, **kwargs, ) -> AsyncSlackResponse: """Removes a user from a private channel.""" kwargs.update({"channel": channel, "user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.kick", json=kwargs)
async def groups_leave(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Leaves a private channel.
Expand source code
async def groups_leave( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Leaves a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.leave", json=kwargs)
async def groups_list(self, **kwargs) ‑> AsyncSlackResponse
-
Lists private channels that the calling user has access to.
Expand source code
async def groups_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists private channels that the calling user has access to.""" return await self.api_call("groups.list", http_verb="GET", params=kwargs)
async def groups_mark(self, *, channel: str, ts: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the read cursor in a private channel.
Expand source code
async def groups_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a private channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.mark", json=kwargs)
async def groups_open(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Opens a private channel.
Expand source code
async def groups_open( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Opens a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.open", json=kwargs)
async def groups_rename(self, *, channel: str, name: str, **kwargs) ‑> AsyncSlackResponse
-
Renames a private channel.
Expand source code
async def groups_rename( self, *, channel: str, name: str, **kwargs, ) -> AsyncSlackResponse: """Renames a private channel.""" kwargs.update({"channel": channel, "name": name}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.rename", json=kwargs)
async def groups_replies(self, *, channel: str, thread_ts: str, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a thread of messages posted to a private channel
Expand source code
async def groups_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a private channel""" kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("groups.replies", http_verb="GET", params=kwargs)
async def groups_setPurpose(self, *, channel: str, purpose: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the purpose for a private channel.
Expand source code
async def groups_setPurpose( self, *, channel: str, purpose: str, **kwargs, ) -> AsyncSlackResponse: """Sets the purpose for a private channel.""" kwargs.update({"channel": channel, "purpose": purpose}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.setPurpose", json=kwargs)
async def groups_setTopic(self, *, channel: str, topic: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the topic for a private channel.
Expand source code
async def groups_setTopic( self, *, channel: str, topic: str, **kwargs, ) -> AsyncSlackResponse: """Sets the topic for a private channel.""" kwargs.update({"channel": channel, "topic": topic}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.setTopic", json=kwargs)
async def groups_unarchive(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Unarchives a private channel.
Expand source code
async def groups_unarchive( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Unarchives a private channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("groups.unarchive", json=kwargs)
async def im_close(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Close a direct message channel.
Expand source code
async def im_close( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Close a direct message channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("im.close", json=kwargs)
async def im_history(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Fetches history of messages and events from direct message channel.
Expand source code
async def im_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from direct message channel.""" kwargs.update({"channel": channel}) return await self.api_call("im.history", http_verb="GET", params=kwargs)
async def im_list(self, **kwargs) ‑> AsyncSlackResponse
-
Lists direct message channels for the calling user.
Expand source code
async def im_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists direct message channels for the calling user.""" return await self.api_call("im.list", http_verb="GET", params=kwargs)
async def im_mark(self, *, channel: str, ts: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the read cursor in a direct message channel.
Expand source code
async def im_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a direct message channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("im.mark", json=kwargs)
async def im_open(self, *, user: str, **kwargs) ‑> AsyncSlackResponse
-
Opens a direct message channel.
Expand source code
async def im_open( self, *, user: str, **kwargs, ) -> AsyncSlackResponse: """Opens a direct message channel.""" kwargs.update({"user": user}) kwargs = _remove_none_values(kwargs) return await self.api_call("im.open", json=kwargs)
async def im_replies(self, *, channel: str, thread_ts: str, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a thread of messages posted to a direct message conversation
Expand source code
async def im_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a direct message conversation""" kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("im.replies", http_verb="GET", params=kwargs)
async def migration_exchange(self, *, users: Union[str, Sequence[str]], team_id: Optional[str] = None, to_old: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
For Enterprise Grid workspaces, map local user IDs to global user IDs https://api.slack.com/methods/migration.exchange
Expand source code
async def migration_exchange( self, *, users: Union[str, Sequence[str]], team_id: Optional[str] = None, to_old: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """For Enterprise Grid workspaces, map local user IDs to global user IDs https://api.slack.com/methods/migration.exchange """ if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) kwargs.update({"team_id": team_id, "to_old": to_old}) return await self.api_call("migration.exchange", http_verb="GET", params=kwargs)
async def mpim_close(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Closes a multiparty direct message channel.
Expand source code
async def mpim_close( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Closes a multiparty direct message channel.""" kwargs.update({"channel": channel}) kwargs = _remove_none_values(kwargs) return await self.api_call("mpim.close", json=kwargs)
async def mpim_history(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Fetches history of messages and events from a multiparty direct message.
Expand source code
async def mpim_history( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Fetches history of messages and events from a multiparty direct message.""" kwargs.update({"channel": channel}) return await self.api_call("mpim.history", http_verb="GET", params=kwargs)
async def mpim_list(self, **kwargs) ‑> AsyncSlackResponse
-
Lists multiparty direct message channels for the calling user.
Expand source code
async def mpim_list( self, **kwargs, ) -> AsyncSlackResponse: """Lists multiparty direct message channels for the calling user.""" return await self.api_call("mpim.list", http_verb="GET", params=kwargs)
async def mpim_mark(self, *, channel: str, ts: str, **kwargs) ‑> AsyncSlackResponse
-
Sets the read cursor in a multiparty direct message channel.
Expand source code
async def mpim_mark( self, *, channel: str, ts: str, **kwargs, ) -> AsyncSlackResponse: """Sets the read cursor in a multiparty direct message channel.""" kwargs.update({"channel": channel, "ts": ts}) kwargs = _remove_none_values(kwargs) return await self.api_call("mpim.mark", json=kwargs)
async def mpim_open(self, *, users: Union[str, Sequence[str]], **kwargs) ‑> AsyncSlackResponse
-
This method opens a multiparty direct message.
Expand source code
async def mpim_open( self, *, users: Union[str, Sequence[str]], **kwargs, ) -> AsyncSlackResponse: """This method opens a multiparty direct message.""" if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("mpim.open", params=kwargs)
async def mpim_replies(self, *, channel: str, thread_ts: str, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a thread of messages posted to a direct message conversation from a multiparty direct message.
Expand source code
async def mpim_replies( self, *, channel: str, thread_ts: str, **kwargs, ) -> AsyncSlackResponse: """Retrieve a thread of messages posted to a direct message conversation from a multiparty direct message. """ kwargs.update({"channel": channel, "thread_ts": thread_ts}) return await self.api_call("mpim.replies", http_verb="GET", params=kwargs)
async def oauth_access(self, *, client_id: str, client_secret: str, code: str, redirect_uri: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Exchanges a temporary OAuth verifier code for an access token. https://api.slack.com/methods/oauth.access
Expand source code
async def oauth_access( self, *, client_id: str, client_secret: str, code: str, redirect_uri: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Exchanges a temporary OAuth verifier code for an access token. https://api.slack.com/methods/oauth.access """ if redirect_uri is not None: kwargs.update({"redirect_uri": redirect_uri}) kwargs.update({"code": code}) return await self.api_call( "oauth.access", data=kwargs, auth={"client_id": client_id, "client_secret": client_secret}, )
async def oauth_v2_access(self, *, client_id: str, client_secret: str, code: Optional[str] = None, redirect_uri: Optional[str] = None, grant_type: Optional[str] = None, refresh_token: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Exchanges a temporary OAuth verifier code for an access token. https://api.slack.com/methods/oauth.v2.access
Expand source code
async def oauth_v2_access( self, *, client_id: str, client_secret: str, # This field is required when processing the OAuth redirect URL requests # while it's absent for token rotation code: Optional[str] = None, redirect_uri: Optional[str] = None, # This field is required for token rotation grant_type: Optional[str] = None, # This field is required for token rotation refresh_token: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Exchanges a temporary OAuth verifier code for an access token. https://api.slack.com/methods/oauth.v2.access """ if redirect_uri is not None: kwargs.update({"redirect_uri": redirect_uri}) if code is not None: kwargs.update({"code": code}) if grant_type is not None: kwargs.update({"grant_type": grant_type}) if refresh_token is not None: kwargs.update({"refresh_token": refresh_token}) return await self.api_call( "oauth.v2.access", data=kwargs, auth={"client_id": client_id, "client_secret": client_secret}, )
async def oauth_v2_exchange(self, *, token: str, client_id: str, client_secret: str, **kwargs) ‑> AsyncSlackResponse
-
Exchanges a legacy access token for a new expiring access token and refresh token https://api.slack.com/methods/oauth.v2.exchange
Expand source code
async def oauth_v2_exchange( self, *, token: str, client_id: str, client_secret: str, **kwargs, ) -> AsyncSlackResponse: """Exchanges a legacy access token for a new expiring access token and refresh token https://api.slack.com/methods/oauth.v2.exchange """ kwargs.update({"client_id": client_id, "client_secret": client_secret, "token": token}) return await self.api_call("oauth.v2.exchange", params=kwargs)
async def openid_connect_token(self, client_id: str, client_secret: str, code: Optional[str] = None, redirect_uri: Optional[str] = None, grant_type: Optional[str] = None, refresh_token: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Exchanges a temporary OAuth verifier code for an access token for Sign in with Slack. https://api.slack.com/methods/openid.connect.token
Expand source code
async def openid_connect_token( self, client_id: str, client_secret: str, code: Optional[str] = None, redirect_uri: Optional[str] = None, grant_type: Optional[str] = None, refresh_token: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Exchanges a temporary OAuth verifier code for an access token for Sign in with Slack. https://api.slack.com/methods/openid.connect.token """ if redirect_uri is not None: kwargs.update({"redirect_uri": redirect_uri}) if code is not None: kwargs.update({"code": code}) if grant_type is not None: kwargs.update({"grant_type": grant_type}) if refresh_token is not None: kwargs.update({"refresh_token": refresh_token}) return await self.api_call( "openid.connect.token", data=kwargs, auth={"client_id": client_id, "client_secret": client_secret}, )
async def openid_connect_userInfo(self, **kwargs) ‑> AsyncSlackResponse
-
Get the identity of a user who has authorized Sign in with Slack. https://api.slack.com/methods/openid.connect.userInfo
Expand source code
async def openid_connect_userInfo( self, **kwargs, ) -> AsyncSlackResponse: """Get the identity of a user who has authorized Sign in with Slack. https://api.slack.com/methods/openid.connect.userInfo """ return await self.api_call("openid.connect.userInfo", params=kwargs)
async def pins_add(self, *, channel: str, timestamp: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Pins an item to a channel. https://api.slack.com/methods/pins.add
Expand source code
async def pins_add( self, *, channel: str, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Pins an item to a channel. https://api.slack.com/methods/pins.add """ kwargs.update({"channel": channel, "timestamp": timestamp}) return await self.api_call("pins.add", params=kwargs)
async def pins_list(self, *, channel: str, **kwargs) ‑> AsyncSlackResponse
-
Lists items pinned to a channel. https://api.slack.com/methods/pins.list
Expand source code
async def pins_list( self, *, channel: str, **kwargs, ) -> AsyncSlackResponse: """Lists items pinned to a channel. https://api.slack.com/methods/pins.list """ kwargs.update({"channel": channel}) return await self.api_call("pins.list", http_verb="GET", params=kwargs)
async def pins_remove(self, *, channel: str, timestamp: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Un-pins an item from a channel. https://api.slack.com/methods/pins.remove
Expand source code
async def pins_remove( self, *, channel: str, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Un-pins an item from a channel. https://api.slack.com/methods/pins.remove """ kwargs.update({"channel": channel, "timestamp": timestamp}) return await self.api_call("pins.remove", params=kwargs)
async def reactions_add(self, *, channel: str, name: str, timestamp: str, **kwargs) ‑> AsyncSlackResponse
-
Adds a reaction to an item. https://api.slack.com/methods/reactions.add
Expand source code
async def reactions_add( self, *, channel: str, name: str, timestamp: str, **kwargs, ) -> AsyncSlackResponse: """Adds a reaction to an item. https://api.slack.com/methods/reactions.add """ kwargs.update({"channel": channel, "name": name, "timestamp": timestamp}) return await self.api_call("reactions.add", params=kwargs)
async def reactions_get(self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, full: Optional[bool] = None, timestamp: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets reactions for an item. https://api.slack.com/methods/reactions.get
Expand source code
async def reactions_get( self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, full: Optional[bool] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets reactions for an item. https://api.slack.com/methods/reactions.get """ kwargs.update( { "channel": channel, "file": file, "file_comment": file_comment, "full": full, "timestamp": timestamp, } ) return await self.api_call("reactions.get", http_verb="GET", params=kwargs)
async def reactions_list(self, *, count: Optional[int] = None, cursor: Optional[str] = None, full: Optional[bool] = None, limit: Optional[int] = None, page: Optional[int] = None, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists reactions made by a user. https://api.slack.com/methods/reactions.list
Expand source code
async def reactions_list( self, *, count: Optional[int] = None, cursor: Optional[str] = None, full: Optional[bool] = None, limit: Optional[int] = None, page: Optional[int] = None, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists reactions made by a user. https://api.slack.com/methods/reactions.list """ kwargs.update( { "count": count, "cursor": cursor, "full": full, "limit": limit, "page": page, "team_id": team_id, "user": user, } ) return await self.api_call("reactions.list", http_verb="GET", params=kwargs)
async def reactions_remove(self, *, name: str, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Removes a reaction from an item. https://api.slack.com/methods/reactions.remove
Expand source code
async def reactions_remove( self, *, name: str, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Removes a reaction from an item. https://api.slack.com/methods/reactions.remove """ kwargs.update( { "name": name, "channel": channel, "file": file, "file_comment": file_comment, "timestamp": timestamp, } ) return await self.api_call("reactions.remove", params=kwargs)
async def reminders_add(self, *, text: str, time: str, team_id: Optional[str] = None, user: Optional[str] = None, recurrence: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Creates a reminder. https://api.slack.com/methods/reminders.add
Expand source code
async def reminders_add( self, *, text: str, time: str, team_id: Optional[str] = None, user: Optional[str] = None, recurrence: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Creates a reminder. https://api.slack.com/methods/reminders.add """ kwargs.update( { "text": text, "time": time, "team_id": team_id, "user": user, "recurrence": recurrence, } ) return await self.api_call("reminders.add", params=kwargs)
async def reminders_complete(self, *, reminder: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Marks a reminder as complete. https://api.slack.com/methods/reminders.complete
Expand source code
async def reminders_complete( self, *, reminder: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Marks a reminder as complete. https://api.slack.com/methods/reminders.complete """ kwargs.update({"reminder": reminder, "team_id": team_id}) return await self.api_call("reminders.complete", params=kwargs)
async def reminders_delete(self, *, reminder: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Deletes a reminder. https://api.slack.com/methods/reminders.delete
Expand source code
async def reminders_delete( self, *, reminder: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Deletes a reminder. https://api.slack.com/methods/reminders.delete """ kwargs.update({"reminder": reminder, "team_id": team_id}) return await self.api_call("reminders.delete", params=kwargs)
async def reminders_info(self, *, reminder: str, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets information about a reminder. https://api.slack.com/methods/reminders.info
Expand source code
async def reminders_info( self, *, reminder: str, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a reminder. https://api.slack.com/methods/reminders.info """ kwargs.update({"reminder": reminder, "team_id": team_id}) return await self.api_call("reminders.info", http_verb="GET", params=kwargs)
async def reminders_list(self, *, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists all reminders created by or for a given user. https://api.slack.com/methods/reminders.list
Expand source code
async def reminders_list( self, *, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all reminders created by or for a given user. https://api.slack.com/methods/reminders.list """ kwargs.update({"team_id": team_id}) return await self.api_call("reminders.list", http_verb="GET", params=kwargs)
async def rtm_connect(self, *, batch_presence_aware: Optional[bool] = None, presence_sub: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Starts a Real Time Messaging session. https://api.slack.com/methods/rtm.connect
Expand source code
async def rtm_connect( self, *, batch_presence_aware: Optional[bool] = None, presence_sub: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Starts a Real Time Messaging session. https://api.slack.com/methods/rtm.connect """ kwargs.update({"batch_presence_aware": batch_presence_aware, "presence_sub": presence_sub}) return await self.api_call("rtm.connect", http_verb="GET", params=kwargs)
async def rtm_start(self, *, batch_presence_aware: Optional[bool] = None, include_locale: Optional[bool] = None, mpim_aware: Optional[bool] = None, no_latest: Optional[bool] = None, no_unreads: Optional[bool] = None, presence_sub: Optional[bool] = None, simple_latest: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Starts a Real Time Messaging session. https://api.slack.com/methods/rtm.start
Expand source code
async def rtm_start( self, *, batch_presence_aware: Optional[bool] = None, include_locale: Optional[bool] = None, mpim_aware: Optional[bool] = None, no_latest: Optional[bool] = None, no_unreads: Optional[bool] = None, presence_sub: Optional[bool] = None, simple_latest: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Starts a Real Time Messaging session. https://api.slack.com/methods/rtm.start """ kwargs.update( { "batch_presence_aware": batch_presence_aware, "include_locale": include_locale, "mpim_aware": mpim_aware, "no_latest": no_latest, "no_unreads": no_unreads, "presence_sub": presence_sub, "simple_latest": simple_latest, } ) return await self.api_call("rtm.start", http_verb="GET", params=kwargs)
async def search_all(self, *, query: str, count: Optional[int] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Searches for messages and files matching a query. https://api.slack.com/methods/search.all
Expand source code
async def search_all( self, *, query: str, count: Optional[int] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Searches for messages and files matching a query. https://api.slack.com/methods/search.all """ kwargs.update( { "query": query, "count": count, "highlight": highlight, "page": page, "sort": sort, "sort_dir": sort_dir, "team_id": team_id, } ) return await self.api_call("search.all", http_verb="GET", params=kwargs)
async def search_files(self, *, query: str, count: Optional[int] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Searches for files matching a query. https://api.slack.com/methods/search.files
Expand source code
async def search_files( self, *, query: str, count: Optional[int] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Searches for files matching a query. https://api.slack.com/methods/search.files """ kwargs.update( { "query": query, "count": count, "highlight": highlight, "page": page, "sort": sort, "sort_dir": sort_dir, "team_id": team_id, } ) return await self.api_call("search.files", http_verb="GET", params=kwargs)
async def search_messages(self, *, query: str, count: Optional[int] = None, cursor: Optional[str] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Searches for messages matching a query. https://api.slack.com/methods/search.messages
Expand source code
async def search_messages( self, *, query: str, count: Optional[int] = None, cursor: Optional[str] = None, highlight: Optional[bool] = None, page: Optional[int] = None, sort: Optional[str] = None, sort_dir: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Searches for messages matching a query. https://api.slack.com/methods/search.messages """ kwargs.update( { "query": query, "count": count, "cursor": cursor, "highlight": highlight, "page": page, "sort": sort, "sort_dir": sort_dir, "team_id": team_id, } ) return await self.api_call("search.messages", http_verb="GET", params=kwargs)
async def stars_add(self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Adds a star to an item. https://api.slack.com/methods/stars.add
Expand source code
async def stars_add( self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Adds a star to an item. https://api.slack.com/methods/stars.add """ kwargs.update( { "channel": channel, "file": file, "file_comment": file_comment, "timestamp": timestamp, } ) return await self.api_call("stars.add", params=kwargs)
async def stars_list(self, *, count: Optional[int] = None, cursor: Optional[str] = None, limit: Optional[int] = None, page: Optional[int] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists stars for a user. https://api.slack.com/methods/stars.list
Expand source code
async def stars_list( self, *, count: Optional[int] = None, cursor: Optional[str] = None, limit: Optional[int] = None, page: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists stars for a user. https://api.slack.com/methods/stars.list """ kwargs.update( { "count": count, "cursor": cursor, "limit": limit, "page": page, "team_id": team_id, } ) return await self.api_call("stars.list", http_verb="GET", params=kwargs)
async def stars_remove(self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Removes a star from an item. https://api.slack.com/methods/stars.remove
Expand source code
async def stars_remove( self, *, channel: Optional[str] = None, file: Optional[str] = None, file_comment: Optional[str] = None, timestamp: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Removes a star from an item. https://api.slack.com/methods/stars.remove """ kwargs.update( { "channel": channel, "file": file, "file_comment": file_comment, "timestamp": timestamp, } ) return await self.api_call("stars.remove", params=kwargs)
async def team_accessLogs(self, *, before: Union[str, int, ForwardRef(None)] = None, count: Union[str, int, ForwardRef(None)] = None, page: Union[str, int, ForwardRef(None)] = None, team_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets the access logs for the current team. https://api.slack.com/methods/team.accessLogs
Expand source code
async def team_accessLogs( self, *, before: Optional[Union[int, str]] = None, count: Optional[Union[int, str]] = None, page: Optional[Union[int, str]] = None, team_id: Optional[str] = None, cursor: Optional[str] = None, limit: Optional[int] = None, **kwargs, ) -> AsyncSlackResponse: """Gets the access logs for the current team. https://api.slack.com/methods/team.accessLogs """ kwargs.update( { "before": before, "count": count, "page": page, "team_id": team_id, "cursor": cursor, "limit": limit, } ) return await self.api_call("team.accessLogs", http_verb="GET", params=kwargs)
async def team_billableInfo(self, *, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets billable users information for the current team. https://api.slack.com/methods/team.billableInfo
Expand source code
async def team_billableInfo( self, *, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets billable users information for the current team. https://api.slack.com/methods/team.billableInfo """ kwargs.update({"team_id": team_id, "user": user}) return await self.api_call("team.billableInfo", http_verb="GET", params=kwargs)
async def team_billing_info(self, **kwargs) ‑> AsyncSlackResponse
-
Reads a workspace's billing plan information. https://api.slack.com/methods/team.billing.info
Expand source code
async def team_billing_info( self, **kwargs, ) -> AsyncSlackResponse: """Reads a workspace's billing plan information. https://api.slack.com/methods/team.billing.info """ return await self.api_call("team.billing.info", params=kwargs)
async def team_info(self, *, team: Optional[str] = None, domain: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets information about the current team. https://api.slack.com/methods/team.info
Expand source code
async def team_info( self, *, team: Optional[str] = None, domain: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about the current team. https://api.slack.com/methods/team.info """ kwargs.update({"team": team, "domain": domain}) return await self.api_call("team.info", http_verb="GET", params=kwargs)
async def team_integrationLogs(self, *, app_id: Optional[str] = None, change_type: Optional[str] = None, count: Union[str, int, ForwardRef(None)] = None, page: Union[str, int, ForwardRef(None)] = None, service_id: Optional[str] = None, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets the integration logs for the current team. https://api.slack.com/methods/team.integrationLogs
Expand source code
async def team_integrationLogs( self, *, app_id: Optional[str] = None, change_type: Optional[str] = None, count: Optional[Union[int, str]] = None, page: Optional[Union[int, str]] = None, service_id: Optional[str] = None, team_id: Optional[str] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Gets the integration logs for the current team. https://api.slack.com/methods/team.integrationLogs """ kwargs.update( { "app_id": app_id, "change_type": change_type, "count": count, "page": page, "service_id": service_id, "team_id": team_id, "user": user, } ) return await self.api_call("team.integrationLogs", http_verb="GET", params=kwargs)
async def team_preferences_list(self, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a list of a workspace's team preferences. https://api.slack.com/methods/team.preferences.list
Expand source code
async def team_preferences_list( self, **kwargs, ) -> AsyncSlackResponse: """Retrieve a list of a workspace's team preferences. https://api.slack.com/methods/team.preferences.list """ return await self.api_call("team.preferences.list", params=kwargs)
async def team_profile_get(self, *, visibility: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieve a team's profile. https://api.slack.com/methods/team.profile.get
Expand source code
async def team_profile_get( self, *, visibility: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieve a team's profile. https://api.slack.com/methods/team.profile.get """ kwargs.update({"visibility": visibility}) return await self.api_call("team.profile.get", http_verb="GET", params=kwargs)
async def usergroups_create(self, *, name: str, channels: Union[str, Sequence[str], ForwardRef(None)] = None, description: Optional[str] = None, handle: Optional[str] = None, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Create a User Group https://api.slack.com/methods/usergroups.create
Expand source code
async def usergroups_create( self, *, name: str, channels: Optional[Union[str, Sequence[str]]] = None, description: Optional[str] = None, handle: Optional[str] = None, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Create a User Group https://api.slack.com/methods/usergroups.create """ kwargs.update( { "name": name, "description": description, "handle": handle, "include_count": include_count, "team_id": team_id, } ) if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) return await self.api_call("usergroups.create", params=kwargs)
async def usergroups_disable(self, *, usergroup: str, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Disable an existing User Group https://api.slack.com/methods/usergroups.disable
Expand source code
async def usergroups_disable( self, *, usergroup: str, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Disable an existing User Group https://api.slack.com/methods/usergroups.disable """ kwargs.update({"usergroup": usergroup, "include_count": include_count, "team_id": team_id}) return await self.api_call("usergroups.disable", params=kwargs)
async def usergroups_enable(self, *, usergroup: str, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Enable a User Group https://api.slack.com/methods/usergroups.enable
Expand source code
async def usergroups_enable( self, *, usergroup: str, include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Enable a User Group https://api.slack.com/methods/usergroups.enable """ kwargs.update({"usergroup": usergroup, "include_count": include_count, "team_id": team_id}) return await self.api_call("usergroups.enable", params=kwargs)
async def usergroups_list(self, *, include_count: Optional[bool] = None, include_disabled: Optional[bool] = None, include_users: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List all User Groups for a team https://api.slack.com/methods/usergroups.list
Expand source code
async def usergroups_list( self, *, include_count: Optional[bool] = None, include_disabled: Optional[bool] = None, include_users: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all User Groups for a team https://api.slack.com/methods/usergroups.list """ kwargs.update( { "include_count": include_count, "include_disabled": include_disabled, "include_users": include_users, "team_id": team_id, } ) return await self.api_call("usergroups.list", http_verb="GET", params=kwargs)
async def usergroups_update(self, *, usergroup: str, channels: Union[str, Sequence[str], ForwardRef(None)] = None, description: Optional[str] = None, handle: Optional[str] = None, include_count: Optional[bool] = None, name: Optional[str] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Update an existing User Group https://api.slack.com/methods/usergroups.update
Expand source code
async def usergroups_update( self, *, usergroup: str, channels: Optional[Union[str, Sequence[str]]] = None, description: Optional[str] = None, handle: Optional[str] = None, include_count: Optional[bool] = None, name: Optional[str] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Update an existing User Group https://api.slack.com/methods/usergroups.update """ kwargs.update( { "usergroup": usergroup, "description": description, "handle": handle, "include_count": include_count, "name": name, "team_id": team_id, } ) if isinstance(channels, (list, Tuple)): kwargs.update({"channels": ",".join(channels)}) else: kwargs.update({"channels": channels}) return await self.api_call("usergroups.update", params=kwargs)
async def usergroups_users_list(self, *, usergroup: str, include_disabled: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List all users in a User Group https://api.slack.com/methods/usergroups.users.list
Expand source code
async def usergroups_users_list( self, *, usergroup: str, include_disabled: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List all users in a User Group https://api.slack.com/methods/usergroups.users.list """ kwargs.update( { "usergroup": usergroup, "include_disabled": include_disabled, "team_id": team_id, } ) return await self.api_call("usergroups.users.list", http_verb="GET", params=kwargs)
async def usergroups_users_update(self, *, usergroup: str, users: Union[str, Sequence[str]], include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Update the list of users for a User Group https://api.slack.com/methods/usergroups.users.update
Expand source code
async def usergroups_users_update( self, *, usergroup: str, users: Union[str, Sequence[str]], include_count: Optional[bool] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Update the list of users for a User Group https://api.slack.com/methods/usergroups.users.update """ kwargs.update( { "usergroup": usergroup, "include_count": include_count, "team_id": team_id, } ) if isinstance(users, (list, Tuple)): kwargs.update({"users": ",".join(users)}) else: kwargs.update({"users": users}) return await self.api_call("usergroups.users.update", params=kwargs)
async def users_conversations(self, *, cursor: Optional[str] = None, exclude_archived: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, types: Union[str, Sequence[str], ForwardRef(None)] = None, user: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
List conversations the calling user may access. https://api.slack.com/methods/users.conversations
Expand source code
async def users_conversations( self, *, cursor: Optional[str] = None, exclude_archived: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, types: Optional[Union[str, Sequence[str]]] = None, user: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """List conversations the calling user may access. https://api.slack.com/methods/users.conversations """ kwargs.update( { "cursor": cursor, "exclude_archived": exclude_archived, "limit": limit, "team_id": team_id, "user": user, } ) if isinstance(types, (list, Tuple)): kwargs.update({"types": ",".join(types)}) else: kwargs.update({"types": types}) return await self.api_call("users.conversations", http_verb="GET", params=kwargs)
async def users_deletePhoto(self, **kwargs) ‑> AsyncSlackResponse
-
Delete the user profile photo https://api.slack.com/methods/users.deletePhoto
Expand source code
async def users_deletePhoto( self, **kwargs, ) -> AsyncSlackResponse: """Delete the user profile photo https://api.slack.com/methods/users.deletePhoto """ return await self.api_call("users.deletePhoto", http_verb="GET", params=kwargs)
async def users_getPresence(self, *, user: str, **kwargs) ‑> AsyncSlackResponse
-
Gets user presence information. https://api.slack.com/methods/users.getPresence
Expand source code
async def users_getPresence( self, *, user: str, **kwargs, ) -> AsyncSlackResponse: """Gets user presence information. https://api.slack.com/methods/users.getPresence """ kwargs.update({"user": user}) return await self.api_call("users.getPresence", http_verb="GET", params=kwargs)
async def users_identity(self, **kwargs) ‑> AsyncSlackResponse
-
Get a user's identity. https://api.slack.com/methods/users.identity
Expand source code
async def users_identity( self, **kwargs, ) -> AsyncSlackResponse: """Get a user's identity. https://api.slack.com/methods/users.identity """ return await self.api_call("users.identity", http_verb="GET", params=kwargs)
async def users_info(self, *, user: str, include_locale: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Gets information about a user. https://api.slack.com/methods/users.info
Expand source code
async def users_info( self, *, user: str, include_locale: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Gets information about a user. https://api.slack.com/methods/users.info """ kwargs.update({"user": user, "include_locale": include_locale}) return await self.api_call("users.info", http_verb="GET", params=kwargs)
async def users_list(self, *, cursor: Optional[str] = None, include_locale: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Lists all users in a Slack team. https://api.slack.com/methods/users.list
Expand source code
async def users_list( self, *, cursor: Optional[str] = None, include_locale: Optional[bool] = None, limit: Optional[int] = None, team_id: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Lists all users in a Slack team. https://api.slack.com/methods/users.list """ kwargs.update( { "cursor": cursor, "include_locale": include_locale, "limit": limit, "team_id": team_id, } ) return await self.api_call("users.list", http_verb="GET", params=kwargs)
async def users_lookupByEmail(self, *, email: str, **kwargs) ‑> AsyncSlackResponse
-
Find a user with an email address. https://api.slack.com/methods/users.lookupByEmail
Expand source code
async def users_lookupByEmail( self, *, email: str, **kwargs, ) -> AsyncSlackResponse: """Find a user with an email address. https://api.slack.com/methods/users.lookupByEmail """ kwargs.update({"email": email}) return await self.api_call("users.lookupByEmail", http_verb="GET", params=kwargs)
async def users_profile_get(self, *, user: Optional[str] = None, include_labels: Optional[bool] = None, **kwargs) ‑> AsyncSlackResponse
-
Retrieves a user's profile information. https://api.slack.com/methods/users.profile.get
Expand source code
async def users_profile_get( self, *, user: Optional[str] = None, include_labels: Optional[bool] = None, **kwargs, ) -> AsyncSlackResponse: """Retrieves a user's profile information. https://api.slack.com/methods/users.profile.get """ kwargs.update({"user": user, "include_labels": include_labels}) return await self.api_call("users.profile.get", http_verb="GET", params=kwargs)
async def users_profile_set(self, *, name: Optional[str] = None, value: Optional[str] = None, user: Optional[str] = None, profile: Optional[Dict] = None, **kwargs) ‑> AsyncSlackResponse
-
Set the profile information for a user. https://api.slack.com/methods/users.profile.set
Expand source code
async def users_profile_set( self, *, name: Optional[str] = None, value: Optional[str] = None, user: Optional[str] = None, profile: Optional[Dict] = None, **kwargs, ) -> AsyncSlackResponse: """Set the profile information for a user. https://api.slack.com/methods/users.profile.set """ kwargs.update( { "name": name, "profile": profile, "user": user, "value": value, } ) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "profile" parameter return await self.api_call("users.profile.set", json=kwargs)
async def users_setPhoto(self, *, image: Union[str, io.IOBase], crop_w: Union[str, int, ForwardRef(None)] = None, crop_x: Union[str, int, ForwardRef(None)] = None, crop_y: Union[str, int, ForwardRef(None)] = None, **kwargs) ‑> AsyncSlackResponse
-
Set the user profile photo https://api.slack.com/methods/users.setPhoto
Expand source code
async def users_setPhoto( self, *, image: Union[str, IOBase], crop_w: Optional[Union[int, str]] = None, crop_x: Optional[Union[int, str]] = None, crop_y: Optional[Union[int, str]] = None, **kwargs, ) -> AsyncSlackResponse: """Set the user profile photo https://api.slack.com/methods/users.setPhoto """ kwargs.update({"crop_w": crop_w, "crop_x": crop_x, "crop_y": crop_y}) return await self.api_call("users.setPhoto", files={"image": image}, data=kwargs)
async def users_setPresence(self, *, presence: str, **kwargs) ‑> AsyncSlackResponse
-
Manually sets user presence. https://api.slack.com/methods/users.setPresence
Expand source code
async def users_setPresence( self, *, presence: str, **kwargs, ) -> AsyncSlackResponse: """Manually sets user presence. https://api.slack.com/methods/users.setPresence """ kwargs.update({"presence": presence}) return await self.api_call("users.setPresence", params=kwargs)
async def views_open(self, *, trigger_id: str, view: Union[dict, View], **kwargs) ‑> AsyncSlackResponse
-
Open a view for a user. https://api.slack.com/methods/views.open See https://api.slack.com/block-kit/surfaces/modals for details.
Expand source code
async def views_open( self, *, trigger_id: str, view: Union[dict, View], **kwargs, ) -> AsyncSlackResponse: """Open a view for a user. https://api.slack.com/methods/views.open See https://api.slack.com/block-kit/surfaces/modals for details. """ kwargs.update({"trigger_id": trigger_id}) if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.open", json=kwargs)
async def views_publish(self, *, user_id: str, view: Union[dict, View], hash: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Publish a static view for a User. Create or update the view that comprises an app's Home tab (https://api.slack.com/surfaces/tabs) https://api.slack.com/methods/views.publish
Expand source code
async def views_publish( self, *, user_id: str, view: Union[dict, View], hash: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Publish a static view for a User. Create or update the view that comprises an app's Home tab (https://api.slack.com/surfaces/tabs) https://api.slack.com/methods/views.publish """ kwargs.update({"user_id": user_id, "hash": hash}) if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.publish", json=kwargs)
async def views_push(self, *, trigger_id: str, view: Union[dict, View], **kwargs) ‑> AsyncSlackResponse
-
Push a view onto the stack of a root view. Push a new view onto the existing view stack by passing a view payload and a valid trigger_id generated from an interaction within the existing modal. Read the modals documentation (https://api.slack.com/block-kit/surfaces/modals) to learn more about the lifecycle and intricacies of views. https://api.slack.com/methods/views.push
Expand source code
async def views_push( self, *, trigger_id: str, view: Union[dict, View], **kwargs, ) -> AsyncSlackResponse: """Push a view onto the stack of a root view. Push a new view onto the existing view stack by passing a view payload and a valid trigger_id generated from an interaction within the existing modal. Read the modals documentation (https://api.slack.com/block-kit/surfaces/modals) to learn more about the lifecycle and intricacies of views. https://api.slack.com/methods/views.push """ kwargs.update({"trigger_id": trigger_id}) if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.push", json=kwargs)
async def views_update(self, *, view: Union[dict, View], external_id: Optional[str] = None, view_id: Optional[str] = None, hash: Optional[str] = None, **kwargs) ‑> AsyncSlackResponse
-
Update an existing view. Update a view by passing a new view definition along with the view_id returned in views.open or the external_id. See the modals documentation (https://api.slack.com/block-kit/surfaces/modals#updating_views) to learn more about updating views and avoiding race conditions with the hash argument. https://api.slack.com/methods/views.update
Expand source code
async def views_update( self, *, view: Union[dict, View], external_id: Optional[str] = None, view_id: Optional[str] = None, hash: Optional[str] = None, **kwargs, ) -> AsyncSlackResponse: """Update an existing view. Update a view by passing a new view definition along with the view_id returned in views.open or the external_id. See the modals documentation (https://api.slack.com/block-kit/surfaces/modals#updating_views) to learn more about updating views and avoiding race conditions with the hash argument. https://api.slack.com/methods/views.update """ if isinstance(view, View): kwargs.update({"view": view.to_dict()}) else: kwargs.update({"view": view}) if external_id: kwargs.update({"external_id": external_id}) elif view_id: kwargs.update({"view_id": view_id}) else: raise e.SlackRequestError("Either view_id or external_id is required.") kwargs.update({"hash": hash}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "view" parameter return await self.api_call("views.update", json=kwargs)
async def workflows_stepCompleted(self, *, workflow_step_execute_id: str, outputs: Optional[dict] = None, **kwargs) ‑> AsyncSlackResponse
-
Indicate a successful outcome of a workflow step's execution. https://api.slack.com/methods/workflows.stepCompleted
Expand source code
async def workflows_stepCompleted( self, *, workflow_step_execute_id: str, outputs: Optional[dict] = None, **kwargs, ) -> AsyncSlackResponse: """Indicate a successful outcome of a workflow step's execution. https://api.slack.com/methods/workflows.stepCompleted """ kwargs.update({"workflow_step_execute_id": workflow_step_execute_id}) if outputs is not None: kwargs.update({"outputs": outputs}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "outputs" parameter return await self.api_call("workflows.stepCompleted", json=kwargs)
async def workflows_stepFailed(self, *, workflow_step_execute_id: str, error: Dict[str, str], **kwargs) ‑> AsyncSlackResponse
-
Indicate an unsuccessful outcome of a workflow step's execution. https://api.slack.com/methods/workflows.stepFailed
Expand source code
async def workflows_stepFailed( self, *, workflow_step_execute_id: str, error: Dict[str, str], **kwargs, ) -> AsyncSlackResponse: """Indicate an unsuccessful outcome of a workflow step's execution. https://api.slack.com/methods/workflows.stepFailed """ kwargs.update( { "workflow_step_execute_id": workflow_step_execute_id, "error": error, } ) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "error" parameter return await self.api_call("workflows.stepFailed", json=kwargs)
async def workflows_updateStep(self, *, workflow_step_edit_id: str, inputs: Optional[Dict[str, Any]] = None, outputs: Optional[List[Dict[str, str]]] = None, **kwargs) ‑> AsyncSlackResponse
-
Update the configuration for a workflow extension step. https://api.slack.com/methods/workflows.updateStep
Expand source code
async def workflows_updateStep( self, *, workflow_step_edit_id: str, inputs: Optional[Dict[str, Any]] = None, outputs: Optional[List[Dict[str, str]]] = None, **kwargs, ) -> AsyncSlackResponse: """Update the configuration for a workflow extension step. https://api.slack.com/methods/workflows.updateStep """ kwargs.update({"workflow_step_edit_id": workflow_step_edit_id}) if inputs is not None: kwargs.update({"inputs": inputs}) if outputs is not None: kwargs.update({"outputs": outputs}) kwargs = _remove_none_values(kwargs) # NOTE: Intentionally using json for the "inputs" / "outputs" parameters return await self.api_call("workflows.updateStep", json=kwargs)
Inherited members