SOLVED Custom Server Notification for Slack Not Working

Bruno Morais

Member
Jan 6, 2018
5
1
3
Portugal
cPanel Access Level
Root Administrator
Hi Kennerth,
Thanks for the reply but it didn't answer to my question.
I folowed this kb article: How To Create Custom Server Notifications - cPanel Knowledge Base - cPanel Documentation to make the custom notification.

I have Slack setup and generated a token.

My Schema Module is working fine and is saving the Slack data needed to send the POST:

Code:
# cpanel - Cpanel/iContact/Provider/Schema/Slack.pm
#
# This code was developed by Bruno Morais [email protected]
# The code has no warranty use it as you want.

package Cpanel::iContact::Provider::Schema::Slack;

use strict;
use warnings;

use Cpanel::LoadModule;

sub get_settings {
    return {
        'SLACKTOKEN' => {
            'shadow'   => 1,             # Flag for saving to /etc/wwwacct.conf.shadow or /etc/wwwacct.conf
            'type'     => 'text',    # This maps to an HTML input tag's "type" attribute.
            'checkval' => sub {

                Cpanel::LoadModule::load_perl_module('Cpanel::StringFunc::Trim');

                # Not really much to do here, since I'm not actually aware of a good validation regex for these tokens
                my $value = shift();
                return Cpanel::StringFunc::Trim::ws_trim($value);
            },
            'label' => 'Slack Token',
            'help'  => 'The Slack Token to use in slack integration. For more information about how to obtain this token, read Slacks <a title="Create and regenerate API tokens" href="https://get.slack.help/hc/en-us/articles/215770388-Create-and-regenerate-API-tokens" target="_blank">Create and regenerate API tokens</a> documentation.',
        },
        'SLACKCHANNEL' => {
            'shadow'   => 1,
            'type'     => 'text',
            'checkval' => sub {
                Cpanel::LoadModule::load_perl_module('Cpanel::StringFunc::Trim');
                my $value = shift();
                $value = Cpanel::StringFunc::Trim::ws_trim($value);

                # Ideally we would have used Data::Validate::URI, however loading it
                # was 30-40% of the execution time of the Basic Setup page so a basic
                # regex was used instead.
                return $value;
            },
            'label' => 'Slack Channel',
            'help'  => sprintf( 'Your Slack channel to send notifications'),
        }
    };
}

    sub get_config {
    return {
        'default_level'    => 'All', # Maps to what you'd see in the WHM >> Contact Manager UI as the default notification level. In /var/cpanel/clevels.conf, this would be translated to '3'.
        'display_name'     => 'Slack', # Maps to what your provider shows up as in the WHM >> Contact Manager UI.
        'icon_name'        => 'Slack', # Maps to what your icon is named. Currently irrelevant, as it does nothing to help your icon load, and falls back to 'display_name' above if not set.
        'icon'             => '', # A long Data URI (ex. "data:image/png;base64,$my_image_base64"). Thankfully these only display at 16x16px, so you can scale down the image first.
    };

}

1;
Then my Provider code:

Code:
# cpanel - Cpanel/iContact/Provider/Schema/Slack.pm
#
# This code was developed by Bruno Morais [email protected]
# The code has no warranty use it as you want.

package Cpanel::iContact::Provider::Slack;

use strict;
use warnings;

use parent 'Cpanel::iContact::Provider';

use Try::Tiny;

use Cpanel::Hostname                               ();
use Cpanel::LoadModule                             ();
use Cpanel::Exception                              ();
use Cpanel::Rand::Get                              ();
use Cpanel::Validate::EmailRFC                     ();
use Cpanel::Autodie::More::Lite                    ();

our $POSTURL_CLASS = 'Cpanel::Posturl';

sub send {
    my ($self) = @_;

    my $args_hr    = $self->{'args'};
    my $contact_hr = $self->{'contact'};

    my @errs;

    Cpanel::LoadModule::load_perl_module($POSTURL_CLASS);

    my $token = $contact_hr->{'SLACKTOKEN'};
    my $channel = $contact_hr->{'SLACKCHANNEL'};
    my $message = $args_hr->{'text_body'};
    my $username = Cpanel::Hostname::gethostname();
    my $url =  'https://slack.com/api/chat.postMessage';

    my $obj = $POSTURL_CLASS->new();

        try {
          my $response = $obj->post(
                $url,
                {
                    token    => $token,
                    channel  => $channel,
                    text     => $message,
                    username => $username,
                    as_user => 'false',
                }
            );
            if ( !$response->{success} ) {
                die Cpanel::Exception::create( 'ConnectionFailed', 'The system could not send data via [asis,HTTP POST] to the [asis,URL] “[_1]” due to an error: [_2]', [ $url, $response->{content} || $response->{reason} ] );
            }
        }
        catch {
            push @errs, $_;
        };
   

    if (@errs) {
        die Cpanel::Exception::create( 'Collection', [ exceptions => \@errs ] );
    }

    return 1;
}

1;
The problem is that no message is sent to slack. The email notification is received but nothing in Slack.
Also I tail the cpanel error log and there are no errors.

I share here my code if someone want to help. Any help would be much appreciated.

Thanks,
Bruno Morais
 

cPanelKenneth

cPanel Development
Staff member
Apr 7, 2006
4,607
79
458
cPanel Access Level
Root Administrator
Hi,

At a guess, you need to redo how your post handler works. Slack appears to require an Authorization header with the token (based upon Using OAuth 2.0).

I also suggest liberal use of print statements, and Data::Dumper statements, during your development and testing stages. Remove both prior to production use though.

I often print simple phrases like
Code:
sub send{
    print print "Entered Cpanel::iContact::Provider::send function\n";
...
Those simple statements, used frequently in your code, can help pinpoint where the errors and failures are occurring. Data::Dumper can be used to output data structures. Both will help you see what is going on.
 
  • Like
Reactions: cPanelMichael

Bruno Morais

Member
Jan 6, 2018
5
1
3
Portugal
cPanel Access Level
Root Administrator
Hi Kenneth,
I'm using a Legalacy Token and not OAuth2.
For instance ot send a message to channel I can make a curl call in console:

Code:
curl -X POST https://slack.com/api/chat.postMessage --data "token=xoxp-xxxxxxxxxx-xxxxxxxxxxx-xxxxxxxxxxx-xxxxxxxxxxxxx&channel=#cpanel&text=Test&as_user=false&username=cpanel01.smartevolve.com&pretty=1"
This curl request is working.

This is regular POST with some query string data.
I cant find the Cpanel::Posturl class reference to read about it. Just tried to figure out with other notification modules.
Comparing with another modules, I believe it is correct. Do you see any error in my POST call?


Thanks for the help.

Regards,
Bruno Morais
 

cPanelMichael

Administrator
Staff member
Apr 11, 2011
47,903
2,237
463

cPanelMichael

Administrator
Staff member
Apr 11, 2011
47,903
2,237
463
Hi Bruno,

I'm glad to see that helped. I've marked this thread as solved.

Thanks!