You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

122 lines
4.3 KiB

#!/usr/bin/env python
# -*- encoding: utf-8 -*-
'''
@Date:2022/07/19 16:34:34
'''
from flask import jsonify, request, Blueprint, g
from Common.auth import token_auth
from Common.Utils import PageParam, Utils
from db_logic.user import BllUser
from models.user_models import EntityUser
user_router = Blueprint('user', __name__)
@user_router.route("/login", methods=["POST"])
# @token_auth.login_required
def user_login():
user_name = request.values.get("user_name")
password = request.values.get('password')
# user_name = body.user_name
# password = body.password
user_obj = BllUser().login(user_name=user_name, password=password)
if user_obj:
return jsonify(Utils.true_return(msg="登陆成功", data={"token":user_obj}))
else:
return jsonify(Utils.false_return(status=201, msg="登陆失败"))
# 修改密码,根据token获取用户信息接受老密码进行校验新密码写入
@user_router.route("/update_password", methods=["POST"])
@token_auth.login_required
def user_update_password():
old_password = request.values.get("old_password")
new_password = request.values.get("new_password")
# user_id = g.current_user.use
msg_bool, msg_token = BllUser().update_password(g.current_user, old_password=old_password, new_password=new_password)
if msg_bool:
return jsonify(Utils.true_return(data={"token": msg_token}))
else:
return jsonify(Utils.false_return(msg=msg_token))
# 获取用户列表
@user_router.route("/get_user_list", methods=["GET", "POST"])
@token_auth.login_required
def get_user_info_list():
user_code = request.values.get("user_code")
real_name = request.values.get("real_name")
role_name = request.values.get("role_name")
is_enabled = request.values.get("is_enabled")
page = int(request.values.get("page", 1))
page_size = int(request.values.get("page_size", 10))
page_param = PageParam(page, page_size)
data_list = BllUser().get_seach_user_list(
user_code=user_code,
real_name=real_name,
role_name=role_name,
is_enabled=is_enabled,
page_param=page_param
)
return jsonify(Utils.true_return(data={"total_count":page_param.totalRecords, "data_list": Utils.msyql_table_model(data_list)}))
# 新增用户
@user_router.route("/add", methods=["GET", "POST"])
@token_auth.login_required
def add_user_info():
try:
obj = EntityUser(
real_name=request.values.get("real_name"),
mobile=request.values.get("mobile"),
sex=request.values.get("sex"),
email=request.values.get("email"),
user_code=request.values.get("user_code"),
qq=request.values.get("qq"),
role_id=request.values.get("role_id"),
is_enabled=request.values.get("is_enabled")
)
BllUser().insert(obj)
# BllUser().update()
return jsonify(Utils.true_return(msg="添加成功"))
except Exception as error:
return jsonify(Utils.except_return(msg=error))
# 修改用户
@user_router.route("/update", methods=["GET", "POST"])
@token_auth.login_required
def update_user_info():
user_id = request.values.get("user_id")
try:
obj = BllUser().findEntity(user_id)
if not obj:
return jsonify(Utils.false_return(msg="用户id有误"))
else:
obj.real_name = request.values.get("real_name")
obj.mobile = request.values.get("mobile")
obj.sex = request.values.get("sex")
obj.email = request.values.get("email")
obj.user_code = request.values.get("user_code")
obj.qq = request.values.get("qq")
obj.role_id = request.values.get("role_id")
obj.role_name = request.values.get("role_name")
obj.is_enabled = request.values.get("is_enabled")
obj.update_last_visit_date()
BllUser().update(obj)
return jsonify(Utils.true_return(msg="修改成功"))
except Exception as error:
return jsonify(Utils.except_return(msg=error))
# 删除用户
@user_router.route("/del", methods=["GET", "POST"])
@token_auth.login_required
def del_user():
user_id = request.values.get("user_id")
BllUser().delete(EntityUser.user_id==user_id)
return jsonify(Utils.true_return(msg="删除成功"))