Coder Social home page Coder Social logo

jzxyouok / hipchat Goto Github PK

View Code? Open in Web Editor NEW

This project forked from laravel-notification-channels/hipchat

0.0 2.0 0.0 53 KB

HipChat Notifications Channel for Laravel 5.3

Home Page: http://laravel-notification-channels.com

License: MIT License

PHP 100.00%

hipchat's Introduction

HipChat Notifications Channel for Laravel 5.3

Latest Version on Packagist Software License Build Status StyleCI SensioLabsInsight Quality Score Code Coverage Total Downloads

This package makes it easy to send HipChat notifications with Laravel 5.3.

Contents

Installation

You can install the package via composer:

composer require laravel-notification-channels/hipchat

You must install the service provider:

// config/app.php
'providers' => [
    ...
    NotificationChannels\HipChat\HipChatServiceProvider::class,
],

Setting up the HipChat service

Add your HipChat Account Token and optionally the default room and Hipchat API server's base url to your config/services.php:

// config/services.php
...
'hipchat' => [
    'token' => env('HIPCHAT_TOKEN'),
    // Default room (optional)
    'room' => 'Notifications',
    // Base URL for Hipchat API server (optional)
    'url' => 'https://api.your.hipchat.server.com',
],
...

Usage

Sending a simple room notification

Note: In order to be able to send room notifications you would need an auth token (both personal and room tokens will work) with the send_notification scope.

use NotificationChannels\HipChat\HipChatChannel;
use NotificationChannels\HipChat\HipChatMessage;
use Illuminate\Notifications\Notification;

class UserRegistered extends Notification
{
    public function via($notifiable)
    {
        return [HipChatChannel::class];
    }

    public function toHipChat($notifiable)
    {
        return HipChatMessage::create()
            ->room('New Registrations')
            ->html("<strong>A new user has registered!</strong>")
            ->success()
            ->notify();
    }
}

Sending a room notification with a card

Read more about HipChat notification cards here.

public function toHipChat($notifiable)
{
    return HipChatMessage::create()
        ->text('Laravel 5.3 has arrived!')
        ->notify(true)
        ->card(Card::create()
            ->title('Laravel')
            ->style(CardStyles::APPLICATION)
            ->url('http://laravel.com')
            ->html('Laravel 5.3 has arrived! The best release ever!')
            ->cardFormat(CardFormats::MEDIUM)
            ->icon('http://bit.ly/2c7ntiF')
            ->activity('Laravel 5.3 has arrived!', 'http://bit.ly/2c7ntiF')
            ->addAttribute(CardAttribute::create()
                ->label('Laravel Scout')
                ->icon('http://bit.ly/2c7ntiF')
                ->value('Driver based full-text search.')
                ->url('https://laravel.com/docs/5.3/scout')
            )
            ->addAttribute(CardAttribute::create()
                ->label('Laravel Echo')
                ->icon('http://bit.ly/2c7ntiF')
                ->value('Event broadcasting, evolved.')
                ->url('https://laravel.com/docs/5.3/broadcasting')
            )
            ->addAttribute(CardAttribute::create()
                ->label('Laravel Passport')
                ->icon('http://bit.ly/2c7ntiF')
                ->value('API authentication.')
                ->url('https://laravel.com/docs/5.3/passport')
            )
        );
}

Sharing a file in a HipChat room

Note: In order to be able to share files you would need an auth token (i.e. personal token) with the send_message scope. You can create such token by visiting HipChat -> Account Setting -> API Access.

In majority of cases all you need is just a path to an exisiting file you want to share

public function toHipChat($notifiable)
{
    return HipChatFile::create($this->user->photo);
}

You can optionally send a text message along the way

public function toHipChat($notifiable)
{
    return HipChatFile::create($this->user->photo);
        ->text("Look we've got a new user!");
}

If you need more control and/or you're creating the content of the file on the fly

public function toHipChat($notifiable)
{
    return HipChatFile::create()
        ->fileName('user_photo.png')
        ->fileType('image/png')
        ->fileContent(fopen('http://example.com/user/photo/johndoe', 'r'))
        ->text("Look we've got a new user!");
}

Available methods

HipChatMessage

  • create(): Creates a new HipChatMessage instance.
  • room(): Sets the id or name of the HipChat room to send the notification to.
  • from(): Sets the optional label to be shown in addition to the sender's name.
  • content(): Sets the content of the notification message.
  • text(): Sets the format to plain text and optionally the content.
  • html(): Sets the format to html and optionally the content. Allowed HTML tags: a, b, i, strong, em, br, img, pre, code, lists, tables.
  • color(): Sets the color of the message. See MessageColors for allowec values.
  • notify(): Specifies if a message should trigger a user notification in a Hipchat client.
  • info(): Sets notification level to info and color to MessageColors::GRAY.
  • success(): Sets notification level to success and color to MessageColors::GREEN.
  • error(): Sets notification level to info and color to MessageColors::RED.

Card

  • create(): Creates a new Card instance.
  • title(): Sets the title of the card.
  • id(): Sets the id of the card.
  • style(): Sets the style of the card. See CardStyles for allowed values.
  • text(): Sets the format to plain text and optionally the content.
  • html(): Sets the format to html and optionally the content.
  • cardFormat(): Sets the format of the card. See CardFormats for allowed values.
  • url(): Sets the url of the card.
  • thumbnail(): Sets the thumbnail of the card.
  • activity(): Sets the activity info of the card.
  • icon(): Sets the icon of the card.
  • addAttribute(): Adds a CardAttribute to the card.

CardAttribute

  • create(): Creates a new CardAttribute instance.
  • value(): Sets the textual value of the attribute.
  • label(): Sets the label of the attribute.
  • url(): Sets the url of the attribute.
  • style(): Sets the style of the attribute. See CardAttributeStyles for allowed values.
  • icon(): Sets the icon of the attribute.

HipChatFile

  • create(): Creates a new HipChatFile instance.
  • room(): Sets the id or name of the HipChat room to share the file in.
  • path(): Sets the fileContent to the resource of the existing file and tries to detect and set the fileName and fileType if they weren't explicitely set.
  • fileName: Sets the name of the file.
  • fileContent: Explicitely sets the content of the file. It can be a string, stream or a file resource. If a resource was passed it tries to detect and set the fileType if it wasn't explicitely set.
  • fileType: Explicitely sets the content (mime) type of the file.
  • text(): Sets a text message to be sent along with the file.

Testing

$ composer test

Security

If you discover any security related issues, please email [email protected] instead of using the issue tracker.

Changelog

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Credits

Special thanks to Jerry Price for his help.

License

The MIT License (MIT). Please see License File for more information.

hipchat's People

Contributors

pmatseykanets avatar freekmurze avatar themsaid avatar mpociot avatar casperboone avatar oyed avatar lbausch avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.