承接 edgaras/laravel-system-backup 相关项目开发

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

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

edgaras/laravel-system-backup

最新稳定版本:v0.2.0

Composer 安装命令:

composer require edgaras/laravel-system-backup

包简介

Laravel package to perform a full system backup, compress it into a zip file, and optionally email it or upload to the cloud.

README 文档

README

Laravel package to perform a full system backup, compress it into a zip file, and optionally email it or upload to the cloud.

Features

  • Zips the entire Laravel application directory.
  • Exclude list to skip unnecessary files (e.g. .env, vendor, node_modules).
  • Optional AES‑256 encryption for the archive.
  • Retention policy – keep only N most recent backups.
  • Upload to any configured filesystem disk (e.g. Azure, S3) and generate a signed URL.
  • Send a configurable email with the local path or cloud link.
  • Artisan command backup:system with --email flag.

Changelog

v0.2.0

  • Fixed retention off‑by‑one (cloud): deletes one too many/too few backups.
  • Signed local download links in emails: generate a temporary signed URL to the provided download route instead of emailing a local filesystem path.
  • Route configurability: added prefix for the download route.
  • Safer, scalable cloud uploads: stream file to the disk; gracefully handle drivers without temporaryUrl.

⚠️ Disclaimer

This package is functional but not thoroughly tested in production environments. Use with caution and verify backups independently before relying on it for critical systems.

Requirements

  • PHP 8.2+
  • Laravel 12

Installation

composer require edgaras/laravel-system-backup

Publish assets:

# Mail blade view
php artisan vendor:publish --tag=backup-mail-view

# Config file
php artisan vendor:publish --tag=backup-config

Usage

Manual backup

php artisan backup:system          # create archive only
php artisan backup:system --email  # create archive and send e‑mail

Configuration (config/backup.php)

return [
    // Where archives are stored locally
    'backup_path' => storage_path('app/backups'),

    // Backup file name 
    'zip_name' => 'system-backup-' . date('YmdHis') . '.zip',

    // Patterns to exclude from the archive
    'exclude' => [
        '.env', 
        '.env.*', 
        '.git', 
        '.gitignore',
        'composer.lock', 
        'vendor', 
        'node_modules',
        'storage/app/backups', 
        'storage/framework', 
        'storage/logs',
    ],

    // Optional AES‑256 encryption password (set in .env)
    'encryption_password' => env('BACKUP_ENCRYPTION_PASSWORD', null),

    // Add .htaccess (Deny from all) to backup_path
    'restrict_access' => true,

    // Keep only the N newest archives (local or cloud)
    'retention' => [
        'enabled' => true,
        'max_backups' => 5,
    ],

    // Cloud storage
    'cloud' => [
        'enabled' => false,           // true = upload instead of storing locally
        'disk'    => 'azure',         // any disk defined in config/filesystems.php
        'path'    => 'backups/path',  // folder inside the disk
        'signed_url_expiry' => 24,    // link validity in hours
    ],

    // Email notification
    'email' => [
        'enabled'    => false,
        'recipients' => ['hello@demomailtrap.co'],
        'subject'    => 'System Backup Completed',
        'body'       => 'Your system backup has finished successfully. Download using the link below (valid for 24 hours):',
        'from' => [
            'address' => env('MAIL_FROM_ADDRESS', 'hello@demomailtrap.co'),
            'name'    => env('MAIL_FROM_NAME', 'Laravel Backup'),
        ], 
        'use_cloud_link' => false,
    ],
    // Signed local download link expiry, in hours
    'download_link_expiry' => 24,

    // Route that serves local downloads (signed)
    'download_route' => [
        'middleware' => ['web', 'signed'],
        'prefix' => '/backups/download'
    ],
];

Environment variables

BACKUP_ENCRYPTION_PASSWORD=secretpass

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-12