定制 logger/pushover 二次开发

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

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

logger/pushover

最新稳定版本:1.0.0

Composer 安装命令:

composer require logger/pushover

包简介

A psr-3 compatible Pushover implementation

README 文档

README

A PSR‑3 compatible logger that sends messages to Pushover.

Requirements

  • PHP >= 8.0
  • logger/essentials (pulled via composer)
  • One of the following transports:
    • Built‑in cURL (ext-curl)
    • PSR‑18 HTTP client + PSR‑17 factories (suggested: psr/http-client, psr/http-factory)

Installation

Install via Composer in your application:

composer require logger/pushover

Basic Usage (cURL transport)

The simplest way uses the built‑in cURL transport. If no transport is provided, cURL is used automatically.

<?php

use Logger\PushoverLogger;

$user  = 'your-user-or-group-key';
$token = 'your-application-token';

// Optional default parameters are passed through to Pushover API.
$params = [
    'title' => 'My App',
    // 'sound' => 'pushover',
    // 'device' => 'iphone',
];

// cURL transport is used by default if you don’t pass one in
$logger = new PushoverLogger($user, $token, $params);

// Log using PSR-3
$logger->emergency('Database is down');   // priority 2, adds retry/expire
$logger->alert('High latency detected');  // priority 2
$logger->critical('Cache unavailable');   // priority 1
$logger->error('Background job failed');  // priority 0

Using PSR‑18 Transport

If you prefer a PSR‑18 client with PSR‑17 factories, use the provided transport.

Install a client and PSR‑7 implementation of your choice (examples):

composer require psr/http-client psr/http-factory nyholm/psr7 symfony/http-client
<?php

use Logger\PushoverLogger;
use Logger\PushoverLogger\Psr18TransportClient;
use Nyholm\Psr7\Factory\Psr17Factory;
use Symfony\Component\HttpClient\Psr18Client;

$user  = 'your-user-or-group-key';
$token = 'your-application-token';
$params = ['title' => 'My App'];

$psr17  = new Psr17Factory();
$client = new Psr18Client(); // Any PSR-18 ClientInterface implementation

$transport = new Psr18TransportClient(
    'https://api.pushover.net/1/messages.json',
    $client,
    $psr17,  // RequestFactoryInterface
    $psr17   // StreamFactoryInterface
);

$logger = new PushoverLogger($user, $token, $params, $transport);
$logger->emergency('Production outage');

How priorities are mapped

  • emergency and alert map to Pushover priority 2 (emergency) and automatically add retry=120 and expire=3600.
  • critical maps to 1.
  • error maps to 0.
  • Other PSR‑3 levels are sent with priority -1 (no priority).

Passing Pushover parameters

Any extra values in the $parameters array are passed straight to the Pushover API (e.g. title, sound, device, url, url_title). Refer to https://pushover.net/api for the full list.

Error handling

This logger catches throwables internally and does not throw on delivery failures to avoid impacting your application’s control flow. Consider monitoring delivery via your transport/client as needed.

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2014-11-20

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固