@hamta/adonis-orm
TypeScript icon, indicating that this package has built-in type declarations

1.0.14 • Public • Published

adonis-hashids

Hashids for AdonisJS 5

gh-workflow-image typescript-image npm-image license-image download-image

This package generates YouTube-like IDs for AdonisJS Lucid models using the hashids.js package. hashids.js is small JavaScript library to generate YouTube-like ids from numbers. Use it when you don't want to expose your database ids to the user.

Prerequisites

  • Adonis Lucid to be installed and configured

  • The db table must have a column named hashid of type string and it must be nullable.

Installation

npm i @fcoded/adonis-hashids or  yarn add @fcoded/adonis-hashids

Configuration

node ace configure @fcoded/adonis-hashids

The configuration file is in config/hashids.ts. The default salt will be the project name, the default minLength is 12 and it uses the default alphabet from the hashids.js package.

Using the Hashids Mixin

Apply the mixin on the model you.

import { compose } from '@ioc:Adonis/Core/Helpers'
import { column, BaseModel } from '@ioc:Adonis/Lucid/Orm'
import { LucidHashIds } from '@ioc:Adonis/Adons/LucidHashIds'

export default class User extends compose(BaseModel, LucidHashIds){

}

The mixin will update the hashid column after the recorded is created using the afterCreate Model hook

Also, if you are using Route model binding package, the routeLookupKey will be set to the hashid by default.

Package Sidebar

Install

npm i @hamta/adonis-orm

Weekly Downloads

18

Version

1.0.14

License

MIT

Unpacked Size

21.2 kB

Total Files

20

Last publish

Collaborators

  • ezarei88