AzureAD登录流程到SPA应用程序需要仅在第一次登录时获得管理员批准
创始人
2024-09-29 12:30:37
0

在应用程序中,可以使用 Microsoft Graph API 来检查用户是否是首次登录。然后,如果是首次登录,则向管理员发送批准请求,以便让用户完成登录。

以下是一个示例代码,该代码使用 Microsoft Graph API 来检查用户是否是首次登录。如果是,它会发送一个邮件给管理员,以便让他们批准该用户的登录请求:

//检查用户是否首次登录
function checkFirstTimeLogin(user) {
    return new Promise(async (resolve, reject) => {
        try {
            const endpoint = `https://graph.microsoft.com/v1.0/users/${user.email}/activity/feed?filter=activityType eq 'signin'`;
            const res = await fetch(endpoint, {
                headers: {
                    Authorization: "Bearer " + authProvider.getAccessToken(),
                    "Content-Type": "application/json"
                }
            });
            const data = await res.json();

            if (data && data.value && data.value.length && data.value[0].status === "success" && data.value[0].approximateSignInDateTime) {
                const lastSigninTime = new Date(data.value[0].approximateSignInDateTime);
                const currentTime = new Date();
                const timeDiff = Math.abs(currentTime.getTime() - lastSigninTime.getTime());
                const diffDays = Math.ceil(timeDiff / (1000 * 3600 * 24));

                if (diffDays <= 1) {
                    resolve(true);
                }
            }
            resolve(false);
        } catch (e) {
            reject(e);
        }
    })
}

// 发送邮件给管理员以便批准
function sendApprovalEmail(user) {
    const email = {
        message: {
            subject: `Require admin approval for ${user.email} to login`,
            toRecipients: [
                {
                    emailAddress: {
                        address: ""
                    }
                }
            ],
            body: {
                content: `
                    Hi, 

                    Please approve ${user.email} to login to the SPA application.

                    Thanks,
                    
                `,
                contentType: "text"
            }
        },
        saveToSentItems: true
    };

    return new Promise(async (resolve, reject) => {
        try {
            await graphClient.api("/users//sendMail").post(email);
            resolve(true)
        } catch (e) {
            reject(e);
        }
    })
}

//登录检查,如果是首次登录则发送批准邮件给管理员
async function loginCheck(user) {

相关内容

热门资讯

第3分钟辅助!wpk德州局怎么... 第3分钟辅助!wpk德州局怎么透视,水鱼辅助软件下载(科技揭秘开挂辅助安装);亲真的是有正版授权,小...
第9分钟开挂!海贝之城辅助软甲... 第9分钟开挂!海贝之城辅助软甲下载,阿拉游戏中心辅助(透视了解开挂辅助平台)>>您好:软件加1367...
第4分钟辅助!游戏茶苑辅助,摸... 第4分钟辅助!游戏茶苑辅助,摸一把麻将辅助(今日重大通报开挂辅助插件);摸一把麻将辅助是一种具有地方...
9分钟开挂!九九联盟辅助,情怀... 9分钟开挂!九九联盟辅助,情怀宜春怎么开挂(透视教程开挂辅助安装);无需打开直接搜索打开薇:1367...
第九分钟辅助!中至赣牌圈插件,... 第九分钟辅助!中至赣牌圈插件,九九山城插件程序(实测发现开挂辅助软件);一、九九山城插件程序AI软件...
3分钟开挂!乐胡摆叫有没有黑科... 3分钟开挂!乐胡摆叫有没有黑科技,微友约局辅助(科技分享开挂辅助下载)1、下载安装好乐胡摆叫有没有黑...
第8分钟辅助!拱趴大菠萝挂怎么... 第8分钟辅助!拱趴大菠萝挂怎么安装,蜀山四川破解版安卓版辅助(一分钟了解开挂辅助插件);是一款可以让...
第8分钟辅助!全来潜山跑风辅助... 第8分钟辅助!全来潜山跑风辅助器,川友汇辅助软件(玩家必看教程开挂辅助工具) 【无需打开直接搜索加薇...
七分钟辅助!wepoker私人... 七分钟辅助!wepoker私人局俱乐部,边锋斗地主插件辅助脚本(透视软件开挂辅助安装);亲真的是有正...
八分钟透视!雀神麻雀充运势有用... 八分钟透视!雀神麻雀充运势有用吗,创思维激k辅助器免费(辅助透视开挂辅助工具) >>您好:软件加薇1...