Search code examples
node.jspostgresqlexpressbackendadminjs

Adminjs with postgresql implementation error while showing table data


I'm new in using adminjs. I have created a node express js project to handle my backend. I've used postgresql as database. So that I use @adminjs/sql admin authentication is working properly. But I', facing some issues while try to show the tables of the postgresql. As I'm a beginner I have followed the official documentation https://docs.adminjs.co/installation/adapters/sql Here is my app.js file:

const express = require("express");
require("express-async-errors");
const cors = require("cors");
const morgan = require("morgan");
const routes = require("./routes");
const compression = require("compression");
const unknownEndpoint = require("./middleware/unKnownEndpoint");
const { handleError } = require("./helpers/error");

const app = express();

app.set("trust proxy", 1);
app.use(cors({ credentials: true, origin: true }));
app.use(express.json());
app.use(morgan("dev"));
app.use(compression());
app.use("/uploads", express.static("uploads"));

// CORS handling
app.use((req, res, next) => {
    res.header("Access-Control-Allow-Origin", "*");
    res.header(
        "Access-Control-Allow-Headers",
        "Origin, X-Requested-With, Content-Type, Accept, Authorization"
    );
    if (req.method === "OPTIONS") {
        res.header("Access-Control-Allow-Methods", "PUT, POST, PATCH, DELETE, GET");
        return res.status(200).json({});
    }
    next();
});

app.use(`/api`, routes);

Promise.all([
    import('adminjs'),
    import('@adminjs/express'),
    import('connect-pg-simple'),
    import('express-session'),
    import('@adminjs/sql'),
]).then(async ([
    { default: AdminJS },
    { default: AdminJSExpress },
    { default: Connect },
    { default: session },
    { default: { Adapter, Resource, Database } },
]) => {
    const connectionString = `postgresql://${process.env.POSTGRES_USER}:${process.env.POSTGRES_PASSWORD}@${process.env.POSTGRES_HOST}:${process.env.POSTGRES_PORT}/${process.env.POSTGRES_DB}`;

    AdminJS.registerAdapter({ Database, Resource })

    const db = await new Adapter('postgresql', {
        connectionString: connectionString,
        database: process.env.POSTGRES_DB,
    }).init();

    const DEFAULT_ADMIN = { email: '[email protected]', password: '@Admin123', name: 'FrogBase Admin' }

    const authenticate = async (email, password) => {
        if (email === DEFAULT_ADMIN.email && password === DEFAULT_ADMIN.password) return Promise.resolve(DEFAULT_ADMIN)
        return null
    }

    const adminJS = new AdminJS({
        version: { admin: true, app: process.env.PROJECT_VERSION },
        rootPath: "/admin",
        databases: [db],
    });
    const ConnectSession = Connect(session)
    const sessionStore = new ConnectSession({
        conObject: {
            connectionString: connectionString,
            /*
            SSL is not supported in development
            */
            ssl:
                process.env.NODE_ENV === "production"
                    ? { rejectUnauthorized: false }
                    : false,
        },
        tableName: 'adminjs',
        createTableIfMissing: true,
    });
    const adminRouter = AdminJSExpress.buildAuthenticatedRouter(
        adminJS,
        {
            authenticate,
            cookieName: process.env.COOKIE_NAME,
            cookiePassword: process.env.COOKIE_SECRET,
        },
        null,
        {
            store: sessionStore,
            resave: true,
            saveUninitialized: true,
            secret: process.env.COOKIE_SECRET,
            cookie: {
                httpOnly: process.env.NODE_ENV === 'production',
                secure: process.env.NODE_ENV === 'production',
            },
            name: process.env.COOKIE_NAME,
        }
    )
    app.use(adminJS.options.rootPath, adminRouter)

    app.use('*', unknownEndpoint);
    app.use(handleError);
});

module.exports = app;


And the error I'm facing is

file:///Users/sabikrahat/Files/Algoramming/frogbase/frogbase/node_modules/adminjs/lib/adminjs.js:101
      throw new Error('Adapter has to have both Database and Resource');
            ^

Error: Adapter has to have both Database and Resource
    at AdminJS.registerAdapter (file:///Users/sabikrahat/Files/Algoramming/frogbase/frogbase/node_modules/adminjs/lib/adminjs.js:101:13)
    at /Users/sabikrahat/Files/Algoramming/frogbase/frogbase/app.js:54:13

enter image description here


Solution

  • Try changing this:

    { default: { Adapter, Resource, Database } }
    

    To this:

    { default: Adapter, Resource, Database }
    

    At the minute you're assigning an object containing 3 modules to default when the adminjs/sql docs look like they are exporting Adapter as the default.