Download the PHP package breachaware/laravel-cdn without Composer
On this page you can find all versions of the php package breachaware/laravel-cdn. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download breachaware/laravel-cdn
More information about breachaware/laravel-cdn
Files in breachaware/laravel-cdn
Package laravel-cdn
Short Description Content Delivery Network (CDN) Package for Laravel
License MIT
Informations about the package laravel-cdn
Laravel CDN Assets Manager
THIS PACKAGE IS STILL IN DEVELOPMENT. DO NOT USE THIS PACKAGE IN PRODUCTION!
A Content Delivery Network package for Laravel
The package allows you to upload your static assets to AWS S3 with a single Artisan command. Optionally, you may configure a CloudFront or CloudFlare URL.
to upload their assets (or any public file) to a CDN with a single artisan command. And then it allows them to switch between the local and the online version of the files.
Fork From Vinelab/cdn and publiux/laravelcdn
This project has been forked from https://github.com/publiux/laravelcdn, which was forked from https://github.com/Vinelab/cdn. All credit for the original work goes to Vinelab and publiux.
Laravel Support
- This package supports Laravel 5.5 up to an including Laravel 5.8 (
master
). - This package supports Laravel's package auto-discovery.
Highlights
- Support for AWS S3
- Support for AWS CloudFront
- Support for CloudFlare with an AWS S3 origin
- Artisan command to upload content to AWS S3
- A simple facade to access CDN assets including support for versioned assets using Laravel Mix.
Questions
- Is this package an alternative to Laravel FileSystem and do they work together?
- No, the package was introduced in Laravel 4 and it's main purpose is to manage your CDN assets by loading them from the CDN into your Views pages, and easily switch between your Local and CDN version of the files. As well it allows you to upload all your assets with single command after specifying the assets directory and rules. The FileSystem was introduced in Laravel 5 and it's designed to facilitate the loading/uploading of files form/to a CDN. It can be used the same way as this Package for loading assets from the CDN, but it's harder to upload your assets to the CDN since it expect you to upload your files one by one. As a result this package still not a replacement of the Laravel FileSystem and they can be used together.
Installation
Via Composer
Require breachaware/laravel-cdn
in your project:
If you are using Laravel 5.5 or higher, there is no need to register the service provider or alias as this package is automatically discovered.
Publish the package config file:
Environment Configuration
This package can be configured by editing the config/cdn.php file. Alternatively, you can set many of these options in as environment variables in your '.env' file.
AWS Credentials
Set your AWS Credentials and other settings in the .env
file.
Note: you should always have an .env
file at the project root, to hold your sensitive information. This file should usually not be committed to your VCS.
CDN URL
Set the CDN URL:
This can altered in your '.env' file as follows:
Bypass
To load your LOCAL assets for testing or during development, set the bypass
option to true
:
This can be altered in your '.env' file as follows:
Cloudfront Support
This can be altered in your '.env' file as follows:
Default CDN Provider
For now, the only CDN provider available is AwsS3. Although, as DO natively support the AWS API, you can utilise it by also providing the endpoint, please see the cdn.php config for more info. This option cannot be set in '.env'.
CDN Provider Configuration
Multiple Buckets
Files & Directories
Include:
Specify directories, extensions, files and patterns to be uploaded.
Exclude:
Specify what to be ignored.
Other Configurations
You can always refer to the AWS S3 Documentation for more details: aws-sdk-php
Usage
You can 'push' your assets to your CDN and you can 'empty' your assets as well using the commands below.
Push
Only changed assets are pushed to the CDN. (THanks, )
Upload assets to CDN
You can specify a folder upload prefix in the cdn.php config file. Your assets will be uploaded into that folder on S3.
Empty
Delete assets from CDN
CAUTION: This will erase your entire bucket. This may not be what you want if you are specifying an upload folder when you push your assets.
Retrieving Asset URLs
There are two primary options when retrieving the CDN URL of a static asset:
Unversioned assets
Use the CDN
facade to call the CDN::asset()
function.
Note: the asset
works the same as the Laravel asset
it start looking for assets in the public/
directory:
Versioned assets using Laravel Mix
Use the CDN
facade to call the CDN::mix()
method.
Note: the mix
method works by parsing the mix-manifest.json
file that is generated by webpack, the same as Laravel Mix
.
To use a file from outside the public/
directory, anywhere in app/
use the CDN::path()
function:
Test
To run the tests, run the following command from the project folder.
Support
Please request support or submit issues via Github
Contributing
Please see CONTRIBUTING for details.
Security Related Issues
If you discover any security related issues, please do not raise a Github issue. Instead, please email [email protected] with the details of the vulnerability.
Credits
- Mahmoud Zalt (original developer)
- Raul Ruiz (pre-fork contributor)
- Filipe Garcia (pre-fork contributor)
- Contributors from original project
- Brent Kozjak (current maintainer)
License
The MIT License (MIT). Please see License File for more information.
Changelog
v1.0.0
- Initial release from BreachAware
Note: The version history has been reset since forking from the original package.
All versions of laravel-cdn with dependencies
illuminate/support Version 5.0.*|5.1.*|5.2.*|5.3.*|5.4.*|5.5.*|5.6.*|5.7.*|5.8.*
illuminate/config Version 5.0.*|5.1.*|5.2.*|5.3.*|5.4.*|5.5.*|5.6.*|5.7.*|5.8.*
symfony/finder Version 2.*|3.*|4.*
symfony/console Version 2.*|3.*|4.*
aws/aws-sdk-php Version ~3.0