定制 mhcg/monolog-wp-cli 二次开发

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

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

mhcg/monolog-wp-cli

最新稳定版本:v2.1.0

Composer 安装命令:

composer require mhcg/monolog-wp-cli

包简介

Extension for Monolog to support outputting to WP-CLI (The WordPress command line interface) when running wp command lines.

README 文档

README

Packagist Version PHP CI

Extension for Monolog that routes log output through WP-CLI when running wp commands.

Requirements

  • PHP 8.3+
  • Monolog 2.5

Installation

composer require mhcg/monolog-wp-cli

Usage

WPCLIHandler works like any other Monolog handler. Create the handler and push it onto a logger inside a WP-CLI command context.

<?php

use Monolog\Logger;
use MHCG\Monolog\Handler\WPCLIHandler;

// Create a log channel.
$log = new Logger('name');
$log->pushHandler(new WPCLIHandler(Logger::WARNING));

// Output to WP-CLI.
$log->warning('This is a warning');
$log->error('An error has occurred');
$log->critical('This will report error and exit out');
$log->debug('Only shown when running wp with --debug');
$log->info('General logging - will not be shown when running wp with --quiet');

WordPress plugin-style example

The following example registers a mycommand WP-CLI command that writes log output through the handler.

This demonstrates the handler only. It is not a recommended project structure for building plugins or commands.

<?php
/**
 * Plugin Name:     My Plugin
 */

// my-plugin.php

use Monolog\Logger;
use MHCG\Monolog\Handler\WPCLIHandler;

// If this file is called directly, abort.
if ( ! defined( 'ABSPATH' ) ) {
    die;
}

// Autoload.
$autoload = dirname( __FILE__ ) . '/vendor/autoload.php';
if ( file_exists( $autoload ) ) {
    require_once $autoload;
}

// 'mycommand' WP-CLI command.
if ( defined( 'WP_CLI' ) && WP_CLI ) {

    function mycommand_command( $args ) {
        // Create logger.
        $log = new Logger( 'name' );
        $log->pushHandler( new WPCLIHandler( Logger::INFO ) );

        // Will only show when wp is run with --debug.
        $log->debug( 'Some geeky stuff' );

        // These will not show when wp is run with --quiet.
        $log->info( 'Started running' );
        $log->warning( 'Something happened of note' );

        // Always shows even with --quiet.
        $log->error( 'An error has occurred' );

        // No direct Monolog equivalent of WP_CLI::success.
        WP_CLI::success( 'Finished running mycommand' );
    }

    WP_CLI::add_command( 'mycommand', 'mycommand_command' );

}
wp mycommand
Started running
Warning: (WARNING) Something happened of note
Error: (ERROR) An error has occurred
Success: Finished running mycommand
wp mycommand --quiet
Error: (ERROR) An error has occurred

Development

Install dependencies:

composer install

Run local checks:

composer run test
composer run lint
composer run qa

CI runs on pull requests and pushes to main, validates Composer metadata, audits locked dependencies, runs PHPUnit on PHP 8.3 and 8.4, and runs PHPMD and PHPCS on PHP 8.3.

Testing and code quality

  • PHPUnit runs the test suite from tests.
  • PHPMD checks src for code-size and unused-code issues.
  • PHPCS enforces PSR-12 across src and tests.

Contributing

Fork the repository and open a pull request for code changes, referencing the related issue where relevant. Documentation improvements are also welcome through the wiki.

Please follow the Code of Conduct.

Support

Licence

Released under the MIT licence. See LICENSE for details.

统计信息

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

GitHub 信息

  • Stars: 10
  • Watchers: 2
  • Forks: 3
  • 开发语言: PHP

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固