- Overview
- Installation
- Usage
- Security
- Credits
- License
A Laravel package that can be used for adding shortened URLs to your existing web app.
Quick note: You must have a basic understanding of the use of the artisan command and composer for installing laravel package.
The package has been developed and tested to work with the following minimum requirements:
- PHP >= 8.0
- Laravel >= 8.0
You can install the package via Composer:
composer require roddy/url-shortener
You can then publish the package's config file and database migrations by using the following command:
php artisan vendor:publish --provider="Roddy\UrlShortener\UrlShortenerProvider"
This package contains a migration that add a new table to the database: url_shortener
. To run this migration, simply run the following command:
php artisan migrate
There are two(2) ways to start using url-shortener
- Generate Shortened Url and Store it into the Database
- Generate Shortened Url Without Storing it into the Database
To store a generated shortened url, you need to add the store
method.
For example:
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->store()
->generate();
To not store a generated shortened url, you do not need to add the store
method.
For example:
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')->generate();
By default the domain for the shortened url will be the current domain of the website.
For example if the domain for your website is http://mywebsite.com, your shortened url will use http://mywebsite.com as the domain.
You can change it by setting the domain
in config/urlshortener.php
to the domain you want.
By default, the shortened URL that is generated will contain a random url key. The url key will be of the length that you define in the config files (defaults to 7 characters). Config file can be found in config/urlshortener.php
.
Example: if a URL is https://domain/aBc1234
, the key is aBc1234
.
You may wish to define a custom url key for your shortened url rather than generating a random key. You can do this by using the ->customKey()
method.
Examples:
- This example will store the generated shortened url with the custom key into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->customKey("custom-url-key") //param should be a string
->store()
->generate();
// Short URL: https://domain.com/custom-key
- This example will generated a shortened url with the custom key without storing it into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->customKey("custom-url-key") //param should be a string
->generate();
// Short URL: https://domain.com/custom-key
Urlshortener allows you to add a user id to the generated short url to indicate the user that generated it. By default it is null
, you can add a user id by using the ->byUerId()
method.
Examples:
- This example will store the generated shortened url with the user id into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->byUserId(1) //param should be a string or int
->store()
->generate();
- This example will generated a shortened url with the user id without storing it into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->byUserId(1) //param should be a string or int
->generate();
By default, all short URLs that you generate can be access on the day you generated it. However, you may set a
date for accessing your URLs when you're generating them. You can do this by using the ->schedule()
method.
The ->schedule()
method accepts number of days as the parameter and it must be int
.
Exapmles:
- This example will store the generated shortened url with the schedule date into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->schedule(2) //This will schedule it to the next 2 days
->store()
->generate();
- This example will generated a shortened url with the schedule date without storing it into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->schedule(2) //This will schedule it to the next 2 days
->generate();
You can generate a QrCode image for your short url by using the ->generateQrCodeImage()
method.
Note: This method generate an image url for the QrCode, example of the image url 
.
Note: You can not use ->generateQrCodeSvg()
and ->generateQrCodeImage()
at the same time, you have to use only one of them.
Examples of usage:
- This example will store the generated shortened url with the generated QrCode Image into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->generateQrCodeImage() //add this method
->store()
->generate();
- This example will generated a shortened url with the generated QrCode Image without storing it into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->generateQrCodeImage() //add this method
->generate();
You can generate a QrCode svg for your short url by using the ->generateQrCodeSvg()
method.
Note: You can not use ->generateQrCodeSvg()
and ->generateQrCodeImage()
at the same time, you have to use only one of them.
Examples of usage:
- This example will store the generated shortened url with the generated QrCode Svg into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->generateQrCodeSvg() //add this method
->store()
->generate();
- This example will generated a shortened url with the generated QrCode Svg without storing it into the database;
use Roddy\UrlShortener\UrlShortenerGenerator;
UrlShortenerGenerator::originalUrl('https://orginalurl.com')
->generateQrCodeSvg() //add this method
->generate();
- You can not use
->generateQrCodeSvg()
and->generateQrCodeImage()
at the same time, you have to use only one of them. - The
->generate()
method should always be the last method. - The
->schedule()
method accepts only int/number as the days parameter.
To find the ShortURL model that corresponds to a given shortened URL id, you can use the findById()
method.
For example, to find the ShortURL model of a shortened URL that has the id 1
, you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::findById(1);
To find the ShortURL model that corresponds to a given shortened URL key, you can use the findByKey()
method.
For example, to find the ShortURL model of a shortened URL that has the key aBcD234
, you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::findByKey('aBcD234');
To find the ShortURL model that corresponds to a given shortened URL original Url, you can use the findByOriginalUrl()
method.
For example, to find all of the ShortURL models of shortened URLs with original url of https://originalUrl.com
, you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::findByOriginalUrl("https://destination.com");
To find the ShortURL model that corresponds to a given custom query or filter, you can use the findWhere()
method.
For example, to find all shortened url where id is greater than 1
you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::findWhere("id", ">", "1");
Note: the findWhere()
method takes 3 parameters, which are column, opertor, value
, you can set the oprator
parameter to null
if you don't want to provide an operator
.
Example:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::findWhere("id", null, "1");
To get all Shortened URL, you can use the getAll()
method.
Example:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::getAl);
Note: All the delete methods returns an array.
To delete the ShortURL model that corresponds to a given shortened URL id, you can use the deleteById()
method.
For example, to delete the ShortURL model of a shortened URL that has the id 1
, you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::deleteById(1);
To delete the ShortURL model that corresponds to a given shortened URL key, you can use the deleteByKey()
method.
For example, to delete the ShortURL model of a shortened URL that has the key aBcD234
, you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::deleteByKey('aBcD234');
To delete the ShortURL model that corresponds to a given shortened URL original url, you can use the deleteByOriginalUrl()
method.
For example, to delete the ShortURL model of a shortened URL that has the original url https://originalUrl.com
, you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::deleteByOriginalUrl('https://originalUrl.com');
To delete the ShortURL model that corresponds to a given custom query or filter, you can use the deleteWhere()
method.
For example, to delete all shortened url where id is greater than 1
you could use the following:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::deleteWhere("id", ">", "1");
Note: the deleteWhere()
method takes 3 parameters, which are column, opertor, value
, you can set the oprator
parameter to null
if you don't want to provide an operator
.
Example:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = UrlShortenerModel::deleteWhere("id", null, "1");
urlShortenerDB returns the urlShortener Model which allows you to use all the Eloquent
methods provided by Laravel.
To see the Eloquent methods click here or visit https://laravel.com/docs/10.x/eloquent.
Example of Usage:
use Roddy\UrlShortener\Model\UrlShortenerModel
$shortURL = urlShortenerDB::findOrFail(1); //You can use any of the Eloquent query building
If you find any security related issues, please contact me directly at alfrednti5000@gmail.com to report it.
If you wish to make any changes or improvements to the package, feel free to make a pull request.
- Alfred Nti
- Chillerlan (QrCode Generator)
- All Contributors
The MIT License (MIT). Please see License File for more information.