Skip to content

raku-community-modules/WebService-Slack-Webhook

 
 

Repository files navigation

Actions Status Actions Status Actions Status

NAME

WebService::Slack::Webhook - Support for Slack's WebService API

SYNOPSIS

use WebService::Slack::Webhook;

my $slack = WebService::Slack::Webhook.new(url => $url);

$slack.send("Beep, boop. *excited robot sounds*");

DESCRIPTION

The idea is to make this module as simple to use as possible. In an effort to do this, info will be passed as a hash instead of named arguments. This is because Slack's API for webhooks is not documented terribly well, and they are always new additions to it. So, instead of preventing you from sending a particular bit of data, just pass a hash and it will be sent.

USAGE

.new

The .new method will require an 'incoming webhook' integration link from Slack, this way it knows where to connect and has the correct authentication to do so.

One of these links will be given after setting up an integration using this link "New Slack incoming webhook". If the url is not given an exception will be thrown. The syntax for this method will look like this:

#String containing the URL.
my $slack = WebService::Slack::Webhook.new(url => $url);

Defaults are now available as well. This should make it easier to use this module, because instead of having to pass a huge hash every time, it can just be set as a default. Note that the defaults can still be overridden just by setting the option to something else when passing a hash. Setting defaults:

#Setting a default hash for the object.
my $slack = WebService::Slack::Webhook.new(
    url      => $url,
    defaults => %( username => "System Messenger" )
);

.send

This will be the method to send a message from. It will be overloaded so that it can be used easier. The correct syntax for it will be:

#Using the '$slack' variable from the previous example...

#Using a hash.
my %info = (
  username   => "Jimmy the Robot",
  icon_emoji => ":robot_face:",
  text       => "Beep, boop. *excited robot sounds*"
);
$slack.send(%info);

#Or if you just want to send something...

#Just a string.
$slack.send("Beep, boop. *excited robot sounds*");

AUTHOR

Nic Quoziente

COPYRIGHT AND LICENSE

Copyright 2016 - 2017 Nic Quoziente

Copyright 2024 Raku Community

This library is free software; you can redistribute it and/or modify it under the Artistic License 2.0.