Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hnhdigital-os/php-slack
https://github.com/hnhdigital-os/php-slack
Last synced: 12 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/hnhdigital-os/php-slack
- Owner: hnhdigital-os
- License: bsd-2-clause
- Created: 2017-06-05T10:38:39.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-06-20T01:51:42.000Z (over 7 years ago)
- Last Synced: 2024-03-30T02:20:22.182Z (10 months ago)
- Language: PHP
- Size: 104 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
```
_____ _ _
/ ____| | | |
| (___ | | __ _ ___| | __
\___ \| |/ _` |/ __| |/ /
____) | | (_| | (__| <
|_____/|_|\__,_|\___|_|\_\
```Send messages to [Slack](https://slack.com) with [incoming webhooks](https://my.slack.com/services/new/incoming-webhook).
[![Latest Stable Version](https://poser.pugx.org/bluora/php-slack/v/stable.svg)](https://packagist.org/packages/bluora/php-slack) [![Total Downloads](https://poser.pugx.org/bluora/php-slack/downloads.svg)](https://packagist.org/packages/bluora/php-slack) [![Latest Unstable Version](https://poser.pugx.org/bluora/php-slack/v/unstable.svg)](https://packagist.org/packages/bluora/php-slack) [![Built for Laravel](https://img.shields.io/badge/Built_for-Laravel-green.svg)](https://laravel.com/) [![License](https://poser.pugx.org/bluora/php-slack/license.svg)](https://packagist.org/packages/bluora/php-slack)
[![Build Status](https://travis-ci.org/bluora/php-slack.svg?branch=master)](https://travis-ci.org/bluora/php-slack) [![StyleCI](https://styleci.io/repos/93393404/shield?branch=master)](https://styleci.io/repos/93393404) [![Test Coverage](https://codeclimate.com/github/bluora/php-slack/badges/coverage.svg)](https://codeclimate.com/github/bluora/php-slack/coverage) [![Issue Count](https://codeclimate.com/github/bluora/php-slack/badges/issue_count.svg)](https://codeclimate.com/github/bluora/php-slack) [![Code Climate](https://codeclimate.com/github/bluora/php-slack/badges/gpa.svg)](https://codeclimate.com/github/bluora/php-slack)
This package has been adapted by H&H|Digital, an Australian botique developer. Visit us at [hnh.digital](http://hnh.digital).
## Integrations
* Laravel: [Slack for Laravel](https://github.com/bluora/laravel-slack)
## Install
Via composer:
`$ composer require bluora/php-slack dev-master`
Then [create an incoming webhook](https://my.slack.com/services/new/incoming-webhook) on your Slack account for the package to use. You'll need the webhook URL to instantiate the client.
## Basic Usage
### Instantiate the client
```php
// Instantiate without defaults
$client = new Bluora\Slack\Client('https://hooks.slack.com/...');// Instantiate with defaults, so all messages created
// will be sent from 'Cyril' and to the #accounting channel
// by default. Any names like @regan or #channel will also be linked.
$settings = [
'username' => 'Cyril',
'channel' => '#accounting',
'link_names' => true
];$client = new Bluora\Slack\Client('https://hooks.slack.com/...', $settings);
```#### Settings
The default settings are pretty good, but you may wish to set up default behaviour for your client to be used for all messages sent. **All settings are optional and you don't need to provide any**. Where not provided, we'll fallback to what is configured on the webhook integration, which are [managed at Slack](https://my.slack.com/apps/manage/custom-integrations), or our sensible defaults.
Field | Type | Description
----- | ---- | -----------
`channel` | string | The default channel that messages will be sent to
`username` | string | The default username for your bot
`icon` | string | The default icon that messages will be sent with, either `:emoji:` or a URL to an image
`link_names` | bool | Whether names like `@regan` or `#accounting` should be linked in the message (defaults to false)
`unfurl_links` | bool | Whether Slack should unfurl text-based URLs (defaults to false)
`unfurl_media` | bool | Whether Slack should unfurl media-based URLs, like tweets or Youtube videos (defaults to true)
`allow_markdown` | bool | Whether markdown should be parsed in messages, or left as plain text (defaults to true)
`markdown_in_attachments` | array | Which attachment fields should have markdown parsed (defaults to none)### Sending messages
#### Sending a basic message ([preview](https://goo.gl/fY43nw))
```php
$client->send('Hello world!');
```#### Sending a message to a non-default channel
```php
$client->to('#accounting')->send('Are we rich yet?');
```#### Sending a message to a user
```php
$client->to('@regan')->send('Yo!');
```#### Sending a message to a channel as a different bot name ([preview](https://goo.gl/xCeEfY))
```php
$client->from('Jake the Dog')->to('@FinnTheHuman')->send('Adventure time!');
```#### Sending a message with a different icon ([preview](https://goo.gl/lff21l))
```php
// Either with a Slack emoji
$client->to('@regan')->withIcon(':ghost:')->send('Boo!');// or a URL
$client->to('#accounting')->withIcon('http://example.com/accounting.png')->send('Some accounting notification');
```#### Send an attachment ([preview](https://goo.gl/fp3iaY))
```php
$client->to('#operations')->attach([
'fallback' => 'Server health: good',
'text' => 'Server health: good',
'color' => 'danger',
])->send('New alert from the monitoring system'); // no message, but can be provided if you'd like
```#### Send an attachment with fields ([preview](https://goo.gl/264mhU))
```php
$client->to('#operations')->attach([
'fallback' => 'Current server stats',
'text' => 'Current server stats',
'color' => 'danger',
'fields' => [
[
'title' => 'CPU usage',
'value' => '90%',
'short' => true // whether the field is short enough to sit side-by-side other fields, defaults to false
],
[
'title' => 'RAM usage',
'value' => '2.5GB of 4GB',
'short' => true
]
]
])->send('New alert from the monitoring system'); // no message, but can be provided if you'd like
```#### Send an attachment with an author ([preview](https://goo.gl/CKd1zJ))
```php
$client->to('@regan')->attach([
'fallback' => 'Keep up the great work! I really love how the app works.',
'text' => 'Keep up the great work! I really love how the app works.',
'author_name' => 'Jane Appleseed',
'author_link' => 'https://yourapp.com/feedback/5874601',
'author_icon' => 'https://static.pexels.com/photos/61120/pexels-photo-61120-large.jpeg'
])->send('New user feedback');
```## Advanced usage
### Markdown
By default, Markdown is enabled for message text, but disabled for attachment fields. This behaviour can be configured in settings, or on the fly:
#### Send a message enabling or disabling Markdown
```php
$client->to('#weird')->disableMarkdown()->send('Disable *markdown* just for this message');$client->to('#general')->enableMarkdown()->send('Enable _markdown_ just for this message');
```#### Send an attachment specifying which fields should have Markdown enabled
```php
$client->to('#operations')->attach([
'fallback' => 'It is all broken, man',
'text' => 'It is _all_ broken, man',
'pretext' => 'From user: *JimBob*',
'color' => 'danger',
'mrkdwn_in' => ['pretext', 'text']
])->send('New alert from the monitoring system');
```### Explicit message creation
For convenience, message objects are created implicitly by calling message methods on the client. We can however do this explicitly to avoid hitting the magic method.
```php
// Implicitly
$client->to('@regan')->send('I am sending this implicitly');// Explicitly
$message = $client->createMessage();$message->to('@regan')->setText('I am sending this explicitly');
$message->send();
```### Attachments
When using attachments, the easiest way is to provide an array of data as shown in the examples, which is actually converted to an Attachment object under the hood. You can also attach an Attachment object to the message:
```php
$attachment = new Attachment([
'fallback' => 'Some fallback text',
'text' => 'The attachment text'
]);// Explicitly create a message from the client
// rather than using the magic passthrough methods
$message = $client->createMessage();$message->attach($attachment);
// Explicitly set the message text rather than
// implicitly through the send method
$message->setText('Hello world')->send();
```Each attachment field is also an object, an AttachmentField. They can be used as well instead of their data in array form:
```php
$attachment = new Attachment([
'fallback' => 'Some fallback text',
'text' => 'The attachment text',
'fields' => [
new AttachmentField([
'title' => 'A title',
'value' => 'A value',
'short' => true
])
]
]);
```You can also set the attachments and fields directly if you have a whole lot of them:
```php
// implicitly create a message and set the attachments
$client->setAttachments($bigArrayOfAttachments);// or explicitly
$client->createMessage()->setAttachments($bigArrayOfAttachments);
``````php
$attachment = new Attachment([]);$attachment->setFields($bigArrayOfFields);
```## Contributing
Please see [CONTRIBUTING](https://github.com/bluora/php-slack/blob/master/CONTRIBUTING.md) for details.
## Credits
* [Rocco Howard](https://github.com/therocis)
* [All Contributors](https://github.com/bluora/php-slack/contributors)## License
The BSD 2-clause. Please see [License File](https://github.com/bluora/php-slack/blob/master/LICENSE) for more information.