amamarul / integer-hashids by amamarul

Laravel Integers Hashids Generator. Encode and decode ids to Integers. Also generate prefixed hashids
17,670
4
2
Package Data
Maintainer Username: amamarul
Maintainer Contact: ama_marul@hotmail.com (Maru Amallo-amamarul)
Package Create Date: 2017-03-22
Package Last Update: 2024-03-26
Language: PHP
License: MIT
Last Refreshed: 2024-04-12 03:11:08
Package Statistics
Total Downloads: 17,670
Monthly Downloads: 173
Daily Downloads: 8
Total Stars: 4
Total Watchers: 2
Total Forks: 5
Total Open Issues: 3

Laravel Integer Hashids

Make Integers Hashids

This package is an adaptation and combination of the following 3 packages:

  • Laravel-Manager https://github.com/GrahamCampbell/Laravel-Manager
  • Hashids https://github.com/ivanakimov/hashids.php
  • Laravel Hashids https://github.com/vinkla/laravel-hashids

This package works like Laravel Hashids but you can make integers hashids placing in alphabet connections only numbers and you can implement prefix ids. Also you can use encode() and decode() helpers. You can also make alphanumeric Hashids

Installation

Composer require

$ composer require amamarul/integer-hashids

Add Provider into config/app.php

Amamarul\Hashids\HashidsServiceProvider::class,

Publish config file

$ php artisan vendor:publish --provider='Amamarul\Hashids\HashidsServiceProvider'

Usage

  1. Setup the Config file (config/hashids.php) You can create differents connections with differents parameters
    'default' => 'main',
    'prefix-separator' => '-',

    '<Name Connection>' => [
        'salt' => 'your-salt-string',
        'length' => '10',
        'alphabet' => '0123456789',
        'prefix' => null,
    ],
  • Name Connection: There are a 'main' connection that is used by default but you can create custom connections and then call them.

  • salt: is a phrase string.

  • length: Number of characters you need

  • alphabet: you can set any character to make the hash, but if you want integer hashid keep the same ('0123456789').

  • prefix: if you want a prefixed hashid you can add the prefix, if not you can omit it or delete the parameter.

  • prefix-separator: If you use a prefix maybe do you want to use a prefix separator. If not leave empty ('').

  • default: you can change the default connection

  1. With 'main' connection and without 'prefix' ('prefix' => null)
  use Hashids;

  Hashids::encode(1548);
  // output: 7988887798

  Hashids::decode('7988887798');
  // output: 1548
  1. With 'main' connection and with 'prefix' ('prefix' => 'AA')
  use Hashids;

  Hashids::encode(1548);
  // output: AA-7988887798

  Hashids::decode('AA-7988887798');
  // output: 1548
  1. With 'custom' name connection and with and without 'prefix'
  use Hashids;

  Hashids::connection('custom')->encode(1548);
  // output: 7988887798

  Hashids::connection('custom')->decode('7988887798');
  // output: 1548
  1. If you prefer to use dependency injection over facades, you can inject the manager:
  • With 'main' connection
      use Amamarul\Hashids\Support\HashidsManager;
    
      class Foo
      {
      	protected $hashids;
    
      	public function __construct(HashidsManager $hashids)
      	{
      		$this->hashids = $hashids;
      	}
    
      	public function encode($id)
      	{
      		$this->hashids->encode($id)
      	}
    
      	public function decode($hashid)
      	{
      		$this->hashids->decode($hashid)
      	}
      }
    
  • With 'custom' connection
      use Amamarul\Hashids\Support\HashidsManager;
    
      class Foo
      {
      	protected $hashids;
    
      	public function __construct(HashidsManager $hashids)
      	{
      		$this->hashids = $hashids->connection('custom');
      	}
    
      	public function encode($id)
      	{
      		$this->hashids->encode($id)
      	}
    
      	public function decode($hashid)
      	{
      		$this->hashids->decode($hashid)
      	}
      }
    

Helpers

You can use the 'encode()' and 'decode()' helpers

  • encode()
  // with 'main' connection
  encode($id)
  // with 'custom' connection
  encode($id,'custom')
  • decode()
  // with 'main' connection
  decode($hashid)
  // with 'custom' connection
  decode($hashid,'custom')

Feel free to send improvements

Created by Maru Amallo-amamarul