user.py 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. #-*- coding:utf-8 -*-
  2. import json
  3. from rrd import corelib
  4. from rrd import config
  5. from rrd.utils.logger import logging
  6. log = logging.getLogger(__file__)
  7. class UserToken(object):
  8. def __init__(self, name, sig):
  9. self.name = name
  10. self.sig = sig
  11. def __repr__(self):
  12. return "<UserToken name=%s, sig=%s>" % (self.name, self.sig)
  13. __str__ = __repr__
  14. class User(object):
  15. def __init__(self, id, name, cnname, email, phone, im, qq, role):
  16. self.id = id
  17. self.name = name
  18. self.cnname = cnname
  19. self.email = email
  20. self.phone = phone
  21. self.im = im
  22. self.qq = qq
  23. self.role = role
  24. def __repr__(self):
  25. return "<User id=%s, name=%s, cnname=%s>" \
  26. % (self.id, self.name, self.cnname)
  27. __str__ = __repr__
  28. def dict(self):
  29. return {
  30. 'id': self.id,
  31. 'name': self.name,
  32. 'cnmame': self.cnname,
  33. 'email': self.email,
  34. 'phone': self.phone,
  35. 'im': self.im,
  36. 'qq': self.qq,
  37. 'role': self.role,
  38. }
  39. def is_root(self):
  40. return str(self.role) == "2"
  41. def is_admin(self):
  42. return str(self.role) == "1"
  43. def in_teams(self, groups=[]):
  44. if not groups:
  45. return False
  46. r = corelib.auth_requests("GET", '%s/user/u/%s/in_teams?team_names=%s' \
  47. % (config.API_ADDR, self.id, ','.join(groups)))
  48. log.debug("%s:%s" %(r.status_code, r.text))
  49. if r.status_code != 200:
  50. return False
  51. j = r.json()
  52. return j["message"] == "true"
  53. @classmethod
  54. def get_by_id(cls, user_id):
  55. h = {"Content-type": "application/json"}
  56. r = corelib.auth_requests("GET", "%s/user/u/%s" %(config.API_ADDR, user_id), headers=h)
  57. log.debug("%s:%s" %(r.status_code, r.text))
  58. if r.status_code != 200:
  59. raise Exception("%s %s" %(r.status_code, r.text))
  60. j = r.json()
  61. return j and cls(j['id'], j['name'], j['cnname'], j['email'], j['phone'], j['im'], j['qq'], j['role'])
  62. @classmethod
  63. def get_by_name(cls, name):
  64. h = {"Content-type": "application/json"}
  65. r = corelib.auth_requests("GET", "%s/user/name/%s" %(config.API_ADDR, name), headers=h)
  66. log.debug("%s:%s" %(r.status_code, r.text))
  67. if r.status_code != 200:
  68. raise Exception("%s %s" %(r.status_code, r.text))
  69. j = r.json()
  70. return j and cls(j['id'], j['name'], j['cnname'], j['email'], j['phone'], j['im'], j['qq'], j['role'])
  71. @classmethod
  72. def update_user_profile(cls, data={}):
  73. h = {"Content-type": "application/json"}
  74. r = corelib.auth_requests("PUT", "%s/user/update" %(config.API_ADDR,), \
  75. data=json.dumps(data), headers=h)
  76. log.debug("%s:%s" %(r.status_code, r.text))
  77. if r.status_code != 200:
  78. raise Exception("%s %s" %(r.status_code, r.text))
  79. return r.text
  80. @classmethod
  81. def change_user_passwd(cls, old_password, new_password):
  82. h = {"Content-type":"application/json"}
  83. d = {
  84. "old_password": old_password,
  85. "new_password": new_password,
  86. }
  87. r = corelib.auth_requests("PUT", "%s/user/cgpasswd" %(config.API_ADDR,), \
  88. data=json.dumps(d), headers=h)
  89. log.debug("%s:%s" %(r.status_code, r.text))
  90. if r.status_code != 200:
  91. raise Exception("%s %s" %(r.status_code, r.text))
  92. return r.text
  93. @classmethod
  94. def get_users(cls, query_term, limit=20, page=1):
  95. users = []
  96. if not query_term:
  97. query_term = '.'
  98. d = {
  99. "q": query_term,
  100. "limit": limit,
  101. "page": page,
  102. }
  103. h = {"Content-type":"application/json"}
  104. r = corelib.auth_requests("GET", "%s/user/users" \
  105. %(config.API_ADDR,), params=d, headers=h)
  106. log.debug("%s:%s" %(r.status_code, r.text))
  107. if r.status_code != 200:
  108. raise Exception("%s %s" %(r.status_code, r.text))
  109. j = r.json() or []
  110. for x in j:
  111. u = cls(x["id"], x["name"], x["cnname"], x["email"], x["phone"], x["im"], x["qq"], x["role"])
  112. users.append(u)
  113. return users
  114. #anyone can create user
  115. @classmethod
  116. def create_user(cls, name, cnname, password, email, phone="", im="", qq=""):
  117. h = {"Content-type": "application/json"}
  118. d = {
  119. "name": name, "cnname": cnname, "password": password, "email": email, "phone": phone, "im": im, "qq": qq,
  120. }
  121. r = corelib.auth_requests("POST", "%s/user/create" %(config.API_ADDR,), \
  122. data=json.dumps(d), headers=h)
  123. log.debug("%s:%s" %(r.status_code, r.text))
  124. if r.status_code != 200:
  125. raise Exception("%s %s" %(r.status_code, r.text))
  126. return r.json()
  127. @classmethod
  128. def admin_update_user_profile(cls, data={}):
  129. h = {"Content-type": "application/json"}
  130. r = corelib.auth_requests("PUT", "%s/admin/change_user_profile" %(config.API_ADDR,), \
  131. data=json.dumps(data), headers=h)
  132. log.debug("%s:%s" %(r.status_code, r.text))
  133. if r.status_code != 200:
  134. raise Exception("%s %s" %(r.status_code, r.text))
  135. return r.text
  136. @classmethod
  137. def admin_change_user_passwd(cls, user_id, password):
  138. h = {"Content-type": "application/json"}
  139. d = {
  140. "user_id": user_id, "password": password,
  141. }
  142. r = corelib.auth_requests("PUT", "%s/admin/change_user_passwd" %(config.API_ADDR,), \
  143. data=json.dumps(d), headers=h)
  144. log.debug("%s:%s" %(r.status_code, r.text))
  145. if r.status_code != 200:
  146. raise Exception("%s %s" %(r.status_code, r.text))
  147. return r.text
  148. @classmethod
  149. def admin_change_user_role(cls, user_id, admin):
  150. h = {"Content-type":"application/json"}
  151. d = {"admin": admin, "user_id": user_id}
  152. r = corelib.auth_requests("PUT", "%s/admin/change_user_role" \
  153. %(config.API_ADDR,), data=json.dumps(d), headers=h)
  154. log.debug("%s:%s" %(r.status_code, r.text))
  155. if r.status_code != 200:
  156. raise Exception("%s %s" %(r.status_code, r.text))
  157. return r.text
  158. @classmethod
  159. def admin_delete_user(cls, user_id):
  160. h = {"Content-type":"application/json"}
  161. d = {"user_id": int(user_id)}
  162. r = corelib.auth_requests("DELETE", "%s/admin/delete_user" \
  163. %(config.API_ADDR,), data=json.dumps(d), headers=h)
  164. log.debug("%s:%s" %(r.status_code, r.text))
  165. if r.status_code != 200:
  166. raise Exception("%s %s" %(r.status_code, r.text))
  167. return r.text