BizDoc.Core.Slack 6.5.9

There is a newer version of this package available.
See the version list below for details.
dotnet add package BizDoc.Core.Slack --version 6.5.9
NuGet\Install-Package BizDoc.Core.Slack -Version 6.5.9
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="BizDoc.Core.Slack" Version="6.5.9" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BizDoc.Core.Slack --version 6.5.9
#r "nuget: BizDoc.Core.Slack, 6.5.9"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install BizDoc.Core.Slack as a Cake Addin
#addin nuget:?package=BizDoc.Core.Slack&version=6.5.9

// Install BizDoc.Core.Slack as a Cake Tool
#tool nuget:?package=BizDoc.Core.Slack&version=6.5.9

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();

Use app-level token.

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.

Responding to events

builder.Services.AddBizDoc().
	AddSlack(..., e =>
		e.UseSocket(o =>
			o.OnMessageReceived = e => {
				if(e.Message is ChannelMessage cm && cm.Message 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
ChannelMessage message See message type.
PresenceChange presence_change
UserChange user_change
BlockActions interactive, block_actions
ViewSubmission interactive, view_submission
BlockSuggestion interactive, block_suggestion
ViewClosed view_closed
SlashCommand slash_commands
TeamJoin team_join
FileShared file_shared
ChannelCreated channel_created
ChannelJoined channel_joined
FileCreated file_created
AppHomeOpened app_home_opened

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
ListFilesAsync files.list
DeleteFileAsync files.delete
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().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);
	}
});

Block can be one of Section, ImageBlock, InputBlock 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.

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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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 841 10/18/2022
6.7.0 774 7/10/2022
6.6.2 736 6/15/2022
6.6.1 784 6/9/2022
6.6.0 743 5/31/2022
6.5.12 758 5/20/2022
6.5.11 798 5/16/2022
6.5.9 746 5/15/2022
6.5.8 732 5/11/2022
6.5.7 739 5/11/2022
6.5.6 786 5/10/2022
6.5.5 765 5/10/2022
6.5.4 762 5/10/2022
6.5.3 758 5/9/2022
6.5.2 763 5/9/2022
6.5.1 752 4/6/2022
6.3.5 775 2/7/2022
6.3.3 767 1/30/2022
6.3.2 812 1/27/2022
6.3.1 796 1/24/2022
6.2.0 763 1/11/2022
6.0.1 639 12/20/2021
6.0.0 636 11/10/2021
5.3.1 683 11/3/2021
5.3.0 829 10/30/2021
5.1.1 681 8/30/2021
5.1.0 692 8/23/2021