Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Help Wanted] Authentication and Session Management. #1732

Open
anjia1991 opened this issue Jan 10, 2025 · 0 comments
Open

[Help Wanted] Authentication and Session Management. #1732

anjia1991 opened this issue Jan 10, 2025 · 0 comments

Comments

@anjia1991
Copy link

anjia1991 commented Jan 10, 2025

I use AdminJS as the admin panel and web application. However, we have encountered the following major issue:

  1. When a user logs into the web application and attempts to access AdminJS's API to fetch data, the requests fail. The API only responds with the expected data after the user completes a separate login through the AdminJS login page.

  2. Upon investigation, we found that AdminJS's buildAuthenticatedRouter intercepts API requests, diverting them away from directly serving the data. This prevents data access as intended from the web application.

The core issue lies in the conflict between handling shared login sessions and the integration of authentication processes across both web application and AdminJS.


Attempted Solution

We have considered the following approach:

  • Use Separate Sessions for Main Application and AdminJS:
    In this solution, the main application handles authentication and data retrieval via a custom API (e.g., /admin/api/resources/getByUser/{userId}). Below is an example implementation:
// userController.ts
import { Request, Response } from 'express';

export const getUserInformation = async (req: Request, res: Response) => {
    try {
        const { userId } = req.params;
        const data = {}; // Build data payload based on logic
        return res.status(200).json({
            status: 'ok',
            message: '',
            result: data,
        });
    } catch (error) {
        return res.status(500).json({
            status: 'error',
            message: 'Internal server error',
        });
    }
};

While this solution provides a customize API handling and login logic, it has drawbacks:

  • It requires completely re-implementing data access logic, missing out on AdminJS's built-in features such as role-based access control.

Desired Solution

We are seeking a more elegant approach that can:

Enable Shared Sessions for Unified Access:
Users should be able to log in through the web application. The session cookies has access AdminJS's admin panel and APIs without needing to log in AdminJS again.

Please advice best practice. Thank you!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant