w-web-perm
Version:
A web service for permissions.
102 lines (85 loc) • 4.25 kB
JavaScript
import WOrm from 'w-orm-lmdb/src/WOrmLmdb.mjs'
import WWebPerm from './server/WWebPerm.mjs'
import getSettings from './g.getSettings.mjs'
//st
let st = getSettings()
let url = st.dbUrl
let db = st.dbName
let opt = {
useCheckUser: false,
getUserById: null,
useExcludeWhenNotAdmin: false,
serverPort: 11006,
subfolder: '', //mperm
urlRedirect: 'https://www.google.com/', //本機測試時得先編譯, 再瀏覽: http://localhost:11006/
showLanguage: 'y', //'n',
language: 'eng', //'eng', 'cht'
showModeEditTargets: 'y', //'n',
showModeEditPemis: 'y',
showModeEditGrups: 'y',
showModeEditUsers: 'y',
modeEditTargets: 'y', //'n',
modeEditPemis: 'y',
modeEditGrups: 'y',
modeEditUsers: 'y',
webName: {
'eng': 'Permission Service',
'cht': '權限管理系統',
},
webDescription: {
'eng': 'A web service package for user permissions and management targets.',
'cht': '基於簡易分層架構來給予與設定使用者所需之權限及群組管理功能',
},
webLogo: '',
// kpLangExt: {
// mmTargets: {
// eng: `Current features list`,
// cht: `現有功能清單`,
// },
// mmTargetsMsg: {
// eng: `Features generally refer to entities such as pages, data, etc., and can also include features or services.`,
// cht: `現有功能泛指實體的頁面、數據等,亦可為的功能或服務。`,
// },
// },
}
let getUserByToken = async (token) => {
// console.log('getUserByToken/token', token)
// console.log('於生產環境時得加入SSO等驗證token機制')
// return {} //測試無法登入
if (token === '{token-for-application}') { //提供外部應用系統作為存取使用者
return {
id: 'id-for-application',
name: 'application',
email: 'application@example.com',
isAdmin: 'y',
}
}
if (token === 'sys') { //開發階段w-ui-loginout自動給予browser使用者(且位於localhost)的token為sys
return {
id: 'id-for-admin',
name: 'admin',
email: 'admin@example.com', //mappingBy為email, 開發階段時會使用email找到所建置之使用者資料
isAdmin: 'y',
}
}
console.log('invalid token', token)
return {}
}
let verifyClientUser = (user, from) => {
// console.log('verifyClientUser/user', user)
// console.log('於生產環境時得加入限制瀏覽器使用者身份機制')
// return false //測試無法登入
return user.isAdmin === 'y' //測試僅系統管理者使用
}
let verifyAppUser = (user, from) => {
// console.log('verifyAppUser/user', user)
// console.log('於生產環境時得加入限制應用程式使用者身份機制')
// return false //測試無法登入
return user.isAdmin === 'y' //測試僅系統管理者使用
}
//WWebPerm
let instWWebPerm = WWebPerm(WOrm, url, db, getUserByToken, verifyClientUser, verifyAppUser, opt)
instWWebPerm.on('error', (err) => {
console.log(err)
})
//node srv.mjs