123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- # -*- coding: utf-8 -*-
- """
- walle-web
- :copyright: © 2015-2017 walle-web.io
- :created time: 2017-03-25 11:15:01
- :author: wushuiyong@walle-web.io
- """
- import os
- from flask import request, current_app, abort
- from flask_login import current_user
- from walle.api.api import SecurityResource
- from walle.form.user import UserUpdateForm, RegistrationForm
- from walle.model.database import db
- from walle.model.user import MemberModel
- from walle.model.user import UserModel
- from werkzeug.security import generate_password_hash
- from walle.service.rbac.role import *
- from walle.service.extensions import permission
- class UserAPI(SecurityResource):
- actions = ['avatar', 'block', 'active']
- def get(self, user_id=None, method=None):
- """
- fetch user list or one user
- /user/<int:user_id>
- :return:
- """
- super(UserAPI, self).get()
- return self.item(user_id) if user_id else self.list()
- def list(self):
- """
- fetch user list or one user
- :return:
- """
- page = int(request.args.get('page', 0))
- page = page - 1 if page else 0
- size = float(request.args.get('size', 10))
- kw = request.values.get('kw', '')
- uids = []
- if current_user.role <> SUPER:
- members = MemberModel(group_id=current_user.last_space).members()
- uids = members['user_ids']
- user_model = UserModel()
- user_list, count = user_model.list(uids=uids, page=page, size=size, kw=kw)
- filters = {
- 'username': ['线上', '线下'],
- 'status': ['正常', '禁用']
- }
- return self.list_json(list=user_list, count=count, table=self.table(filters), enable_create=permission.enable_role(MASTER))
- def item(self, user_id):
- """
- 获取某个用户
- :param user_id:
- :return:
- """
- user_info = UserModel(id=user_id).item()
- if not user_info:
- return self.render_json(code=-1)
- return self.render_json(data=user_info)
- def post(self, user_id=None, action=None):
- """
- create user
- /user/
- :return:
- """
- super(UserAPI, self).post()
- if action and action == 'avatar':
- return self.avatar(user_id)
- form = RegistrationForm(request.form, csrf_enabled=False)
- if form.validate_on_submit():
- user = UserModel().add(form.form2dict())
- return self.render_json(data=user.item(user_id=user.id))
- return self.render_json(code=-1, message=form.errors)
- def put(self, user_id, action=None):
- """
- edit user
- /user/<int:user_id>
- :return:
- """
- super(UserAPI, self).put()
- if action:
- if action in self.actions:
- self_action = getattr(self, action.lower(), None)
- return self_action(user_id=user_id)
- else:
- abort(404)
- form = UserUpdateForm(request.form, csrf_enabled=False)
- if form.validate_on_submit():
- user = UserModel(id=user_id)
- user.update_name_pwd(username=form.username.data, password=form.password.data)
- return self.render_json(data=user.item())
- return self.render_json(code=-1, message=form.errors)
- def delete(self, user_id):
- """
- remove a user with his group relation
- /user/<int:user_id>
- :param user_id:
- :return:
- """
- super(UserAPI, self).delete()
- UserModel(id=user_id).remove()
- MemberModel().remove(user_id=user_id)
- return self.render_json(message='')
- def table(self, filter={}):
- table = {
- 'username': {
- 'sort': 0
- },
- 'email': {
- 'sort': 0
- },
- 'status': {
- 'sort': 0
- },
- 'role_name': {
- 'sort': 0
- },
- }
- ret = []
- for (key, value) in table.items():
- value['key'] = key
- if key in filter:
- value['value'] = filter[key]
- else:
- value['value'] = []
- ret.append(value)
- return ret
- def avatar(self, user_id):
- # TODO uid
- # fname = current_user.id + '.jpg'
- random = generate_password_hash(str(user_id))
- fname = random[-10:] + '.jpg'
- current_app.logger.info(fname)
- f = request.files['avatar']
- # todo rename to uid relation
- # fname = secure_filename(f.filename)
- # TODO try
- ret = f.save(os.path.join(current_app.config['UPLOAD_AVATAR'], fname))
- user = UserModel.query.get(user_id)
- user.avatar = fname
- user.save()
- return self.render_json(data={
- 'avatar': UserModel.avatar_url(user.avatar),
- })
- def block(self, user_id):
- user = UserModel(id=user_id)
- user.block_active(UserModel.status_blocked)
- return self.render_json(data=user.item())
- def active(self, user_id):
- user = UserModel(id=user_id)
- user.block_active(UserModel.status_active)
- return self.render_json(data=user.item())
|