跳转到主要内容

为Slack-Machine提供的实用插件,Slack-Machine是一款性感、简单、功能强大且可扩展的Slack机器人。

项目描述

slack-machine-plugins

为Slack-Machine提供的实用插件,Slack-Machine是一款性感、简单、功能强大且可扩展的Slack机器人。

pip install slack-machine-plugins

commander

Commander提供了两个类CommandCommandArgument,以声明式的方式定义聊天命令及其参数,用于输入验证和错误反馈。功能包括

  • 聊天命令参数的类型和长度验证。
  • 严格选择。
  • 自定义验证和错误消息。
  • 用户反馈的使用文本和错误文本。

示例用法

从测试用例中提取,现实示例。

# command definition
####################
from machine_plugins.commander import Command, CommandArgument

scale_cmd = Command(
    name='scale',
    description='Scale a deployment.',
    arguments=[
        CommandArgument(
            name='namespace',
            target_type=str,
            choices=['default', 'dev'],
            description='Namespace of the deployment.',
        ),
        CommandArgument(
            name='deployment',
            validation=(lambda d: d.startswith('deployment-prefix-'),),
            description='Name of the deployment.',
        ),
        CommandArgument(
            name='replicas',
            target_type=int,
            validation=(lambda r: 2 <= int(r) <= 10, 'You can not scale under 2 or above 10 replicas.'),
        ),
    ],
)

# command usage in slack-machine
################################
from machine.plugins.base import MachineBasePlugin
from machine.plugins.decorators import respond_to


class DeploymentPlugin(MachineBasePlugin):

    @respond_to(regex=r'^scale ?(?P<args>.*)$')
    def scale(self, msg, args):
        errs = scale_cmd.errors(args)
        if errs:
            resp = '\n'.join(errs)
            msg.say(f'```{resp}```')
            return
        # input validation complete, do your thing e.g `scale(*args.split())`

项目详情


下载文件

下载适合您平台的文件。如果您不确定选择哪个,请了解更多关于安装软件包的信息。

源分发

slack-machine-plugins-0.1.1.tar.gz (6.7 kB 查看哈希值)

上传于

构建分发版

slack_machine_plugins-0.1.1-py2.py3-none-any.whl (7.3 kB 查看哈希值)

上传于 Python 2 Python 3

由以下组织支持