Hire Laravel developers with AI expertise at $20/hr. Get started in 48 hours.

Laravel Sharelink

Laravel Sharelink stats

Downloads
0
Stars
8
Open Issues
0
Forks
0

View on GitHub →

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

Laravel ShareLink

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


πŸš€ 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.
Grazulex photo

Hi, I'm Jean‑Marc Strauven (aka @grazulex) β€” a passionate developer, open-source enthusiast, and clean-code advocate.

Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.


Grazulex Laravel Sharelink Related Articles

Generate Secure Temporary Share Links for Files in Laravel image

Generate Secure Temporary Share Links for Files in Laravel

Read article
Dynamic Relationship Loading in Laravel image

Dynamic Relationship Loading in Laravel

Read article
PhpStorm logo

PhpStorm

The go-to PHP IDE with extensive out-of-the-box support for Laravel and its ecosystem.

PhpStorm
Honeybadger logo

Honeybadger

Simple developer-focused application monitoring for Laravel. Error tracking, log management, uptime monitoring, status pages, and more!

Honeybadger
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
Get expert guidance in a few days with a Laravel code review logo

Get expert guidance in a few days with a Laravel code review

Expert code review! Get clear, practical feedback from two Laravel devs with 10+ years of experience helping teams build better apps.

Get expert guidance in a few days with a Laravel code review
Acquaint Softtech logo

Acquaint Softtech

Acquaint Softtech offers AI-ready Laravel developers who onboard in 48 hours at $3000/Month with no lengthy sales process and a 100 percent money-back guarantee.

Acquaint Softtech
The Certification of Competence for Laravel logo

The Certification of Competence for Laravel

A community-driven, proctored assessment across 4 levels designed to validate real-world Laravel knowledge, from Junior to mastery-level Artisan. Official Vue.js, Official Nuxt, Angular, React, JS certifications also available.

The Certification of Competence for Laravel