定制 tatarko/yii-slack 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tatarko/yii-slack

最新稳定版本:v0.4.1

Composer 安装命令:

composer require tatarko/yii-slack

包简介

Yii extension for accessing Slack API with Guzzle interface

README 文档

README

Yii extension for accessing Slack API in Yii framework via Guzzle.

Latest Stable Version Code Climate

Installation

Yii Slack is composer library so you can install the latest version with:

php composer.phar require tatarko/yii-slack

Configuration

To your application's config add following:

'components' => array(
	'slack' => array(
		'class' => 'Tatarko\\YiiSlack\\ApplicationComponent',
		'appId' => '', // Your's application ID
		'appSecret' => '', // Your's application secret code
		'tokenStateName' => 'slack.access.token'; // optional - change name of the user's state variable to store access token in
		'companyToken' => '', // optional - set global access token of your company's account to use slack component without user authentication
	),
)

For OAuth authentication add following method to the controller:

class SiteController extends Controller
{
	public function actions()
    {
        return array(
            'slack' => array(
                'class' => 'Tatarko\\YiiSlack\\AuthenticationAction',
				'onAuthSuccess' => function(CEvent $event) {
					// you can get $event->params->access_token and store it in some persistant database instead of user's states (that is basically sessions variable)
					$this->redirect('welcome');
				},
                'onAuthError' => function(CEvent $event) {
					// $event->params is instance of Exception (CException or GuzzleHttp\Exception\TransferException)
					$this->redirect('login');
				},
            ),
        );
    }
}

Usage

For simple OAuth just create link in any view file:

<a href="<?= $this->createUrl('site/slack') ?>">Login with Slack</a>

After that you can check if current web user is logged using Slack by calling:

var_dump(Yii::app()->slack->isAuthenticated); // boolean

And in case that user is really authenticated you can make API call like:

var_dump(Yii::app()->slack->get('auth.test'));

That prints something likes:

array(6) {
  'ok' =>
  bool(true)
  'url' =>
  string(25) "https://myteam.slack.com/"
  'team' =>
  string(7) "My Team"
  'user' =>
  string(3) "cal"
  'team_id' =>
  string(6) "T12345"
  'user_id' =>
  string(6) "U12345"
}

For additional arguments use:

Yii::app()->slack->post('channels.create', array('name' => 'mychannel'));

For complete list of all available methods and their arguments go to official Slack documentation.

统计信息

  • 总下载量: 30.8k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-03-22