BizDoc.Core.Slack
                              
                            
                                6.5.12
                            
                        
                    See the version list below for details.
dotnet add package BizDoc.Core.Slack --version 6.5.12
NuGet\Install-Package BizDoc.Core.Slack -Version 6.5.12
<PackageReference Include="BizDoc.Core.Slack" Version="6.5.12" />
<PackageVersion Include="BizDoc.Core.Slack" Version="6.5.12" />
<PackageReference Include="BizDoc.Core.Slack" />
paket add BizDoc.Core.Slack --version 6.5.12
#r "nuget: BizDoc.Core.Slack, 6.5.12"
#:package BizDoc.Core.Slack@6.5.12
#addin nuget:?package=BizDoc.Core.Slack&version=6.5.12
#tool nuget:?package=BizDoc.Core.Slack&version=6.5.12
Slack for BizDoc
BizDoc pushes messages and notifications into Slack and responds to actions in Slack on messages.
To utilize Slack messaging, add in program.cs.
builder.Services.AddBizDoc().AddSlack(o => {
	o.Token = "{bot-oauth-token}";
	o.ChannelId = e => "{channel-id}";
});
app.UseBizDoc().UseSlack();
Sockets
To enable socket for background communication, call UseSocket().
builder.Services.AddBizDoc().AddSlack(o => ..., 
	e => e.UseSocket(o => {
		Token = "{app-level-token}";
	}));
You can configure ProxySettings and retry policy on this option.
Remember to enable Socket Mode in app config. Use app-level token.
Responding to events
builder.Services.AddBizDoc().
	AddSlack(..., e =>
		e.UseSocket(o =>
			o.OnMessageReceived = e => {
				if(e.Message is EventCallback em && em.Payload.Event is NewMessage msg)
					Debug.Write($"Message text '{msg.Text}'");
			}));
You can notify the user by setting the event Response property.
	e.Response.Text = Markdown($"*{ctx.Document.Number}* success!");
| Event | API | Usage | 
|---|---|---|
| BlockActions | interactive, block_actions | |
| ViewSubmission | interactive, view_submission | |
| BlockSuggestion | interactive, block_suggestion | |
| ViewClosed | view_closed | |
| EventCallback | event_callback | |
| Shortcut | shortcut | |
| MessageAction | message_action | |
| SlashCommand | slash_commands | |
| AppHomeOpened | app_home_opened | 
Events.
| Type | API | 
|---|---|
| TeamJoin | team_join | 
| NewMessage | message | 
| PresenceChange | presence_change | 
| ChannelCreated | channel_created | 
| ChannelJoined | channel_joined | 
| FileCreated | file_created | 
| FileShared | file_shared | 
| FileCommentAdded | file_comment_added | 
| UserChange | user_change | 
Message types.
| Type | API | 
|---|---|
| NewMessage | message | 
| MeMessage | me_message | 
| BotMessage | bot_message | 
| MessageChanged | message_changed | 
| FileShare | file_share | 
| GroupJoin | group_join | 
| GroupLeave | group_leave | 
| FileCommentAdded | file_comment | 
| MessageReplied | message_replied | 
| MessageDeleted | message_deleted | 
| ChannelLeave | channel_leave | 
| ChannelJoin | channel_join | 
| ThreadBroadcast | thread_broadcast | 
Service
Inject SlackService service.
await _slackService.PostMessageAsync("channel-id", test: "Message!");
| Name | API | Usage | 
|---|---|---|
| ListUsersAsync | users.list | List of User | 
| PostMessageAsync | chat.postMessage | |
| PostEphemeralMessageAsync | chat.postEphemeral | |
| ScheduleMessageAsync | chat.scheduleMessage | |
| UpdateMessageAsync | chat.update | |
| DeleteMessageAsync | chat.delete | |
| UploadFileAsync | files.uploadAsync or files.upload | |
| GetFileInfoAsync | files.info | |
| ListFilesAsync | files.list | |
| DeleteFileAsync | files.delete | |
| OpenViewAsync | views.open | |
| UpdateViewAsync | views.update | |
| SearchFilesAsync | search.files | |
| PublishAppHomeTabAsync | views.publish | |
| ListConversationsAsync | conversations.list | |
| CreateConversationAsync | conversations.create | |
| ConversationInviteAsync | conversations.invite | |
| ConversationKickAsync | conversations.kick | |
| MarkConversationAsync | conversations.mark | |
| CloseConversationAsync | conversations.close | |
| LeaveConversationAsync | conversations.leave | |
| SearchMessagesAsync | search.messages | Query Message | 
| GetUserInfoAsync | users.info | |
| GetUserByEmailAsync | users.lookupByEmail | 
Intercept outgoing messages
Implement the OnMessagePost option in AddSlack() to contribute an outgoing message.
Use the IDocumentContext to access form model using the GetModel() method.
using BizDoc.Slack.Models;
builder.Services.
	AddBizDoc(o => {
		o.ApplicationUrl = "{server-public-address}";
	}).
	AddSlack(o => {
		...
		o.OnMessagePost = e => {
			var formModel = e.Context.GetModel<MyFormModel>();
	
			var section = new Section("form_section");
			section.Fields.Add(new Text(formModel.Title));
		
			e.Request.Blocks.Add(section);
		}
	});
| Name | Usage | 
|---|---|
| OnMessagePost | Canelable. | 
| OnMessageUpdate | Someone updated the document on BizDoc, hance update Slack message. Canelable. | 
| OnActionTaken | User has taken action on Slack and workflow was resumed in BizDoc. | 
| OnNotify | Notification, such as CubeAnomaly. Canelable. | 
Block can be one of Section, ImageBlock, InputBlock, RichTextBlock or ActionsBlock, which corresponds to Block Kit.
Element can be one of Input, DatePicker, Checkboxes, RadioButtons, Select, MultiSelect, Image, OverflowMenu, Button, ConversationsSelect, MultiConversationsSelect, ChannelsSelect or MultiChannelsSelect.
Use Text or Markdown to represent texts.
Commonly use Section, and Button as section Accessory for interaction.
The ApplicationUrl is used to provide the Slack user links back to BizDoc.
Components
Components can be found in bizdoc.slack.json file.
Flow node
Post a message in a channel when workflow reaches the node.
Type surce
BizDoc adds sources from channels and groups.
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
- 
                                                - SlackAPI (>= 1.1.13)
 
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | |
|---|---|---|---|
| 6.8.2 | 1,053 | 10/18/2022 | |
| 6.7.0 | 904 | 7/10/2022 | |
| 6.6.2 | 871 | 6/15/2022 | |
| 6.6.1 | 937 | 6/9/2022 | |
| 6.6.0 | 943 | 5/31/2022 | |
| 6.5.12 | 904 | 5/20/2022 | |
| 6.5.11 | 962 | 5/16/2022 | |
| 6.5.9 | 913 | 5/15/2022 | |
| 6.5.8 | 894 | 5/11/2022 | |
| 6.5.7 | 890 | 5/11/2022 | |
| 6.5.6 | 944 | 5/10/2022 | |
| 6.5.5 | 938 | 5/10/2022 | |
| 6.5.4 | 903 | 5/10/2022 | |
| 6.5.3 | 899 | 5/9/2022 | |
| 6.5.2 | 908 | 5/9/2022 | |
| 6.5.1 | 905 | 4/6/2022 | |
| 6.3.5 | 916 | 2/7/2022 | |
| 6.3.3 | 943 | 1/30/2022 | |
| 6.3.2 | 952 | 1/27/2022 | |
| 6.3.1 | 963 | 1/24/2022 | |
| 6.2.0 | 945 | 1/11/2022 | |
| 6.0.1 | 779 | 12/20/2021 | |
| 6.0.0 | 781 | 11/10/2021 | |
| 5.3.1 | 824 | 11/3/2021 | |
| 5.3.0 | 980 | 10/30/2021 | |
| 5.1.1 | 830 | 8/30/2021 | |
| 5.1.0 | 834 | 8/23/2021 |