Please whitelist cPanel in your adblocker so that you’re able to see our version release promotions, thanks!

The Community Forums

Interact with an entire community of cPanel & WHM users!

SOLVED Custom Server Notification for Slack Not Working

Discussion in 'cPanel Developers' started by Bruno Morais, Jan 28, 2018.

  1. Bruno Morais

    Bruno Morais Member

    Joined:
    Jan 6, 2018
    Messages:
    5
    Likes Received:
    1
    Trophy Points:
    3
    Location:
    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 bruno.morais@smartevolve.com
    # 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 bruno.morais@smartevolve.com
    # 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
     
  2. cPanelKenneth

    cPanelKenneth cPanel Development
    Staff Member

    Joined:
    Apr 7, 2006
    Messages:
    4,561
    Likes Received:
    42
    Trophy Points:
    308
    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.
     
    Stop hovering to collapse... Click to collapse... Hover to expand... Click to expand...
    cPanelMichael likes this.
  3. Bruno Morais

    Bruno Morais Member

    Joined:
    Jan 6, 2018
    Messages:
    5
    Likes Received:
    1
    Trophy Points:
    3
    Location:
    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
     
  4. cPanelMichael

    cPanelMichael Forums Analyst
    Staff Member

    Joined:
    Apr 11, 2011
    Messages:
    43,633
    Likes Received:
    1,787
    Trophy Points:
    363
    cPanel Access Level:
    Root Administrator
    Stop hovering to collapse... Click to collapse... Hover to expand... Click to expand...
  5. Bruno Morais

    Bruno Morais Member

    Joined:
    Jan 6, 2018
    Messages:
    5
    Likes Received:
    1
    Trophy Points:
    3
    Location:
    Portugal
    cPanel Access Level:
    Root Administrator
    Hi Michael,
    That helped a lot. A different approach with webhook in Slack side but working good.
    Thanks for the help.

    Regards,
    Bruno Morais
     
    cPanelMichael likes this.
  6. cPanelMichael

    cPanelMichael Forums Analyst
    Staff Member

    Joined:
    Apr 11, 2011
    Messages:
    43,633
    Likes Received:
    1,787
    Trophy Points:
    363
    cPanel Access Level:
    Root Administrator
    Hi Bruno,

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

    Thanks!
     
    Stop hovering to collapse... Click to collapse... Hover to expand... Click to expand...
Loading...

Share This Page

  1. This site uses cookies to help personalise content, tailor your experience and to keep you logged in if you register.
    By continuing to use this site, you are consenting to our use of cookies.
    Dismiss Notice