Slack.NetStandard 6.0.0

.NET Standard 2.0
There is a newer version of this package available.
See the version list below for details.
dotnet add package Slack.NetStandard --version 6.0.0
NuGet\Install-Package Slack.NetStandard -Version 6.0.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="6.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Slack.NetStandard --version 6.0.0
#r "nuget: Slack.NetStandard, 6.0.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.
// Install Slack.NetStandard as a Cake Addin
#addin nuget:?package=Slack.NetStandard&version=6.0.0

// Install Slack.NetStandard as a Cake Tool
#tool nuget:?package=Slack.NetStandard&version=6.0.0

Slack.NetStandard

.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. 
.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)
Additional computed target framework(s)
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
8.0.0 360 9/18/2023
7.0.0 4,228 7/25/2023
6.1.0-beta1 341 3/22/2023
6.0.0 17,140 3/22/2023
5.3.0-beta3 3,708 10/26/2022
5.3.0-beta1 85 10/26/2022
5.2.2 25,249 10/26/2022
5.2.0 370 10/26/2022
5.2.0-beta5 149 9/19/2022
5.2.0-beta4 152 8/15/2022
5.2.0-beta3 112 7/28/2022
5.2.0-beta2 120 7/14/2022
5.1.3 3,867 9/19/2022
5.1.2 10,838 7/28/2022
5.1.1 853 7/14/2022
5.1.0-beta1 128 7/13/2022
5.0.0 431 7/13/2022
4.1.0-beta1 109 7/1/2022
4.0.0 5,639 7/1/2022
3.14.0-beta6 100 7/1/2022
3.14.0-beta5 101 6/10/2022
3.14.0-beta4 105 6/7/2022
3.14.0-beta3 107 6/3/2022
3.14.0-beta2 112 6/1/2022
3.14.0-beta1 105 6/1/2022
3.13.5 5,744 7/1/2022
3.13.4 2,229 6/10/2022
3.13.3 887 6/7/2022
3.13.2 568 6/3/2022
3.13.1 567 6/1/2022
3.13.0 430 6/1/2022
3.13.0-beta2 108 5/27/2022
3.13.0-beta1 114 5/13/2022
3.12.1 730 5/27/2022
3.12.0 2,751 5/13/2022
3.12.0-beta2 119 4/13/2022
3.12.0-beta1 107 4/5/2022
3.11.0 4,828 4/5/2022
3.11.0-beta1 113 2/23/2022
3.10.0 6,455 2/23/2022
3.10.0-beta2 112 2/17/2022
3.10.0-beta1 112 2/9/2022
3.9.1 759 2/17/2022
3.9.0 641 2/9/2022
3.9.0-beta1 117 2/1/2022
3.8.0 2,336 2/1/2022
3.8.0-beta3 129 1/15/2022
3.8.0-beta2 119 1/13/2022
3.8.0-beta1 111 1/12/2022
3.7.1 5,373 1/13/2022
3.7.0 442 1/12/2022
3.7.0-beta1 142 12/20/2021
3.6.0 529 12/20/2021
3.6.0-beta1 138 12/14/2021
3.5.0 675 12/14/2021
3.5.0-beta1 3,201 11/25/2021
3.4.0 4,234 11/25/2021
3.4.0-beta1 799 10/10/2021
3.3.0 205,183 10/6/2021
3.2.0 7,432 9/3/2021
3.2.0-beta1 205 8/17/2021
3.1.0 1,145 8/17/2021
3.0.0 2,795 7/19/2021
2.17.0-beta4 270 6/8/2021
2.17.0-beta3 308 5/30/2021
2.17.0-beta2 240 5/22/2021
2.17.0-beta1 173 5/8/2021
2.16.3 35,760 6/8/2021
2.16.2 687 5/30/2021
2.16.1 369 5/22/2021
2.16.0 692 5/8/2021
2.16.0-beta3 188 5/2/2021
2.16.0-beta2 168 4/28/2021
2.16.0-beta1 273 4/7/2021
2.15.2 387 5/2/2021
2.15.1 1,450 4/28/2021
2.15.0 9,183 4/7/2021
2.15.0-beta5 154 4/7/2021
2.15.0-beta3 3,231 3/21/2021
2.15.0-beta2 256 3/18/2021
2.15.0-beta1 169 3/17/2021
2.14.4 299 4/7/2021
2.14.2 1,989 3/21/2021
2.14.1 346 3/18/2021
2.14.0 369 3/17/2021
2.14.0-beta3 163 3/4/2021
2.14.0-beta2 156 3/2/2021
2.14.0-beta1 182 3/2/2021
2.13.2 524 3/4/2021
2.13.1 8,056 3/2/2021
2.13.0 3,058 3/2/2021
2.13.0-beta1 194 2/24/2021
2.12.0 500 2/24/2021
2.12.0-beta1 171 2/22/2021
2.11.0 5,373 2/22/2021
2.10.1 354 2/11/2021
2.10.0 3,225 1/28/2021
2.10.0-beta2 171 1/16/2021
2.10.0-beta1 160 1/15/2021
2.9.2 322 1/27/2021
2.9.1 488 1/16/2021
2.9.0 493 1/15/2021
2.9.0-beta8 214 1/11/2021
2.9.0-beta7 250 12/10/2020
2.9.0-beta6 254 11/30/2020
2.9.0-beta5 251 11/28/2020
2.9.0-beta4 249 11/26/2020
2.9.0-beta3 291 10/20/2020
2.9.0-beta2 236 10/20/2020
2.9.0-beta 274 10/20/2020
2.8.7 6,169 1/11/2021
2.8.6 3,478 12/10/2020
2.8.5 5,459 11/30/2020
2.8.4 465 11/28/2020
2.8.3 435 11/26/2020
2.8.2 1,469 10/20/2020
2.8.1 413 10/20/2020
2.8.0 449 10/20/2020
2.8.0-beta 314 10/17/2020
2.7.0 461 10/17/2020
2.7.0-beta2 227 10/17/2020
2.7.0-beta 274 10/14/2020
2.6.1 374 10/17/2020
2.6.0 434 10/14/2020
2.6.0-beta 338 10/8/2020
2.5.1 536 10/8/2020
2.5.0 518 10/8/2020
2.4.0 492 10/5/2020
2.3.0 1,226 9/17/2020
2.2.1 16,946 9/1/2020
2.2.0 421 8/28/2020
2.1.0 11,042 6/16/2020
2.0.0 596 5/29/2020
1.7.1 442 5/28/2020
1.7.0 559 5/21/2020
1.6.0 443 5/21/2020
1.5.5 462 5/17/2020
1.5.4 421 5/14/2020
1.5.3 467 5/11/2020
1.5.2 485 5/6/2020
1.5.1 485 5/4/2020
1.5.0 444 5/4/2020
1.4.2 439 5/4/2020
1.4.1 427 5/4/2020
1.4.0 464 5/4/2020
1.3.2 462 5/4/2020
1.3.1 529 4/30/2020
1.3.0 453 4/29/2020
1.2.1 450 4/29/2020
1.2.0 451 4/29/2020
1.1.0 429 4/28/2020
1.0.2 418 4/28/2020
1.0.1 448 4/27/2020
1.0.0 504 4/21/2020
0.5.0 484 4/13/2020
0.4.1-alpha8 323 4/12/2020
0.4.1-alpha7 313 4/12/2020
0.4.1-alpha6 321 4/12/2020
0.4.1-alpha4 330 4/12/2020
0.4.1-alpha3 340 4/12/2020
0.4.1-alpha2 278 4/12/2020
0.4.1-alpha1 294 4/11/2020
0.4.0-pre 433 4/5/2020
0.3.2 537 1/3/2020
0.3.1 509 1/3/2020
0.3.0 542 1/2/2020
0.2.2 514 12/23/2019
0.2.1 471 12/23/2019
0.2.1-pre 346 12/19/2019
0.2.0 473 12/20/2019
0.2.0-pre 347 12/18/2019
0.1.1-pre 330 12/17/2019
0.1.0 491 12/19/2019
0.1.0-pre 334 12/17/2019

More complete information returned for Pins, Reactions and Star Events (thank you @khcnz!)
Breaking change is the removal of the Item object and some namespaces were changed for these improved classes