utils.py 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. import json
  2. import hashlib
  3. import time
  4. import requests
  5. from requests.auth import HTTPBasicAuth
  6. def get_equip_list(d_id, isfullId=0):
  7. """
  8. 跨平台获取设备信息
  9. :param d_id: 设备号
  10. :param isfullId:0模糊匹配,1表示完整设备号匹配
  11. :return:列表数据,相同设备号放一起,并且最近更新数据靠前,最近更新数据可认为设备最后所在平台
  12. """
  13. if isfullId == 1:
  14. bigdata_res = requests.post("http://8.136.98.49:8002/search/equip", data={"device_id": d_id, "isfullId": "1"})
  15. siqing_res = requests.post("http://www.yfzhwlw.com/search/equip", data={"device_id": d_id, "isfullId": "1"})
  16. else:
  17. bigdata_res = requests.post("http://8.136.98.49:8002/search/equip", data={"device_id": d_id})
  18. siqing_res = requests.post("http://www.yfzhwlw.com/search/equip", data={"device_id": d_id})
  19. django_data = json.loads(bigdata_res.content.decode()).get("data", [])
  20. siqing_data = json.loads(siqing_res.content.decode()).get("data", [])
  21. data = []
  22. data.extend(django_data)
  23. data.extend(siqing_data)
  24. data = sorted(data, key=lambda e: e.__getitem__('uptime'), reverse=True)
  25. data = sorted(data, key=lambda e: e.__getitem__('device_id'), reverse=True)
  26. return data
  27. class Get_SIM_info(object):
  28. """
  29. 自定义获取SIM卡对应卡商及数据
  30. """
  31. def __init__(self, iccid) -> None:
  32. self.iccid = iccid
  33. self.hz_status = {
  34. 0: "未知",
  35. 1: "测试期",
  36. 2: "沉默期",
  37. 3: "使用中",
  38. 4: "停机",
  39. 5: "停机保号",
  40. 6: "预销号",
  41. 7: "销号"
  42. }
  43. self.qp_status = {
  44. "testing": "测试中",
  45. "inventory": "库存",
  46. "pending-activation": "待激活",
  47. "activation": "已激活",
  48. "deactivation": "已停卡",
  49. "retired": "已销卡"
  50. }
  51. def hz_sim_info(self):
  52. """获取合宙流量卡信息"""
  53. url = "http://api.openluat.com/sim/iotcard/card"
  54. payload = {
  55. 'iccid': self.iccid,
  56. }
  57. appkey = 'KDlhc9VY4rWSXkbM'
  58. appsecret = 'DmwxcSB1b8dx7kLWqWMJNRLgyQhCvPJ7DHIfLdHIz9A18CifSHqJk3nWZ1vHv4cR'
  59. auth = HTTPBasicAuth(appkey, appsecret)
  60. try:
  61. res = requests.post(url, json=payload, auth=auth, timeout=5)
  62. data = json.loads(res.text)
  63. except Exception as e:
  64. data = {'code': 99999, 'msg': '接口调用异常异常'}
  65. return data
  66. def qp_sim_info(self):
  67. """ 获取企鹏(SIMBOSS)流量卡信息 """
  68. url = "https://api.simboss.com/2.0/device/detail"
  69. current_milli_time = lambda: int(round(time.time() * 1000))
  70. data_1 = "appid=%s&iccid=%s&timestamp=%s%s" % (
  71. "102420177762", self.iccid, current_milli_time(), "6397d7e6a56589f1d93284e9800493e1")
  72. sign = hashlib.sha256(data_1.encode('utf-8')).hexdigest()
  73. data = {"appid": "102420177762", "iccid": self.iccid, "timestamp": current_milli_time(), "sign": sign}
  74. try:
  75. res = requests.post(url, data=data, timeout=5)
  76. data = json.loads(res.text)
  77. except Exception as e:
  78. data = {'code': 99999, 'msg': '接口调用异常异常'}
  79. return data
  80. def get_sim_info(self):
  81. """未知卡商情况下获取卡信息"""
  82. hz_data = self.hz_sim_info()
  83. if hz_data["code"] == 0: # 合宙
  84. sim_operators = 1
  85. account_status = self.hz_status[hz_data["data"]["account_status"]]
  86. if hz_data["data"]["active"] == 1:
  87. active_date = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(hz_data["data"]["active_date"]))
  88. data_plan = str(hz_data["data"]["data_plan"]) + "M"
  89. data_usage = str(hz_data["data"]["data_usage"]) + "M"
  90. data_balance = str(hz_data["data"]["data_balance"]) + "M"
  91. expiry_date = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(hz_data["data"]["expiry_date"]))
  92. else:
  93. active_date = "未激活"
  94. data_plan = "未激活"
  95. data_usage = "未激活"
  96. data_balance = "未激活"
  97. expiry_date = "未激活"
  98. else:
  99. qp_data = self.qp_sim_info()
  100. if qp_data["code"] == "0":
  101. sim_operators = 2
  102. account_status = self.qp_status[qp_data["data"]["status"]]
  103. active_date = qp_data["data"].get("startDate", "")
  104. if active_date:
  105. if qp_data["data"]["useCountAsVolume"] == False:
  106. data_plan = str(qp_data["data"]["totalDataVolume"]) + "M"
  107. data_usage = str(qp_data["data"]["usedDataVolume"]) + "M"
  108. data_balance = str(qp_data["data"]["totalDataVolume"] - qp_data["data"]["usedDataVolume"]) + "M"
  109. else:
  110. data_plan = str(qp_data["data"]["totalDataVolume"] * 1024) + "M"
  111. data_usage = str(qp_data["data"]["usedDataVolume"] * 1024) + "M"
  112. data_balance = str(
  113. (qp_data["data"]["totalDataVolume"] - qp_data["data"]["usedDataVolume"]) * 1024) + "M"
  114. expiry_date = qp_data["data"]["expireDate"]
  115. else:
  116. data_plan = "未激活"
  117. data_usage = "未激活"
  118. data_balance = "未激活"
  119. expiry_date = "未激活"
  120. else:
  121. sim_operators = 3
  122. account_status = "未知"
  123. active_date = "未知"
  124. data_plan = "未知"
  125. data_usage = "未知"
  126. data_balance = "未知"
  127. expiry_date = "未知"
  128. return sim_operators, account_status, active_date, data_plan, data_usage, data_balance, expiry_date