sebbmeyer/laravel-teams-connector 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

sebbmeyer/laravel-teams-connector

最新稳定版本:0.6.5

Composer 安装命令:

composer require sebbmeyer/laravel-teams-connector

包简介

Microsoft Teams Connector for Laravel 5/6

README 文档

README

A Laravel 5/6 package to send notifications to Microsoft Teams by using "Incoming Webhook". This package also contains a card to send a Laravel Forge deployment notification, because Microsoft Teams notification is not supported at the moment.

If you are using Laravel 5.4 or older versions of laravel, please use the version 0.3.x of this package.

Forge card

Package Installation - Composer

You can install the package via composer:

composer require sebbmeyer/laravel-teams-connector

Laravel

If you are using Laravel 5.5 and up, the service provider will automatically get registered.

For older versions of Laravel (<5.5), you have to add the service provider and alias to config/app.php:

Sebbmyr\LaravelTeams\TeamsConnectorServiceProvider::class,

You can optionally use the facade for shorter code. Add this to your facades:

'TeamsConnector' => Sebbmyr\LaravelTeams\Facades\TeamsConnector::class,

Lumen

For Lumen usage, the service provider should be registered manually by adding the following line in bootstrap/app.php:

$app->register(Sebbmyr\LaravelTeams\TeamsConnectorServiceProvider::class);

Configuration

For this package to work, you need to configure an "Incomming Webhook" connector in your targeted Teams channel and copy the url into a config file that you can publish like this:

php artisan vendor:publish --provider="Sebbmyr\LaravelTeams\TeamsConnectorServiceProvider"

... or you simple add the following to your .env file:

MICROSOFT_TEAMS_WEBHOOK=<incoming_webhook_url>

Usage

How to send simple notification look at the readme of this package sebbmeyer/php-microsoft-teams-connector

Custom card - ForgeCard

You can create your own cards for every purpose you need, just extend the AbstractCard class and implement the getMessage() function.

\\ Sebbmyr\LaravelTeams\Cards\ForgeCard.php
public function getMessage()
{
    return [
        "@type" => "MessageCard",
        "@context" => "http://schema.org/extensions",
        "summary" => "Forge Card",
        "themeColor" => ($this->data["status"] === 'success') ? self::STATUS_SUCCESS : self::STATUS_ERROR,
        "title" => "Forge deployment message",
        "sections" => [
            [
                "activityTitle" => "",
                "activitySubtitle" => "",
                "activityImage" => "",
                "facts" => [
                    [
                        "name" => "Server:",
                        "value" => $this->data["server"]['name']
                    ],
                    [
                        "name" => "Site",
                        "value" => "[". $this->data["site"]["name"] ."](http://". $this->data["site"]["name"] .")"
                    ],                        [
                        "name" => "Commit hash:",
                        "value" => "[". $this->data["commit_hash"] ."](". $this->data["commit_url"] .")"
                    ],
                    [
                        "name" => "Commit message",
                        "value" => $this->data["commit_message"]
                    ]
                ],
                "text" => ($this->data["status"] === 'success') ? $this->data["commit_author"] ." deployed some fresh code!" : "Something went wrong :/"
            ]
        ]
    ];
}

Custom Card

You can use the CustomCard class and dynamically build out our card. Based on Microsoft Legacy Card

Available Methods

  • addTitle
  • addText
  • addColor
  • addActivity
  • addFacts
  • addFactsText
  • addImage
  • addImages
  • addAction
$card = New Sebbmyr\LaravelTeams\Cards\CustomCard('Title Test','Text Test');
$card->addColor('800080')
    ->addFactsText('Supported Laravel Versions',['5.x','6.x'])
    ->addFactsText('Unsupported Laravel Versions',['Before Version 5'])
    ->addAction('Laravel Website','http://www.laravel.com')
    ->addFacts('Facts Section',['Fact Name 1' => 'Fact Value 1','Fact Name 2' => 'Fact Value 2']);
app('TeamsConnector')->send($card);

Adaptive Card

To use an adaptive card see the documentation here. Better support will coming soon.

License

This Microsoft Teams connector for Laravel is open-sourced software licensed under the MIT license

统计信息

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

GitHub 信息

  • Stars: 33
  • Watchers: 4
  • Forks: 10
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-08-10