使用现有的 api 和 admin bro 中的控制器登录

Login using existing api and controller in admin bro

我的项目(nodejs 后端)需要几个项目的基本 CRUD 功能:大洲、国家等

我正在创建一个管理仪表板,我发现了用于创建仪表板的 admin-bro 插件。 但是因为这将在实时服务器中,我也需要创建身份验证。

我已经创建了身份验证 api 并且具有良好的目录结构。

如图所示,我已经在 routes.js 文件

中拥有我需要的所有 api
const express             = require('express');
const router              = express.Router();
const authController      = require('../api/v1/controllers/auth.controller');
const counrtyController   = require('../api/v1/controllers/country.controller')
const adminController     = require('../api/v1/controllers/admin.controller');

// rendering admin pages
router.get('/Admin/Login', authController.renderLoginView);
router.get('/admin/Dashboard', adminController.renderDashboardView);

// API End Points for admin auth and new admin register and signout
router.post('/api/v1/auth/login', authController.login);
router.post('/api/v1/auth/register', authController.register);
router.post('/api/v1/auth/signout', authController.signout);

// API endpoints for countries(get all, get one, add one, delete one, edit one)
router.post('/api/v1/countries/addOne', counrtyController.addOne);
router.get('/api/v1/countries/getAll', counrtyController.listAll);
router.get('/api/v1/countries/:country_name', counrtyController.listOne);
router.put('/api/v1/countries/:country_name', counrtyController.updateOne);
router.delete('/api/v1/countries/:country_name',counrtyController.deleteOne);
module.exports            = router;

这是我在 routes.js 文件中的一些 api

每个 api 调用一个特定的控制器,其中包含所有逻辑。

现在我的问题是我想使用我现有的身份验证进入仪表板。我应该改变什么?

我将保留 api 因为将来我会将管理仪表板带到前端,我需要获取方法来显示有关 continent/country 的信息。

我现在可能会注释掉所有 post/put/delete 方法

接下来我该做什么?

这是我里面的东西admin.route.js

const AdminBro          = require('admin-bro');
const AdminBroExpress   = require('@admin-bro/express');
const AdminBroMongoose  = require('@admin-bro/mongoose');

const mongoose          = require('mongoose');

AdminBro.registerAdapter(AdminBroMongoose);

const Country           = require('../models/country.model');
const Continent         = require('../models/continent.model');
const Visa              = require('../models/visa.model');


const adminBro = new AdminBro({
    resources: [
        {
            resource: Continent,
            options: {
                parent: {
                    name: 'Continent'
                }
            }
        },
        {
            resource: Country,
            options: {
                parent: {
                    name: 'Country'
                }
            }
        },
    ],
    rootPath: '/admin',
})

const adminBroRouter = AdminBroExpress.buildRouter(adminBro)

module.exports = adminBroRouter;

在我的 index.js 里面:

const express           = require('express');
const app               = express();
const mongoose          = require('mongoose');
const dotenv            = require('dotenv');
const bodyParser        = require('body-parser');
const engine            = require('./config/view.engine');
const router            = require('./routes/routes');
const session           = require('express-session');
const adminRouter       = require('./routes/admin.route');

// Middlewares
app.use(session({secret: 'mysupersecret', saveUninitialized: true, resave: true}));
app.use(bodyParser.urlencoded({extended: true}))
app.use(express.json());
app.use('/', router);


// connect to db
dotenv.config();
mongoose.connect(
    process.env.DB_CONNECT,
    {
        useUnifiedTopology: true,
        useNewUrlParser: true
    },
    () => console.log("connected to db")
);

// use engine for views
engine(app);

app.use('/admin', adminRouter);
app.get("/", (req, res) =>{
    res.send("This route wont return anything")
});

const PORT            = process.env.PORT || 5000
app.listen(PORT, () => console.log("server up and running"));

一些小细节: 我的登录页面应该是 /Admin/Login,仪表板应该是 /Admin/Dashboard

这很有帮助。我必须编写自定义身份验证控制器和路由,而不是使用 buildAuthenticatedRouter()。

custom login page for firebase

这对我有用 mongodb atlas