Slack.NetStandard 9.3.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Slack.NetStandard --version 9.3.0
                    
NuGet\Install-Package Slack.NetStandard -Version 9.3.0
                    
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="Slack.NetStandard" Version="9.3.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Slack.NetStandard" Version="9.3.0" />
                    
Directory.Packages.props
<PackageReference Include="Slack.NetStandard" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Slack.NetStandard --version 9.3.0
                    
#r "nuget: Slack.NetStandard, 9.3.0"
                    
#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.
#:package Slack.NetStandard@9.3.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Slack.NetStandard&version=9.3.0
                    
Install as a Cake Addin
#tool nuget:?package=Slack.NetStandard&version=9.3.0
                    
Install as a Cake Tool

Slack.NetStandard

Latest NuGet version

.NET Core NuGet package that helps with Slack interactions Available at https://www.nuget.org/packages/Slack.NetStandard

Create OAuth URL

using Slack.NetStandard.Auth;

var builder = new OAuthV2Builder("clientId")
{
    State = "stateGoesHere", 
    BotScope = "channels:read"
};
var redirectUri = builder.BuildUri(); 

Get OAuth Access Token from Code

using Slack.NetStandard.Auth;

var token = await OAuthV2Builder.Exchange(code,clientId,clientSecret);

Verify Incoming Request is from Slack

using Slack.NetStandard;

var verifier = new RequestVerifier(signingSecret);
var verified = verifier.Verify(request.Headers[RequestVerifier.SignatureHeaderName], long.Parse(request.Headers[RequestVerifier.TimestampHeaderName]), request.Body);

Receive/Respond to a slash command payload

var command = new SlashCommand(payloadText);

var message = new InteractionMessage();
message.Blocks.Add(new Section{Text = new PlainText("Only title is required")});
message.Blocks.Add(new Divider());
message.Send(command.ResponseUrl);

await command.Respond(message);

// or - if it's not from a slash command, any response url can use
await command.Response(responseUrl);

Building & sending a modal

var view = new View
{
    Type = "modal",
    Title = "Create New Story",
    Close = "Cancel",
    Submit = "Submit",
    Blocks = new List<IMessageBlock>
    {
       new Section{Text = new PlainText("Only title is required")}
    }
};

var client = new SlackWebApiClient(accessToken);
var response = await client.View.Open(triggerId,view);

Sending a new message to a channel

var request = new PostMessageRequest {Channel = "C123456"};
request.Blocks.Add(new Section{Text = new PlainText("Hi There!")});

var client = new SlackWebApiClient("token");
await client.Chat.Post(request);

Parse Events API Body

using Slack.NetStandard.EventsApi;
using Slack.NetStandard.EventsApi.CallbackEvents;

var eventObject = JsonConvert.DeserializeObject<Event>(input.Body);

if (eventObject is EventCallback callback)
{
    switch(callback.Event)
    {
        case AppHomeOpened appHome:
            break;
        case GroupClose groupClose:
            break;

    }
}
var entities = TextParser.FindEntities("<@W123456|Steven>");
if(entities.First() is UserMention mention)
{
    var userId = mention.UserId //W123456
    var label = mention.Label //Steven
}

Socket Mode - getting to your payload

if(msg.Contains("envelope_id")) //If there's no envelope ID it's a Hello or Disconnect object
{
   var env = JsonConvert.DeserializeObject<Envelope>(msg);
   switch(env.Payload) {
     case SlashCommand command:
       //logic here
       break;
     case EventCallback evt: 
       //logic here
       break;
     case InteractionPayload payload:
       //logic here
       break;
   }
   var ack = new Acknowledge{EnvelopeId=env.EnvelopeId} //All messages must be acknowledged within a few seconds
   Send(ack);
}

For a .NET 3.1 client that helps with a lot of the Socket Mode plumbing, the SocketSample app is now available at Slack.NetStandard.AsyncEnumerable

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on Slack.NetStandard:

Package Downloads
Slack.NetStandard.AsyncEnumerable

Additional support for Slack.NetStandard apps running Socket Mode

Slack.NetStandard.Endpoint

Small library used to build single Slack endpoints - allowing simpler wiring of Slack apps by examining the full request and deserializing appropriately

Slack.NetStandard.Annotations

Library that uses method attributes to generate a Slack app

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
9.9.0 84,416 3/4/2025
9.8.0 438 3/1/2025
9.7.3 7,147 2/9/2025
9.7.2 2,467 2/5/2025
9.7.1 24,451 12/16/2024
9.7.0 1,268 12/1/2024
9.6.1 3,392 11/13/2024
9.6.0 9,822 10/18/2024
9.5.0 26,469 6/28/2024
9.4.0 1,458 6/26/2024
9.3.0 140,665 2/28/2024
9.2.0 170 2/28/2024
9.1.1 4,839 1/25/2024
9.1.0 166 1/24/2024
9.0.0 148 1/24/2024
8.2.1 1,346 1/19/2024
8.2.0 1,029 1/13/2024
8.1.1 38,290 11/14/2023
8.1.0 63,662 10/13/2023
8.0.1 54,944 9/27/2023
8.0.0 926 9/18/2023
7.0.0 22,453 7/25/2023
6.1.0-beta1 1,384 3/22/2023
6.0.0 60,158 3/22/2023
5.3.0-beta3 4,087 10/26/2022
5.3.0-beta1 232 10/26/2022
5.2.2 96,992 10/26/2022
5.2.0 511 10/26/2022
5.2.0-beta5 314 9/19/2022
5.2.0-beta4 311 8/15/2022
5.2.0-beta3 249 7/28/2022
5.2.0-beta2 247 7/14/2022
5.1.3 4,920 9/19/2022
5.1.2 14,673 7/28/2022
5.1.1 1,002 7/14/2022
5.1.0-beta1 252 7/13/2022
5.0.0 594 7/13/2022
4.1.0-beta1 261 7/1/2022
4.0.0 7,050 7/1/2022
3.14.0-beta6 257 7/1/2022
3.14.0-beta5 234 6/10/2022
3.14.0-beta4 253 6/7/2022
3.14.0-beta3 269 6/3/2022
3.14.0-beta2 269 6/1/2022
3.14.0-beta1 251 6/1/2022
3.13.5 11,220 7/1/2022
3.13.4 2,568 6/10/2022
3.13.3 1,043 6/7/2022
3.13.2 721 6/3/2022
3.13.1 698 6/1/2022
3.13.0 556 6/1/2022
3.13.0-beta2 261 5/27/2022
3.13.0-beta1 271 5/13/2022
3.12.1 884 5/27/2022
3.12.0 2,993 5/13/2022
3.12.0-beta2 277 4/13/2022
3.12.0-beta1 253 4/5/2022
3.11.0 5,133 4/5/2022
3.11.0-beta1 259 2/23/2022
3.10.0 8,019 2/23/2022
3.10.0-beta2 257 2/17/2022
3.10.0-beta1 273 2/9/2022
3.9.1 905 2/17/2022
3.9.0 812 2/9/2022
3.9.0-beta1 282 2/1/2022
3.8.0 4,106 2/1/2022
3.8.0-beta3 281 1/15/2022
3.8.0-beta2 276 1/13/2022
3.8.0-beta1 281 1/12/2022
3.7.1 13,481 1/13/2022
3.7.0 577 1/12/2022
3.7.0-beta1 291 12/20/2021
3.6.0 798 12/20/2021
3.6.0-beta1 298 12/14/2021
3.5.0 882 12/14/2021
3.5.0-beta1 3,364 11/25/2021
3.4.0 4,394 11/25/2021
3.4.0-beta1 941 10/10/2021
3.3.0 296,473 10/6/2021
3.2.0 7,584 9/3/2021
3.2.0-beta1 339 8/17/2021
3.1.0 1,318 8/17/2021
3.0.0 2,981 7/19/2021
2.17.0-beta4 415 6/8/2021
2.17.0-beta3 454 5/30/2021
2.17.0-beta2 380 5/22/2021
2.17.0-beta1 314 5/8/2021
2.16.3 154,015 6/8/2021
2.16.2 843 5/30/2021
2.16.1 529 5/22/2021
2.16.0 853 5/8/2021
2.16.0-beta3 323 5/2/2021
2.16.0-beta2 318 4/28/2021
2.16.0-beta1 403 4/7/2021
2.15.2 635 5/2/2021
2.15.1 1,615 4/28/2021
2.15.0 16,885 4/7/2021
2.15.0-beta5 294 4/7/2021
2.15.0-beta3 3,372 3/21/2021
2.15.0-beta2 399 3/18/2021
2.15.0-beta1 320 3/17/2021
2.14.4 464 4/7/2021
2.14.2 2,149 3/21/2021
2.14.1 517 3/18/2021
2.14.0 524 3/17/2021
2.14.0-beta3 311 3/4/2021
2.14.0-beta2 309 3/2/2021
2.14.0-beta1 329 3/2/2021
2.13.2 694 3/4/2021
2.13.1 8,279 3/2/2021
2.13.0 11,188 3/2/2021
2.13.0-beta1 322 2/24/2021
2.12.0 675 2/24/2021
2.12.0-beta1 323 2/22/2021
2.11.0 7,171 2/22/2021
2.10.1 519 2/11/2021
2.10.0 4,525 1/28/2021
2.10.0-beta2 319 1/16/2021
2.10.0-beta1 303 1/15/2021
2.9.2 477 1/27/2021
2.9.1 657 1/16/2021
2.9.0 662 1/15/2021
2.9.0-beta8 353 1/11/2021
2.9.0-beta7 402 12/10/2020
2.9.0-beta6 411 11/30/2020
2.9.0-beta5 399 11/28/2020
2.9.0-beta4 388 11/26/2020
2.9.0-beta3 445 10/20/2020
2.9.0-beta2 379 10/20/2020
2.9.0-beta 415 10/20/2020
2.8.7 7,976 1/11/2021
2.8.6 4,268 12/10/2020
2.8.5 5,631 11/30/2020
2.8.4 629 11/28/2020
2.8.3 612 11/26/2020
2.8.2 1,635 10/20/2020
2.8.1 577 10/20/2020
2.8.0 618 10/20/2020
2.8.0-beta 474 10/17/2020
2.7.0 631 10/17/2020
2.7.0-beta2 371 10/17/2020
2.7.0-beta 426 10/14/2020
2.6.1 531 10/17/2020
2.6.0 589 10/14/2020
2.6.0-beta 501 10/8/2020
2.5.1 704 10/8/2020
2.5.0 695 10/8/2020
2.4.0 662 10/5/2020
2.3.0 1,384 9/17/2020
2.2.1 17,336 9/1/2020
2.2.0 597 8/28/2020
2.1.0 11,917 6/16/2020
2.0.0 777 5/29/2020
1.7.1 621 5/28/2020
1.7.0 897 5/21/2020
1.6.0 620 5/21/2020
1.5.5 648 5/17/2020
1.5.4 590 5/14/2020
1.5.3 626 5/11/2020
1.5.2 649 5/6/2020
1.5.1 646 5/4/2020
1.5.0 619 5/4/2020
1.4.2 618 5/4/2020
1.4.1 607 5/4/2020
1.4.0 629 5/4/2020
1.3.2 651 5/4/2020
1.3.1 711 4/30/2020
1.3.0 607 4/29/2020
1.2.1 631 4/29/2020
1.2.0 632 4/29/2020
1.1.0 620 4/28/2020
1.0.2 603 4/28/2020
1.0.1 623 4/27/2020
1.0.0 677 4/21/2020
0.5.0 662 4/13/2020
0.4.1-alpha8 481 4/12/2020
0.4.1-alpha7 468 4/12/2020
0.4.1-alpha6 472 4/12/2020
0.4.1-alpha4 497 4/12/2020
0.4.1-alpha3 495 4/12/2020
0.4.1-alpha2 429 4/12/2020
0.4.1-alpha1 456 4/11/2020
0.4.0-pre 601 4/5/2020
0.3.2 700 1/3/2020
0.3.1 694 1/3/2020
0.3.0 737 1/2/2020
0.2.2 683 12/23/2019
0.2.1 645 12/23/2019
0.2.1-pre 510 12/19/2019
0.2.0 650 12/20/2019
0.2.0-pre 499 12/18/2019
0.1.1-pre 505 12/17/2019
0.1.0 2,016 12/19/2019
0.1.0-pre 484 12/17/2019

Extend auth.teams.list with icon support (thank you @lucaghersi!)