grazulex/laravel-sharelink

Generate, manage, and secure temporary share links for files, routes, and model previews.

v1.0.0 2025-08-08 10:57 UTC

This package is auto-updated.

Last update: 2025-08-10 07:38:04 UTC


README

Laravel ShareLink

Generate, manage, and secure temporary share links for files, routes, and models

A powerful Laravel package for creating secure, time-limited sharing capabilities with comprehensive audit trails

Latest Version Total Downloads License PHP Version Laravel Version Tests Code Style

๐Ÿš€ Overview

Laravel ShareLink is a comprehensive package for generating secure, time-limited sharing capabilities in your Laravel applications. Perfect for sharing files, creating temporary access to routes, or providing time-limited previews of model data with complete audit trails and advanced security features.

โœจ Key Features

  • ๐Ÿ”— Multiple Resource Types - Share files, routes, and model previews seamlessly
  • โฐ Time-Limited Access - Set expiration dates and usage limits
  • ๐Ÿ”’ Password Protection - Optional password gates for enhanced security
  • ๐Ÿšซ Rate Limiting - Per-token rate limiting to prevent abuse
  • ๐ŸŒ IP Filtering - Allow/deny specific IP addresses or CIDR ranges
  • ๐Ÿ” Signed URLs - Optional Laravel signed route integration
  • ๐Ÿ”ฅ Burn After Reading - One-time access links that self-destruct
  • ๐Ÿ“Š Comprehensive Auditing - Track access patterns, IPs, and timestamps
  • ๐Ÿ›ก๏ธ Advanced Security - Password throttling, brute force protection
  • ๐ŸŽฏ Flexible Delivery - Support for X-Sendfile, X-Accel-Redirect, and streaming
  • ๐Ÿ“‹ Management API - Revoke and extend links programmatically
  • ๐ŸŽจ CLI Commands - Full Artisan command support
  • ๐Ÿ“ˆ Observability - Built-in logging and metrics integration
  • ๐Ÿงช Test-Friendly - Comprehensive test coverage with easy mocking

๐Ÿ“ฆ Installation

Install the package via Composer:

composer require grazulex/laravel-sharelink

Publish and run the migrations:

php artisan vendor:publish --tag="sharelink-migrations"
php artisan migrate

Optionally, publish the configuration file:

php artisan vendor:publish --tag="sharelink-config"

๐Ÿ’ก Auto-Discovery: The service provider will be automatically registered thanks to Laravel's package auto-discovery.

โšก Quick Start

๐Ÿš€ Basic Usage

use Grazulex\ShareLink\Facades\ShareLink;

// Share a file with expiration
$link = ShareLink::create('/path/to/document.pdf')
    ->expiresIn(60) // 60 minutes
    ->maxClicks(5)
    ->withPassword('secret123')
    ->generate();

echo $link->url; // https://yourapp.com/share/abc123xyz

๐Ÿ“ File Sharing

// Share a local file
$link = ShareLink::create('/storage/documents/report.pdf')
    ->expiresIn(1440) // 24 hours
    ->maxClicks(10)
    ->generate();

// Share via Laravel Storage
$link = ShareLink::create('s3://bucket/private/document.pdf')
    ->expiresIn(60)
    ->withPassword('secure')
    ->generate();

๐ŸŒ Route Sharing

// Share a named route with parameters
$link = ShareLink::create([
    'type' => 'route',
    'route' => 'user.profile',
    'parameters' => ['user' => 123]
])
->expiresIn(120)
->generate();

๐Ÿ“Š Model Preview

// Share a model preview (JSON representation)
$user = User::find(1);
$link = ShareLink::create([
    'type' => 'model',
    'class' => User::class,
    'id' => $user->id
])
->expiresIn(30)
->generate();

๐Ÿ”ฅ Advanced Security Features

// Burn-after-reading link with IP restrictions
$link = ShareLink::create('/secure/document.pdf')
    ->expiresIn(60)
    ->burnAfterReading() // Self-destructs after first access
    ->metadata([
        'allowed_ips' => ['192.168.1.0/24', '10.0.0.1'],
        'denied_ips' => ['192.168.1.100']
    ])
    ->generate();

// Signed URL for extra security
$signedUrl = ShareLink::signedUrl($link, now()->addHour());

๐Ÿ”ง Requirements

  • PHP 8.3+
  • Laravel 11.0+ | 12.0+

๐Ÿ“š Complete Documentation

For comprehensive documentation, examples, and advanced usage guides, visit our Wiki:

๐Ÿ“– ๐Ÿ‘‰ Laravel ShareLink Wiki

The wiki includes:

๐ŸŽจ Artisan Commands

Laravel ShareLink includes powerful CLI commands for managing your share links:

# Create a new share link
php artisan sharelink:create /path/to/file --expires=60 --max-clicks=5

# List all share links
php artisan sharelink:list --active --expired

# Revoke a specific link
php artisan sharelink:revoke abc123xyz

# Clean up expired links
php artisan sharelink:prune --days=7

๐Ÿ”ง Configuration

The package comes with sensible defaults, but you can customize everything:

// config/sharelink.php
return [
    'route' => [
        'prefix' => 'share',
        'middleware' => ['web'],
    ],
    
    'security' => [
        'signed_routes' => [
            'enabled' => true,
            'required' => false,
        ],
        'rate_limiting' => [
            'enabled' => true,
            'max_attempts' => 10,
        ],
        'password_throttling' => [
            'enabled' => true,
            'max_attempts' => 5,
        ],
    ],
    
    'delivery' => [
        'x_sendfile' => false,
        'x_accel_redirect' => false,
    ],
];

๐Ÿงช Testing

composer test

๐Ÿค Contributing

Please see CONTRIBUTING.md for details.

๐Ÿ”’ Security

If you discover any security-related issues, please email jms@grazulex.be instead of using the issue tracker.

๐Ÿ“ Changelog

Please see the Wiki Changelog for more information on what has changed recently.

๐Ÿ“„ License

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

๐Ÿ‘ฅ Credits

๐Ÿ’ฌ Support

Laravel ShareLink - Secure, time-limited sharing for Laravel applications
with comprehensive audit trails and advanced security features.