本文整理汇总了Python中models.UserInfo.add_credit方法的典型用法代码示例。如果您正苦于以下问题:Python UserInfo.add_credit方法的具体用法?Python UserInfo.add_credit怎么用?Python UserInfo.add_credit使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类models.UserInfo
的用法示例。
在下文中一共展示了UserInfo.add_credit方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: post
# 需要导入模块: from models import UserInfo [as 别名]
# 或者: from models.UserInfo import add_credit [as 别名]
def post():
parser = reqparse.RequestParser()
parser.add_argument('login_type', type=int, required=True, help=u'缺少参数 login_type必须为 0(注册用户),1(微博用户),2(QQ用户)')
parser.add_argument('nick_name', type=str, required=True, help=u'缺少参数 nick_name必须唯一')
parser.add_argument('password', type=str, required=False)
parser.add_argument('login_name', type=str, required=False)
parser.add_argument('open_id', type=str, required=False)
args = parser.parse_args()
login_type = args.get('login_type')
nick_name = args.get('nick_name')
password = args.get('password', None)
login_name = args.get('login_name', None)
open_id = args.get('open_id', None)
err = {'status': 1}
if login_type == 0: # 注意纯数字的昵称和手机号的冲突,以后不同用户的昵称和不能用户登录名不能相同,同一个用户可以
if not password:
err['message'] = '注册用户必须要有密码'
return err
if not login_name:
err['message'] = '注册用户必须有登陆名'
return err
if nick_name.count('@'):
err['message'] = 'nick_name不能包含@符号'
return err
if User.query.filter(User.login_name == login_name).count():
err['message'] = 'login_name已重复'
return err
if User.query.filter(User.nick_name == login_name).count():
err['message'] = 'login_name已重复'
return err
if User.query.filter(User.nick_name == nick_name).count():
err['message'] = 'nick_name已重复'
return err
if User.query.filter(User.login_name == nick_name).count():
err['message'] = 'nick_name已重复'
return err
user = User(login_type=login_type, nick_name=nick_name, password=password, login_name=login_name)
db.add(user)
db.commit()
user = User.query.filter(User.login_name == login_name).first()
user_info = UserInfoDb(user_id=user.id)
if login_name.count('@'):
user_info.email = login_name
db.add(user_info)
db.commit()
user_info.add_credit('register')
db.commit()
if login_type == 1 or login_type == 2:
if not open_id:
err['message'] = '第三方登陆用户必须有open_id'
return err
if nick_name.count('@'):
err['message'] = 'nick_name不能包含@符号'
return err
if User.query.filter(User.open_id == open_id).count():
err['message'] = 'open_id已重复'
return err
if User.query.filter(User.nick_name == nick_name).count():
err['message'] = 'nick_name已重复'
return err
user = User(login_type=login_type, nick_name=nick_name, open_id=open_id)
db.add(user)
db.commit()
user = User.query.filter(User.login_name == login_name).first()
user_info = UserInfoDb(user_id=user.id)
db.add(user_info)
db.commit()
user_info.add_credit('register')
return_user = User.query.filter(User.nick_name == nick_name).first()
return wrap_user_json(return_user)