SlashPress

설명

It’s very easy to create a custom slash command on Mattermost, or a private app on Slack that has the slash command feature. This plugin turns that convenient chat interface into a subscribable event using standard WordPress filter & action hooks. This enables automation of tasks that need to be run on-demand, and provision of interactive help for them.

The hooks provided are as follows:

  • slashpress_command_${command}
  • slashpress_command
  • slashpress_help_${command}
  • slashpress_help

The subscribed events receive a helper object representing the sent slash command, with methods to respond using Markdown or a rich response object the chat service can render. Plugins may listen for a specific slash command or a site-wide one, and respond based on the command content. Long-running tasks (> 3 seconds) can provide an immediate acknowledgement response, then later a result response; this is easily achieved by ensuring a proper cron invocation for the site, then passing the helper object to wp_schedule_single_event() to run the task in the background and POST a status message back upon completion.

By itself, this plugin doesn’t do anything. It is aimed at developers and maintainers to abstract away the boring plumbing and authentication, allowing you to keep your code DRY. It supports authentication by both tokens and HMAC signatures. There is no limit on the number of such integrations this endpoint can handle. Only POST method requests are accepted and sent so access logs are kept clean. The interactive help keyword is configurable.

There is no logging, metrics, analytics, nags, or anything that would violate your privacy or GDPR obligations contained in this plugin. It is not freemium; there is no ‘Pro’ version.

설치

  1. Upload the entire, extracted plugin directory to the wp-content/plugins/ directory, or install the plugin through the WordPress Plugins screen directly.
  2. Activate the plugin through the Plugins screen.
  3. Go to Settings > SlashPress, add a service ID, and save.
  4. Note the endpoint URLs provided and insert them into your chat service integration.
  5. Copy the authentication credential from your service to the plugin settings and save again.
  6. Test the integration by entering your slash command followed by help.
  7. Subscribe to the hooks in your own code.

FAQ

What is this good for?

Running any task any task that you want to start immediately from the comfort of your chat app. It’s great for providing instant summaries, triggering actions like backups, clearing/preloading caches of optimisation plugins, updating copies of remote data.

Your code can respond with anything you need, from a simple OK to a full tabulated response using Markdown:

|Order stat|Count|
|:---|---:|
|New orders today|27|
|Orders to fulfil|8|
|Unpaid orders|2|

So how do I use this thing?

A simple example is probably best:

add_action(
    'slashpress_help'
    , function(SlashPress\Command $slash, string $help_terms) {
        $slash->addHelp('flubbers', '`flubbers` Gets the latest map of nearby flubbers.')
            ->addHelp('gronks', '`gronks` Updates the list of the top 100 gronks and their values.')
            ->addHelp('uncache', 'Site content not looking quite right? Use `uncache` to clear the out the generated pages.');
    }
    , 100
    , 2
);

add_filter(
    'slashpress_command'
    , function($initial_response, SlashPress\Command $slash) {
        if (!$slash->known) {
            $text = trim($slash->data['text']);
            switch ($text) {
                case 'flubbers':
                case 'gronks':
                    $slash->handled = true;
                    wp_schedule_single_event(time(), 'big_data_fetch_cron_event_hook', [$text, $slash]);
                    return 'Big data fetch queued.';
                case 'uncache':
                    $slash->handled = true;
                    if (function_exists('w3tc_flush_posts')) {
                        w3tc_flush_posts();
                        return 'Cleared the post cache.';
                    }
                    return 'No cache found to clear.';
            }
        }
        return $initial_response;
    }
    , 10
    , 2
);

add_action(
    'big_data_fetch_cron_event_hook'
    , function(string $what = null, SlashPress\Command $slash = null) {
        $results_bad = $results = [];
        if (null == $what || 'flubbers' == $what) {
            if (fetch_flubbers()) {
                $results[] = 'Flubbers fetched.';
            }
            else {
                $results_bad[] = $results[] = 'Could not fetch the flubbers.';
            }
        }
        if (null == $what || 'gronks' == $what) {
            if (fetch_gronks()) {
                $results[] = 'Gronks fetched.';
            }
            else {
                $results_bad[] = $results[] = 'Could not fetch the gronks.';
            }
        }
        if ($slash) {
            if ($slash->canRespondDelayed()) {
                $slash->respondDelayed(implode("  \n", $results));
            }
        }
        elseif ($results_bad) {
            echo implode("\n", $results_bad);
        }
    }
);

후기

이 플러그인에 대한 평가가 없습니다.

기여자 & 개발자

“SlashPress”(은)는 오픈 소스 소프트웨어입니다. 다음의 사람들이 이 플러그인에 기여하였습니다.

기여자

자국어로 “SlashPress”(을)를 번역하십시오.

개발에 관심이 있으십니까?

코드 탐색하기는, SVN 저장소를 확인하시거나, 개발 기록RSS로 구독하십시오.