Search…
Hapi
@adminjs/hapi
Make sure you have installed AdminJS packages described in Getting started article.
$ yarn add adminjs @adminjs/hapi
To setup AdminJS panel with Hapi you need to have @hapi/hapi installed and required peer dependencies:
$ yarn add @hapi/hapi @hapi/boom @hapi/cookie @hapi/inert
Afterwards, follow one of the examples below.

Simple

Javascript
Typescript
app.js
const { default: AdminJSHapi } = require('@adminjs/hapi')
const Hapi = require('@hapi/hapi')
const PORT = 3000
const start = async () => {
const server = Hapi.server({ port: PORT })
const adminOptions = {
resources: [],
rootPath: '/admin',
auth: {
isSecure: process.env.NODE_ENV === 'production',
},
registerInert: true,
}
await server.register({
plugin: AdminJSHapi,
options: adminOptions,
})
await server.start();
console.log(`AdminJS available at ${server.info.uri}${adminOptions.rootPath}`);
}
start()
Now you can start your AdminJS application:
$ node app.js
Install ts-node:
$ yarn add -D ts-node
app.ts
import AdminJSHapi, { ExtendedAdminJSOptions } from '@adminjs/hapi'
import Hapi from '@hapi/hapi'
const PORT = 3000
const start = async () => {
const server = Hapi.server({ port: PORT })
const adminOptions: ExtendedAdminJSOptions = {
resources: [],
rootPath: '/admin',
auth: {
isSecure: process.env.NODE_ENV === 'production',
},
registerInert: true,
}
await server.register<ExtendedAdminJSOptions>({
plugin: AdminJSHapi,
options: adminOptions,
})
await server.start();
console.log(`AdminJS available at ${server.info.uri}${adminOptions.rootPath}`);
}
start()
Now you can start your AdminJS application:
$ ts-node app.ts

Authentication

To add authentication, all you have to do is extend auth config with authenticate, cookieName and cookiePassword.
Javascript
Second Tab
app.js
const { default: AdminJSHapi } = require('@adminjs/hapi')
const Hapi = require('@hapi/hapi')
const PORT = 3000
const DEFAULT_ADMIN = {
password: 'password',
test: 'abc',
}
const authenticate = async (email, password) => {
if (email === DEFAULT_ADMIN.email && password === DEFAULT_ADMIN.password) {
return Promise.resolve(DEFAULT_ADMIN)
}
return null
}
const start = async () => {
const server = Hapi.server({ port: PORT })
// "secret" must be a string with at least 32 characters, example:
const cookieSecret = 'sieL67H7GbkzJ4XCoH0IHcmO1hGBSiG5'
const adminOptions = {
resources: [],
rootPath: '/admin',
auth: {
isSecure: process.env.NODE_ENV === 'production',
authenticate,
cookieName: 'adminjs',
cookiePassword: cookieSecret,
},
registerInert: true,
}
await server.register({
plugin: AdminJSHapi,
options: adminOptions,
})
await server.start();
console.log(`AdminJS available at ${server.info.uri}${adminOptions.rootPath}`);
}
start()
Now you can start your AdminJS application:
$ node app.js
Install ts-node:
$ yarn add -D ts-node
app.ts
import AdminJSHapi, { ExtendedAdminJSOptions } from '@adminjs/hapi'
import Hapi from '@hapi/hapi'
const PORT = 3000
const DEFAULT_ADMIN = {
password: 'password',
}
const authenticate = async (email: string, password: string): Promise<Record<string, unknown> | null> => {
if (email === DEFAULT_ADMIN.email && password === DEFAULT_ADMIN.password) {
return Promise.resolve(DEFAULT_ADMIN)
}
return null
}
const start = async () => {
const server = Hapi.server({ port: PORT })
// "secret" must be a string with at least 32 characters, example:
const cookieSecret = 'sieL67H7GbkzJ4XCoH0IHcmO1hGBSiG5'
const adminOptions: ExtendedAdminJSOptions = {
resources: [],
rootPath: '/admin',
auth: {
isSecure: process.env.NODE_ENV === 'production',
authenticate,
cookieName: 'adminjs',
cookiePassword: cookieSecret,
},
registerInert: true,
}
await server.register<ExtendedAdminJSOptions>({
plugin: AdminJSHapi,
options: adminOptions,
})
await server.start();
console.log(`AdminJS available at ${server.info.uri}${adminOptions.rootPath}`);
}
start()
Now you can start your AdminJS application:
$ ts-node app.ts
Last modified 1mo ago
Copy link
Outline
Simple
Authentication