sebbmeyer / laravel-teams-connector
Microsoft Teams Connector for Laravel 5/6
Installs: 130 296
Dependents: 0
Suggesters: 0
Security: 0
Stars: 32
Watchers: 5
Forks: 10
Open Issues: 1
Requires
- php: >=7.0.0
- illuminate/support: 5.5.x|5.6.x|5.7.x|5.8.x|6.x|7.x|8.x|9.x|10.x|^11.0
- sebbmeyer/php-microsoft-teams-connector: 0.2.*
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.
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