2 changed files with 0 additions and 221 deletions
			
			
		| @ -1,189 +0,0 @@ | |||||
| 'use strict'; |  | ||||
| const Hex = require('crypto-js/enc-hex'); |  | ||||
| const MD5 = require('crypto-js/md5'); |  | ||||
| const moment = require('moment'); |  | ||||
| const uuid = require('uuid'); |  | ||||
| 
 |  | ||||
| async function login(ctx, next) { |  | ||||
|     const transaction = await ctx.fs.dc.orm.transaction(); |  | ||||
|     try { |  | ||||
|         const models = ctx.fs.dc.models; |  | ||||
|         const params = ctx.request.body; |  | ||||
|         let password = Hex.stringify(MD5(params.password)); |  | ||||
| 
 |  | ||||
|         const userRes = await models.User.findOne({ |  | ||||
|             where: { |  | ||||
|                 username: params.username, |  | ||||
|                 password: password, |  | ||||
|                 delete: false, |  | ||||
|             }, |  | ||||
|             attributes: { exclude: ['password'] }, |  | ||||
|             include: [{ |  | ||||
|                 attributes: ["resourceId"], |  | ||||
|                 model: models.UserResource |  | ||||
|             }] |  | ||||
|         }); |  | ||||
| 
 |  | ||||
|         if (!userRes) { |  | ||||
|             ctx.status = 400; |  | ||||
|             ctx.body = { |  | ||||
|                 "message": "账号或密码错误" |  | ||||
|             } |  | ||||
|         } else if (!userRes.enable) { |  | ||||
|             ctx.status = 400; |  | ||||
|             ctx.body = { message: "该用户已被禁用" } |  | ||||
|         } else { |  | ||||
|             const token = uuid.v4(); |  | ||||
| 
 |  | ||||
|             let userRslt = Object.assign(userRes.dataValues, { |  | ||||
|                 authorized: true, |  | ||||
|                 token: token, |  | ||||
|                 userResources: userRes.userResources.map(r => r.resourceId), |  | ||||
|             }); |  | ||||
| 
 |  | ||||
|             await models.UserToken.create({ |  | ||||
|                 token: token, |  | ||||
|                 userInfo: userRslt, |  | ||||
|                 expired: moment().add(30, 'days').format() |  | ||||
|             }); |  | ||||
| 
 |  | ||||
|             ctx.status = 200; |  | ||||
|             ctx.body = userRslt; |  | ||||
|         } |  | ||||
|         await transaction.commit(); |  | ||||
|     } catch (error) { |  | ||||
|         await transaction.rollback(); |  | ||||
|         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); |  | ||||
|         ctx.status = 400; |  | ||||
|         ctx.body = { |  | ||||
|             "message": "登录失败" |  | ||||
|         } |  | ||||
|     } |  | ||||
| } |  | ||||
| 
 |  | ||||
| /** |  | ||||
|  * 微信小程序登录 |  | ||||
|  * @@requires.body {phone-手机号, password-密码} ctx  |  | ||||
|  */ |  | ||||
| async function wxLogin(ctx, next) { |  | ||||
|     const transaction = await ctx.fs.dc.orm.transaction(); |  | ||||
|     try { |  | ||||
|         const models = ctx.fs.dc.models; |  | ||||
|         const params = ctx.request.body; |  | ||||
|         let password = Hex.stringify(MD5(params.password)); |  | ||||
|         const userRes = await models.User.findOne({ |  | ||||
|             where: { |  | ||||
|                 phone: params.phone, |  | ||||
|                 password: password, |  | ||||
|                 delete: false, |  | ||||
|             }, |  | ||||
|             attributes: { exclude: ['password'] } |  | ||||
|         }); |  | ||||
|         if (!userRes) { |  | ||||
|             ctx.status = 400; |  | ||||
|             ctx.body = { message: "手机号或密码错误" } |  | ||||
|         } else if (!userRes.enable) { |  | ||||
|             ctx.status = 400; |  | ||||
|             ctx.body = { message: "该用户已被禁用" } |  | ||||
|         } else { |  | ||||
|             const token = uuid.v4(); |  | ||||
|             //获取用户关注区域信息
 |  | ||||
|             const departmentRes = await models.Department.findOne({ where: { id: userRes.departmentId } }); |  | ||||
|             let attentionRegion = departmentRes; |  | ||||
|             while (attentionRegion.dependence && attentionRegion.type != 1) { |  | ||||
|                 const departmentParent = await models.Department.findOne({ where: { id: attentionRegion.dependence } }); |  | ||||
|                 attentionRegion = { |  | ||||
|                     ...departmentParent.dataValues, |  | ||||
|                     nextRegin: attentionRegion |  | ||||
|                 } |  | ||||
|             } |  | ||||
|             //获取用户权限信息
 |  | ||||
|             const resourceRes = await models.UserResource.findAll({ |  | ||||
|                 where: { |  | ||||
|                     userId: userRes.id |  | ||||
|                 }, |  | ||||
|                 include: [{ |  | ||||
|                     model: models.Resource, |  | ||||
|                     attributes: ['code', 'name'], |  | ||||
|                 }], |  | ||||
|                 attributes: [] |  | ||||
|             }); |  | ||||
|             let userRslt = Object.assign({ |  | ||||
|                 authorized: true, |  | ||||
|                 token: token, |  | ||||
|                 ...userRes.dataValues |  | ||||
|             }); |  | ||||
|             await models.UserToken.create({ |  | ||||
|                 token: token, |  | ||||
|                 userInfo: userRslt, |  | ||||
|                 expired: moment().add(30, 'day').format('YYYY-MM-DD HH:mm:ss') |  | ||||
|             }, { transaction: transaction }); |  | ||||
|             ctx.status = 200; |  | ||||
|             ctx.body = Object.assign({ |  | ||||
|                 ...userRslt, |  | ||||
|                 userRegionType: departmentRes.type,//1-市级,2-区县级,3-乡镇级,4-村级
 |  | ||||
|                 attentionRegion: attentionRegion, |  | ||||
|                 resources: resourceRes.map(r => r.resource) |  | ||||
|             }); |  | ||||
|         } |  | ||||
|         await transaction.commit(); |  | ||||
|     } catch (error) { |  | ||||
|         await transaction.rollback(); |  | ||||
|         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); |  | ||||
|         ctx.status = 400; |  | ||||
|         ctx.body = { |  | ||||
|             "message": "登录失败" |  | ||||
|         } |  | ||||
|     } |  | ||||
| } |  | ||||
| 
 |  | ||||
| async function logout(ctx) { |  | ||||
|     try { |  | ||||
|         const { token, code } = ctx.request.body; |  | ||||
|         const models = ctx.fs.dc.models; |  | ||||
| 
 |  | ||||
|         await models.UserToken.destroy({ |  | ||||
|             where: { |  | ||||
|                 token: token, |  | ||||
|             }, |  | ||||
|         }); |  | ||||
| 
 |  | ||||
|         ctx.status = 204; |  | ||||
|     } catch (error) { |  | ||||
|         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); |  | ||||
|         ctx.status = 400; |  | ||||
|         ctx.body = { |  | ||||
|             "message": "登出失败" |  | ||||
|         } |  | ||||
|     } |  | ||||
| } |  | ||||
| 
 |  | ||||
| /** |  | ||||
|  * 微信小程序登出 |  | ||||
|  * @request.body {token-用户登录Token} ctx  |  | ||||
|  */ |  | ||||
| async function wxLogout(ctx) { |  | ||||
|     try { |  | ||||
|         const { token } = ctx.request.body; |  | ||||
|         const models = ctx.fs.dc.models; |  | ||||
|         await models.UserToken.destroy({ |  | ||||
|             where: { |  | ||||
|                 token: token, |  | ||||
|             }, |  | ||||
|         }); |  | ||||
|         ctx.status = 204; |  | ||||
|     } catch (error) { |  | ||||
|         ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); |  | ||||
|         ctx.status = 400; |  | ||||
|         ctx.body = { |  | ||||
|             "message": "登出失败" |  | ||||
|         } |  | ||||
|     } |  | ||||
| } |  | ||||
| 
 |  | ||||
| module.exports = { |  | ||||
|     login, |  | ||||
|     wxLogin, |  | ||||
|     logout, |  | ||||
|     wxLogout |  | ||||
| }; |  | ||||
| @ -1,32 +0,0 @@ | |||||
| 'use strict'; |  | ||||
| 
 |  | ||||
| const auth = require('../../controllers/auth'); |  | ||||
| 
 |  | ||||
| module.exports = function (app, router, opts) { |  | ||||
|     /** |  | ||||
|      * @api {Post} login 登录. |  | ||||
|      * @apiVersion 1.0.0 |  | ||||
|      * @apiGroup Auth |  | ||||
|      */ |  | ||||
|     app.fs.api.logAttr['POST/login'] = { content: '登录', visible: true }; |  | ||||
|     router.post('/login', auth.login); |  | ||||
| 
 |  | ||||
|     /** |  | ||||
|      * @api {POST} wxLogin 微信小程序登录.(使用手机号、密码登录) |  | ||||
|      * @apiVersion 1.0.0 |  | ||||
|      * @apiGroup Auth |  | ||||
|      */ |  | ||||
|     app.fs.api.logAttr['POST/wxLogin'] = { content: '微信小程序登录', visible: true }; |  | ||||
|     router.post('/wxLogin', auth.wxLogin); |  | ||||
| 
 |  | ||||
|     app.fs.api.logAttr['PUT/logout'] = { content: '登出', visible: false }; |  | ||||
|     router.put('/logout', auth.logout); |  | ||||
| 
 |  | ||||
|     /** |  | ||||
|      * @api {PUT} wxLogout 微信小程序登出 |  | ||||
|      * @apiVersion 1.0.0 |  | ||||
|      * @apiGroup Auth |  | ||||
|      */ |  | ||||
|     app.fs.api.logAttr['PUT/wxLogout'] = { content: '登出', visible: false }; |  | ||||
|     router.put('/wxLogout', auth.wxLogout); |  | ||||
| }; |  | ||||
					Loading…
					
					
				
		Reference in new issue