承接 codeldev/laravel-schedule-log 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

codeldev/laravel-schedule-log

最新稳定版本:1.0.0

Composer 安装命令:

composer require codeldev/laravel-schedule-log

包简介

A simple Laravel package that automatically logs every scheduled command execution to your database. It listens to Laravel's built-in schedulerevents to record information without wrapping or modifying the scheduler itself. Ships with configurable table names, swappable Eloquent models, and a built-

README 文档

README

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

A simple Laravel package that automatically logs every scheduled command execution to your database. It listens to Laravel's built-in scheduler events to record information without wrapping or modifying the scheduler itself. Ships with configurable table names, swappable Eloquent models, and a built-in prune command to manage retention.

Pest Tests: 100% Code Coverage | PHP Stan: Level Max

Requirements

  • PHP 8.4+
  • Laravel 13+

Installation

You can install the package via composer:

composer require codeldev/laravel-schedule-log

You can publish and run the migrations with:

php artisan vendor:publish --tag="schedule-log-migrations"
php artisan migrate

You can publish the config file with:

php artisan vendor:publish --tag="schedule-log-config"

This is the contents of the published config file:

return [
    'prune_days' => (int) env('SCHEDULE_LOG_PRUNE_DAYS', 365),
    'models' => [
        'commands' => CodelDev\LaravelScheduleLog\Models\LaravelScheduledCommand::class,
        'history'  => CodelDev\LaravelScheduleLog\Models\LaravelScheduledCommandHistory::class,
    ],
    'tables' => [
        // Stores the scheduled commands
        'commands' => env('SCHEDULE_LOG_TABLE_COMMANDS', 'scheduled_commands'),
        'history'  => env('SCHEDULE_LOG_TABLE_HISTORY', 'scheduled_commands_history'),
    ],
];

Environment Variables

The following env variables are available to configure the package using your env file.

SCHEDULE_LOG_PRUNE_DAYS=365
SCHEDULE_LOG_TABLE_COMMANDS=scheduled_commands
SCHEDULE_LOG_TABLE_HISTORY=scheduled_commands_history

⚠️ Required!

In order for the output to be stored for each command, you must add the storeOutput() method to your schedule command.

Schedule::command('custom:command')
    ->storeOutput()
    ->weeklyOn(1, '02:30')
    ->withoutOverlapping();

Usage

Add to your routes/console.php file:

Schedule::command('schedule-log:prune')
    ->weeklyOn(1, '02:30')
    ->withoutOverlapping();

Run manually:

php artisan schedule-log:prune

Querying the Data

The package provides two Eloquent models you can use directly:

use CodelDev\LaravelScheduleLog\Models\LaravelScheduledCommand;
use CodelDev\LaravelScheduleLog\Models\LaravelScheduledCommandHistory;

// Get all logged commands
$commands = LaravelScheduledCommand::all();

// Get history for a specific command
$history = LaravelScheduledCommand::query()
    ->where('command', 'inspire')
    ->with('history')
    ->first()
    ->history;

// Get all failed runs
$failed = LaravelScheduledCommandHistory::query()
    ->where('status', LaravelScheduledRunStatusEnum::FAILED)
    ->latest('started_at')
    ->get();

// Get the last run for a command
$lastRun = LaravelScheduledCommandHistory::query()
    ->whereHas('scheduledCommand', fn ($q) => $q->where('command', 'inspire'))
    ->latest('started_at')
    ->first();

Available Fields

LaravelScheduledCommand

Field Type
id string (UUID)
command string
description string|null
created_at CarbonImmutable
updated_at CarbonImmutable

LaravelScheduledCommandHistory

Field Type
id string (UUID)
scheduled_command_id string (UUID)
started_at CarbonImmutable
completed_at CarbonImmutable|null
status LaravelScheduledRunStatusEnum
output string|null
error string|null
duration_ms int|null
created_at CarbonImmutable
updated_at CarbonImmutable

Using Custom Models

You can extend the package models to add your own behaviour, scopes, or relationships. Create your custom model, extend the package model, then update the config:

use CodelDev\LaravelScheduleLog\Models\LaravelScheduledCommandHistory as BaseHistory;

class ScheduledCommandHistory extends BaseHistory
{
    public function scopeFailed($query)
    {
        return $query->where('status', LaravelScheduledRunStatusEnum::FAILED);
    }
}

Then in config/schedule-log.php:

'models' => [
    'commands' => \App\Models\ScheduledCommand::class,
    'history'  => \App\Models\ScheduledCommandHistory::class,
],

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

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

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-11

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固