trigger-user-save.js 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. // https://docs.authing.co/v2/reference/sdk-for-node/management/UsersManagementClient.html
  2. const { ManagementClient } = require('authing-node-sdk')
  3. const managementClient = new ManagementClient({
  4. accessKeyId: '6686bffb373d06911e24a969',
  5. accessKeySecret: "4e978331675938d1bc81fb109e67d59a",
  6. host: 'https://textbook.u2-dev.hep.com.cn', // 应用的认证地址
  7. })
  8. /**
  9. * 用户创建前,创建用户至Authing
  10. * @desc 仅同步注册信息及密码,资料在afterSave中同步
  11. */
  12. export function defineUserBeforeSave(){
  13. Parse.Cloud.beforeSave("_User", async (request) => {
  14. let user = request.object;
  15. // 仅首次注册/创建用户/修改密码有password属性,同步Authing账号
  16. let password = user?.get("password");
  17. if(password){
  18. let mobile = user?.get("mobile");
  19. let email = user?.get("email");
  20. let username = user?.get("username");
  21. let externalId = user?.id;
  22. let authingUserExists = await findUserByMobileEmailUserName(user)
  23. if(authingUserExists?.statusCode==404){ // 创建用户
  24. let newuser = {
  25. status:"Activated",
  26. }
  27. if(mobile){newuser.phone = mobile}
  28. if(email){newuser.email = email}
  29. if(username){newuser.username = username}
  30. if(externalId){newuser.externalId = externalId}
  31. result = await managementClient.createUser(newuser)
  32. }
  33. if(authingUserExists?.statusCode==200){
  34. let existsUser = authingUserExists?.data;
  35. try{
  36. let updateRes = await managementClient.updateUser({
  37. userId:existsUser?.userId,
  38. password:password,
  39. })
  40. // console.log(result)
  41. }catch(err){console.log(err)}
  42. }
  43. }
  44. });
  45. }
  46. /**
  47. * 用户删除前,删除用户从Authing
  48. */
  49. export function defineUserBeforeDelete(){
  50. Parse.Cloud.beforeDelete("_User", async (request) => {
  51. let user = request.object;
  52. // console.log(user.toJSON());
  53. // console.log(user?.get("password"))
  54. let authingUserExists = await findUserByMobileEmailUserName(user)
  55. if(authingUserExists?.statusCode==200){
  56. let existsUser = authingUserExists?.data;
  57. let deleteRes = await managementClient.deleteUsersBatch({
  58. // 替换用户 ID 数组
  59. userIds: [existsUser.userId],
  60. options: {
  61. userIdType: "user_id"
  62. }
  63. });
  64. }
  65. });
  66. }
  67. /**
  68. * 用户保存后同步数据至Authing
  69. */
  70. export function defineUserAfterSave(){
  71. Parse.Cloud.afterSave("_User", async (request) => {
  72. // console.log("save _User",request?.object?.id)
  73. let query = new Parse.Query("Profile");
  74. query.equalTo("user",request?.object?.id)
  75. let profile = await query.first();
  76. syncUserProfileToAuthing(request?.object,profile)
  77. });
  78. Parse.Cloud.afterSave("Profile", async (request) => {
  79. // console.log("save Profile",request?.object?.id)
  80. let query = new Parse.Query("Profile");
  81. query.include("user");
  82. profile = await query.get(request?.object?.id);
  83. syncUserProfileToAuthing(profile.get("user"),profile)
  84. });
  85. }
  86. /**
  87. * 查询用户
  88. * @param {*} user
  89. * @returns
  90. * 不存在:
  91. * {
  92. statusCode: 404,
  93. apiCode: 2004,
  94. message: '用户不存在',
  95. requestId: 'e59cb407-f2d9-4bd8-ac93-d2dbc8d6ab72'
  96. }
  97. {
  98. statusCode: 200,
  99. message: '',
  100. data: {
  101. userId: '669676e5a3a9ac870bfff2a3',
  102. createdAt: '2024-07-16T13:34:29.789Z',
  103. updatedAt: '2024-07-16T13:34:29.789Z',
  104. status: 'Activated'
  105. }
  106. }
  107. */
  108. async function findUserByMobileEmailUserName(user){
  109. let mobile = user?.get("mobile");
  110. let email = user?.get("email");
  111. let username = user?.get("username");
  112. let externalId = user?.id;
  113. let result;
  114. if(email){
  115. try{
  116. result = await managementClient.getUser({userIdType:`email`,userId:email})
  117. // console.log(email,result)
  118. }catch(err){}
  119. }
  120. if(mobile&&(!result || result?.statusCode==404)){
  121. try{
  122. result = await managementClient.getUser({userIdType:`phone`,userId:mobile})
  123. // console.log(mobile,result)
  124. }catch(err){}
  125. }
  126. if(username&&(!result || result?.statusCode==404)){
  127. try{
  128. result = await managementClient.getUser({userIdType:`username`,userId:username})
  129. // console.log("username",username,result)
  130. }catch(err){}
  131. }
  132. if(externalId&&(!result || result?.statusCode==404)){
  133. try{
  134. result = await managementClient.getUser({userIdType:`external_id`,userId:externalId})
  135. // console.log(externalId,result)
  136. }catch(err){}
  137. }
  138. return result
  139. }
  140. async function syncUserProfileToAuthing(user,profile){
  141. if(!user?.id) return
  142. let userInfo = user.toJSON();
  143. userInfo = fixJsonFileds(userInfo)
  144. if(profile?.id){
  145. let pjson = profile.toJSON();
  146. delete pjson.objectId;
  147. pjson= fixJsonFileds(pjson)
  148. Object.keys(pjson).forEach(key=>{
  149. userInfo[key] = pjson[key]
  150. })
  151. }
  152. // 映射对应字段
  153. userInfo.company = userInfo.companyName
  154. delete userInfo.companyName
  155. userInfo.userType = userInfo.identity
  156. delete userInfo.identity
  157. userInfo.userId = userInfo.objectId
  158. let authingUserExists = await findUserByMobileEmailUserName(user)
  159. if(authingUserExists?.statusCode==200){
  160. let existsUser = authingUserExists?.data;
  161. userInfo.userId = existsUser.userId
  162. }
  163. delete userInfo.objectId
  164. userInfo.identifyStatus = userInfo.accountState
  165. // 自定义数据全量同步
  166. userInfo.customData = JSON.parse(JSON.stringify(userInfo))
  167. // {
  168. // identifyStatus : userInfo.accountState
  169. // }
  170. // console.log(userInfo)
  171. // 同步数据至Authing用户池
  172. let result
  173. try{
  174. result = await managementClient.updateUser(userInfo)
  175. // console.log(result)
  176. }catch(err){console.log(err)}
  177. }
  178. function fixJsonFileds(json){
  179. // Parse独有关系数据
  180. delete json.ACL
  181. delete json.className
  182. delete json.sessionToken
  183. delete json.company
  184. delete json.user
  185. delete json.createdAt
  186. delete json.updatedAt
  187. // 来自Authing的数据
  188. delete json?.loginsCount
  189. delete json?.lastIP
  190. delete json?.lastLogin
  191. return json
  192. }