Skip to content

Commit 40f7a57

Browse files
feat: add new conversations.externalInvitePermissions.set API (#1517)
Co-authored-by: Kazuhiro Sera <[email protected]>
1 parent e64677b commit 40f7a57

File tree

5 files changed

+88
-2
lines changed

5 files changed

+88
-2
lines changed

integration_tests/web/test_conversations_connect.py

Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,10 @@ def test_sync(self):
4545
channel_id: Optional[str] = None
4646

4747
try:
48+
auth_test: SlackResponse = receiver.auth_test()
49+
self.assertIsNotNone(auth_test["team_id"])
50+
connect_team_id = auth_test["team_id"]
51+
4852
# list senders pending connect invites
4953
connect_invites: SlackResponse = sender.conversations_listConnectInvites()
5054
self.assertIsNotNone(connect_invites["invites"])
@@ -76,6 +80,21 @@ def test_sync(self):
7680
receiver.conversations_approveSharedInvite,
7781
invite_id=invite["invite_id"],
7882
)
83+
84+
sender_approval = sender.conversations_approveSharedInvite(
85+
invite_id=invite["invite_id"], team_id=connect_team_id
86+
)
87+
self.assertIsNone(sender_approval["error"])
88+
89+
downgrade = sender.conversations_externalInvitePermissions_set(
90+
channel=channel_id, target_team=connect_team_id, action="downgrade"
91+
)
92+
self.assertIsNone(downgrade["error"])
93+
94+
upgrade = sender.conversations_externalInvitePermissions_set(
95+
channel=channel_id, target_team=connect_team_id, action="upgrade"
96+
)
97+
self.assertIsNone(upgrade["error"])
7998
finally:
8099
if channel_id is not None:
81100
# clean up created channel
@@ -89,6 +108,10 @@ async def test_async(self):
89108
channel_id: Optional[str] = None
90109

91110
try:
111+
auth_test: SlackResponse = await receiver.auth_test()
112+
self.assertIsNotNone(auth_test["team_id"])
113+
connect_team_id = auth_test["team_id"]
114+
92115
# list senders pending connect invites
93116
connect_invites: SlackResponse = await sender.conversations_listConnectInvites()
94117
self.assertIsNotNone(connect_invites["invites"])
@@ -117,6 +140,21 @@ async def test_async(self):
117140
# receiver attempt to approve invite already accepted by an admin level token should fail
118141
with self.assertRaises(SlackApiError):
119142
await receiver.conversations_approveSharedInvite(invite_id=invite["invite_id"])
143+
144+
sender_approval = await sender.conversations_approveSharedInvite(
145+
invite_id=invite["invite_id"], team_id=connect_team_id
146+
)
147+
self.assertIsNone(sender_approval["error"])
148+
149+
downgrade = await sender.conversations_externalInvitePermissions_set(
150+
channel=channel_id, target_team=connect_team_id, action="downgrade"
151+
)
152+
self.assertIsNone(downgrade["error"])
153+
154+
upgrade = await sender.conversations_externalInvitePermissions_set(
155+
channel=channel_id, target_team=connect_team_id, action="upgrade"
156+
)
157+
self.assertIsNone(upgrade["error"])
120158
finally:
121159
if channel_id is not None:
122160
# clean up created channel

slack_sdk/web/async_client.py

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2912,6 +2912,21 @@ async def conversations_declineSharedInvite(
29122912
kwargs.update({"invite_id": invite_id, "target_team": target_team})
29132913
return await self.api_call("conversations.declineSharedInvite", http_verb="GET", params=kwargs)
29142914

2915+
async def conversations_externalInvitePermissions_set(
2916+
self, *, action: str, channel: str, target_team: str, **kwargs
2917+
) -> AsyncSlackResponse:
2918+
"""Sets a team in a shared External Limited channel to a shared Slack Connect channel or vice versa.
2919+
https://api.slack.com/methods/conversations.externalInvitePermissions.set
2920+
"""
2921+
kwargs.update(
2922+
{
2923+
"action": action,
2924+
"channel": channel,
2925+
"target_team": target_team,
2926+
}
2927+
)
2928+
return await self.api_call("conversations.externalInvitePermissions.set", params=kwargs)
2929+
29152930
async def conversations_history(
29162931
self,
29172932
*,

slack_sdk/web/client.py

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2903,6 +2903,21 @@ def conversations_declineSharedInvite(
29032903
kwargs.update({"invite_id": invite_id, "target_team": target_team})
29042904
return self.api_call("conversations.declineSharedInvite", http_verb="GET", params=kwargs)
29052905

2906+
def conversations_externalInvitePermissions_set(
2907+
self, *, action: str, channel: str, target_team: str, **kwargs
2908+
) -> SlackResponse:
2909+
"""Sets a team in a shared External Limited channel to a shared Slack Connect channel or vice versa.
2910+
https://api.slack.com/methods/conversations.externalInvitePermissions.set
2911+
"""
2912+
kwargs.update(
2913+
{
2914+
"action": action,
2915+
"channel": channel,
2916+
"target_team": target_team,
2917+
}
2918+
)
2919+
return self.api_call("conversations.externalInvitePermissions.set", params=kwargs)
2920+
29062921
def conversations_history(
29072922
self,
29082923
*,

slack_sdk/web/legacy_client.py

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2914,6 +2914,21 @@ def conversations_declineSharedInvite(
29142914
kwargs.update({"invite_id": invite_id, "target_team": target_team})
29152915
return self.api_call("conversations.declineSharedInvite", http_verb="GET", params=kwargs)
29162916

2917+
def conversations_externalInvitePermissions_set(
2918+
self, *, action: str, channel: str, target_team: str, **kwargs
2919+
) -> Union[Future, SlackResponse]:
2920+
"""Sets a team in a shared External Limited channel to a shared Slack Connect channel or vice versa.
2921+
https://api.slack.com/methods/conversations.externalInvitePermissions.set
2922+
"""
2923+
kwargs.update(
2924+
{
2925+
"action": action,
2926+
"channel": channel,
2927+
"target_team": target_team,
2928+
}
2929+
)
2930+
return self.api_call("conversations.externalInvitePermissions.set", params=kwargs)
2931+
29172932
def conversations_history(
29182933
self,
29192934
*,

tests/slack_sdk_async/web/test_web_client_coverage.py

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -15,9 +15,9 @@
1515

1616

1717
class TestWebClientCoverage(unittest.TestCase):
18-
# 284 endpoints as of June 19, 2024
18+
# 285 endpoints as of June 25, 2024
1919
# Can be fetched by running `var methodNames = [].slice.call(document.getElementsByClassName('apiReferenceFilterableList__listItemLink')).map(e => e.href.replace("https://api.slack.com/methods/", ""));console.log(methodNames.toString());console.log(methodNames.length);` on https://api.slack.com/methods
20-
all_api_methods = "admin.analytics.getFile,admin.apps.activities.list,admin.apps.approve,admin.apps.clearResolution,admin.apps.restrict,admin.apps.uninstall,admin.apps.approved.list,admin.apps.config.lookup,admin.apps.config.set,admin.apps.requests.cancel,admin.apps.requests.list,admin.apps.restricted.list,admin.audit.anomaly.allow.getItem,admin.audit.anomaly.allow.updateItem,admin.auth.policy.assignEntities,admin.auth.policy.getEntities,admin.auth.policy.removeEntities,admin.barriers.create,admin.barriers.delete,admin.barriers.list,admin.barriers.update,admin.conversations.archive,admin.conversations.bulkArchive,admin.conversations.bulkDelete,admin.conversations.bulkMove,admin.conversations.convertToPrivate,admin.conversations.convertToPublic,admin.conversations.create,admin.conversations.delete,admin.conversations.disconnectShared,admin.conversations.getConversationPrefs,admin.conversations.getCustomRetention,admin.conversations.getTeams,admin.conversations.invite,admin.conversations.lookup,admin.conversations.removeCustomRetention,admin.conversations.rename,admin.conversations.search,admin.conversations.setConversationPrefs,admin.conversations.setCustomRetention,admin.conversations.setTeams,admin.conversations.unarchive,admin.conversations.ekm.listOriginalConnectedChannelInfo,admin.conversations.restrictAccess.addGroup,admin.conversations.restrictAccess.listGroups,admin.conversations.restrictAccess.removeGroup,admin.emoji.add,admin.emoji.addAlias,admin.emoji.list,admin.emoji.remove,admin.emoji.rename,admin.functions.list,admin.functions.permissions.lookup,admin.functions.permissions.set,admin.inviteRequests.approve,admin.inviteRequests.deny,admin.inviteRequests.list,admin.inviteRequests.approved.list,admin.inviteRequests.denied.list,admin.roles.addAssignments,admin.roles.listAssignments,admin.roles.removeAssignments,admin.teams.admins.list,admin.teams.create,admin.teams.list,admin.teams.owners.list,admin.teams.settings.info,admin.teams.settings.setDefaultChannels,admin.teams.settings.setDescription,admin.teams.settings.setDiscoverability,admin.teams.settings.setIcon,admin.teams.settings.setName,admin.usergroups.addChannels,admin.usergroups.addTeams,admin.usergroups.listChannels,admin.usergroups.removeChannels,admin.users.assign,admin.users.invite,admin.users.list,admin.users.remove,admin.users.setAdmin,admin.users.setExpiration,admin.users.setOwner,admin.users.setRegular,admin.users.session.clearSettings,admin.users.session.getSettings,admin.users.session.invalidate,admin.users.session.list,admin.users.session.reset,admin.users.session.resetBulk,admin.users.session.setSettings,admin.users.unsupportedVersions.export,admin.workflows.collaborators.add,admin.workflows.collaborators.remove,admin.workflows.permissions.lookup,admin.workflows.search,admin.workflows.unpublish,admin.workflows.triggers.types.permissions.lookup,admin.workflows.triggers.types.permissions.set,api.test,apps.activities.list,apps.auth.external.delete,apps.auth.external.get,apps.connections.open,apps.uninstall,apps.datastore.bulkDelete,apps.datastore.bulkGet,apps.datastore.bulkPut,apps.datastore.count,apps.datastore.delete,apps.datastore.get,apps.datastore.put,apps.datastore.query,apps.datastore.update,apps.event.authorizations.list,apps.manifest.create,apps.manifest.delete,apps.manifest.export,apps.manifest.update,apps.manifest.validate,auth.revoke,auth.test,auth.teams.list,bookmarks.add,bookmarks.edit,bookmarks.list,bookmarks.remove,bots.info,calls.add,calls.end,calls.info,calls.update,calls.participants.add,calls.participants.remove,canvases.access.delete,canvases.access.set,canvases.create,canvases.delete,canvases.edit,canvases.sections.lookup,chat.delete,chat.deleteScheduledMessage,chat.getPermalink,chat.meMessage,chat.postEphemeral,chat.postMessage,chat.scheduleMessage,chat.unfurl,chat.update,chat.scheduledMessages.list,conversations.acceptSharedInvite,conversations.approveSharedInvite,conversations.archive,conversations.close,conversations.create,conversations.declineSharedInvite,conversations.history,conversations.info,conversations.invite,conversations.inviteShared,conversations.join,conversations.kick,conversations.leave,conversations.list,conversations.listConnectInvites,conversations.mark,conversations.members,conversations.open,conversations.rename,conversations.replies,conversations.setPurpose,conversations.setTopic,conversations.unarchive,conversations.canvases.create,dialog.open,dnd.endDnd,dnd.endSnooze,dnd.info,dnd.setSnooze,dnd.teamInfo,emoji.list,files.completeUploadExternal,files.delete,files.getUploadURLExternal,files.info,files.list,files.revokePublicURL,files.sharedPublicURL,files.upload,files.comments.delete,files.remote.add,files.remote.info,files.remote.list,files.remote.remove,files.remote.share,files.remote.update,functions.completeError,functions.completeSuccess,functions.distributions.permissions.add,functions.distributions.permissions.list,functions.distributions.permissions.remove,functions.distributions.permissions.set,functions.workflows.steps.list,functions.workflows.steps.responses.export,migration.exchange,oauth.access,oauth.v2.access,oauth.v2.exchange,openid.connect.token,openid.connect.userInfo,pins.add,pins.list,pins.remove,reactions.add,reactions.get,reactions.list,reactions.remove,reminders.add,reminders.complete,reminders.delete,reminders.info,reminders.list,rtm.connect,rtm.start,search.all,search.files,search.messages,stars.add,stars.list,stars.remove,team.accessLogs,team.billableInfo,team.info,team.integrationLogs,team.billing.info,team.externalTeams.list,team.preferences.list,team.profile.get,tooling.tokens.rotate,usergroups.create,usergroups.disable,usergroups.enable,usergroups.list,usergroups.update,usergroups.users.list,usergroups.users.update,users.conversations,users.deletePhoto,users.getPresence,users.identity,users.info,users.list,users.lookupByEmail,users.setActive,users.setPhoto,users.setPresence,users.profile.get,users.profile.set,views.open,views.publish,views.push,views.update,workflows.stepCompleted,workflows.stepFailed,workflows.updateStep,workflows.triggers.permissions.add,workflows.triggers.permissions.list,workflows.triggers.permissions.remove,workflows.triggers.permissions.set,channels.create,channels.info,channels.invite,channels.mark,groups.create,groups.info,groups.invite,groups.mark,groups.open,im.list,im.mark,im.open,mpim.list,mpim.mark,mpim.open".split(
20+
all_api_methods = "admin.analytics.getFile,admin.apps.activities.list,admin.apps.approve,admin.apps.clearResolution,admin.apps.restrict,admin.apps.uninstall,admin.apps.approved.list,admin.apps.config.lookup,admin.apps.config.set,admin.apps.requests.cancel,admin.apps.requests.list,admin.apps.restricted.list,admin.audit.anomaly.allow.getItem,admin.audit.anomaly.allow.updateItem,admin.auth.policy.assignEntities,admin.auth.policy.getEntities,admin.auth.policy.removeEntities,admin.barriers.create,admin.barriers.delete,admin.barriers.list,admin.barriers.update,admin.conversations.archive,admin.conversations.bulkArchive,admin.conversations.bulkDelete,admin.conversations.bulkMove,admin.conversations.convertToPrivate,admin.conversations.convertToPublic,admin.conversations.create,admin.conversations.delete,admin.conversations.disconnectShared,admin.conversations.getConversationPrefs,admin.conversations.getCustomRetention,admin.conversations.getTeams,admin.conversations.invite,admin.conversations.lookup,admin.conversations.removeCustomRetention,admin.conversations.rename,admin.conversations.search,admin.conversations.setConversationPrefs,admin.conversations.setCustomRetention,admin.conversations.setTeams,admin.conversations.unarchive,admin.conversations.ekm.listOriginalConnectedChannelInfo,admin.conversations.restrictAccess.addGroup,admin.conversations.restrictAccess.listGroups,admin.conversations.restrictAccess.removeGroup,admin.emoji.add,admin.emoji.addAlias,admin.emoji.list,admin.emoji.remove,admin.emoji.rename,admin.functions.list,admin.functions.permissions.lookup,admin.functions.permissions.set,admin.inviteRequests.approve,admin.inviteRequests.deny,admin.inviteRequests.list,admin.inviteRequests.approved.list,admin.inviteRequests.denied.list,admin.roles.addAssignments,admin.roles.listAssignments,admin.roles.removeAssignments,admin.teams.admins.list,admin.teams.create,admin.teams.list,admin.teams.owners.list,admin.teams.settings.info,admin.teams.settings.setDefaultChannels,admin.teams.settings.setDescription,admin.teams.settings.setDiscoverability,admin.teams.settings.setIcon,admin.teams.settings.setName,admin.usergroups.addChannels,admin.usergroups.addTeams,admin.usergroups.listChannels,admin.usergroups.removeChannels,admin.users.assign,admin.users.invite,admin.users.list,admin.users.remove,admin.users.setAdmin,admin.users.setExpiration,admin.users.setOwner,admin.users.setRegular,admin.users.session.clearSettings,admin.users.session.getSettings,admin.users.session.invalidate,admin.users.session.list,admin.users.session.reset,admin.users.session.resetBulk,admin.users.session.setSettings,admin.users.unsupportedVersions.export,admin.workflows.collaborators.add,admin.workflows.collaborators.remove,admin.workflows.permissions.lookup,admin.workflows.search,admin.workflows.unpublish,admin.workflows.triggers.types.permissions.lookup,admin.workflows.triggers.types.permissions.set,api.test,apps.activities.list,apps.auth.external.delete,apps.auth.external.get,apps.connections.open,apps.uninstall,apps.datastore.bulkDelete,apps.datastore.bulkGet,apps.datastore.bulkPut,apps.datastore.count,apps.datastore.delete,apps.datastore.get,apps.datastore.put,apps.datastore.query,apps.datastore.update,apps.event.authorizations.list,apps.manifest.create,apps.manifest.delete,apps.manifest.export,apps.manifest.update,apps.manifest.validate,auth.revoke,auth.test,auth.teams.list,bookmarks.add,bookmarks.edit,bookmarks.list,bookmarks.remove,bots.info,calls.add,calls.end,calls.info,calls.update,calls.participants.add,calls.participants.remove,canvases.access.delete,canvases.access.set,canvases.create,canvases.delete,canvases.edit,canvases.sections.lookup,chat.delete,chat.deleteScheduledMessage,chat.getPermalink,chat.meMessage,chat.postEphemeral,chat.postMessage,chat.scheduleMessage,chat.unfurl,chat.update,chat.scheduledMessages.list,conversations.acceptSharedInvite,conversations.approveSharedInvite,conversations.archive,conversations.close,conversations.create,conversations.declineSharedInvite,conversations.history,conversations.info,conversations.invite,conversations.inviteShared,conversations.join,conversations.kick,conversations.leave,conversations.list,conversations.listConnectInvites,conversations.mark,conversations.members,conversations.open,conversations.rename,conversations.replies,conversations.setPurpose,conversations.setTopic,conversations.unarchive,conversations.canvases.create,conversations.externalInvitePermissions.set,dialog.open,dnd.endDnd,dnd.endSnooze,dnd.info,dnd.setSnooze,dnd.teamInfo,emoji.list,files.completeUploadExternal,files.delete,files.getUploadURLExternal,files.info,files.list,files.revokePublicURL,files.sharedPublicURL,files.upload,files.comments.delete,files.remote.add,files.remote.info,files.remote.list,files.remote.remove,files.remote.share,files.remote.update,functions.completeError,functions.completeSuccess,functions.distributions.permissions.add,functions.distributions.permissions.list,functions.distributions.permissions.remove,functions.distributions.permissions.set,functions.workflows.steps.list,functions.workflows.steps.responses.export,migration.exchange,oauth.access,oauth.v2.access,oauth.v2.exchange,openid.connect.token,openid.connect.userInfo,pins.add,pins.list,pins.remove,reactions.add,reactions.get,reactions.list,reactions.remove,reminders.add,reminders.complete,reminders.delete,reminders.info,reminders.list,rtm.connect,rtm.start,search.all,search.files,search.messages,stars.add,stars.list,stars.remove,team.accessLogs,team.billableInfo,team.info,team.integrationLogs,team.billing.info,team.externalTeams.list,team.preferences.list,team.profile.get,tooling.tokens.rotate,usergroups.create,usergroups.disable,usergroups.enable,usergroups.list,usergroups.update,usergroups.users.list,usergroups.users.update,users.conversations,users.deletePhoto,users.getPresence,users.identity,users.info,users.list,users.lookupByEmail,users.setActive,users.setPhoto,users.setPresence,users.profile.get,users.profile.set,views.open,views.publish,views.push,views.update,workflows.stepCompleted,workflows.stepFailed,workflows.updateStep,workflows.triggers.permissions.add,workflows.triggers.permissions.list,workflows.triggers.permissions.remove,workflows.triggers.permissions.set,channels.create,channels.info,channels.invite,channels.mark,groups.create,groups.info,groups.invite,groups.mark,groups.open,im.list,im.mark,im.open,mpim.list,mpim.mark,mpim.open".split(
2121
","
2222
)
2323

@@ -482,6 +482,9 @@ async def run_method(self, method_name, method, async_method):
482482
elif method_name == "conversations_canvases_create":
483483
self.api_methods_to_call.remove(method(channel_id="C123", document_content={})["method"])
484484
await async_method(channel_id="C123", document_content={})
485+
elif method_name == "conversations_externalInvitePermissions_set":
486+
self.api_methods_to_call.remove(method(action="upgrade", channel="C123", target_team="T123")["method"])
487+
await async_method(action="upgrade", channel="C123", target_team="T123")
485488
elif method_name == "canvases_access_set":
486489
self.api_methods_to_call.remove(method(canvas_id="F111", access_level="write")["method"])
487490
await async_method(canvas_id="F111", access_level="write")

0 commit comments

Comments
 (0)