三方接口调用日志

This commit is contained in:
曹前明 2022-06-25 09:17:27 +08:00
parent 71da2960a2
commit 16c46902c1
10 changed files with 118 additions and 39 deletions

View File

@ -1,6 +1,6 @@
from apps.utils.xunxi import XxClient from apps.third.xunxi import XxClient
from apps.utils.dahua import DhClient from apps.third.dahua import DhClient
from apps.utils.speaker import SpClient from apps.third.speaker import SpClient
dhClient = DhClient() dhClient = DhClient()
xxClient = XxClient() xxClient = XxClient()
spClient = SpClient() spClient = SpClient()

35
apps/utils/dahua.py → apps/third/dahua.py Executable file → Normal file
View File

@ -1,12 +1,15 @@
import time import time
from threading import Thread from threading import Thread
import uuid
import requests import requests
from django.conf import settings from django.conf import settings
from rest_framework.exceptions import APIException, ParseError from rest_framework.exceptions import APIException, ParseError
from apps.utils.errors import DH_REQUEST_ERROR from apps.third.errors import DH_REQUEST_ERROR
from apps.third.models import Tlog
from apps.utils.tools import print_roundtrip from apps.utils.tools import print_roundtrip
from django.utils.timezone import now
requests.packages.urllib3.disable_warnings() requests.packages.urllib3.disable_warnings()
@ -26,6 +29,7 @@ class DhClient:
self.isRuning = True self.isRuning = True
self.token = None self.token = None
self.t = None # 线程 self.t = None # 线程
self.log = {}
self.setup() self.setup()
def _get_token_loop(self): def _get_token_loop(self):
@ -59,16 +63,20 @@ class DhClient:
file_path_rela=None, raise_exception=True): file_path_rela=None, raise_exception=True):
if not settings.DAHUA_ENABLED: if not settings.DAHUA_ENABLED:
raise ParseError('大华对接未启用') raise ParseError('大华对接未启用')
self.log = {"requested_at": now(), "id": uuid.uuid4(), "path": url, "method": method,
"params": params, "body": json, "target": "dahua", "result": 10}
files = None files = None
if file_path_rela: # 相对路径 if file_path_rela: # 相对路径
files = {'file': open(settings.BASE_DIR + file_path_rela, 'rb')} files = {'file': open(settings.BASE_DIR + file_path_rela, 'rb')}
try: try:
if params: if params:
url = url.format(**params) url = url.format(**params)
self.log.update({"path": url})
r = getattr(requests, method)('{}{}'.format(settings.DAHUA_BASE_URL, url), r = getattr(requests, method)('{}{}'.format(settings.DAHUA_BASE_URL, url),
headers=self.headers, params=params, json=json, headers=self.headers, params=params, json=json,
timeout=timeout, files=files, verify=False) timeout=timeout, files=files, verify=False)
except Exception: except Exception:
self.handle_log(result='error')
if raise_exception: if raise_exception:
raise APIException(**DH_REQUEST_ERROR) raise APIException(**DH_REQUEST_ERROR)
return 'error', DH_REQUEST_ERROR return 'error', DH_REQUEST_ERROR
@ -76,19 +84,36 @@ class DhClient:
# print_roundtrip(r) # print_roundtrip(r)
if r.status_code == 200: if r.status_code == 200:
ret = r.json() ret = r.json()
if ret.get('code') == '27001007':
self.get_token() # 重新获取token
self.request(url, method, params, json, timeout, file_path_rela, raise_exception)
else:
if ret['code'] not in ['0', '100', '00000', '1000', 0, 100, 1000]: if ret['code'] not in ['0', '100', '00000', '1000', 0, 100, 1000]:
detail = '大华错误:' + \ detail = '大华错误:' + \
'{}|{}{}{}'.format(str(ret['code']), ret.get('errMsg', ''), '{}|{}{}{}'.format(str(ret['code']), ret.get('errMsg', ''),
ret.get('desc', ''), str(ret.get('data', ''))) ret.get('desc', ''), str(ret.get('data', '')))
err_detail = dict(detail=detail, code='dh_'+str(ret['code'])) err_detail = dict(detail=detail, code='dh_'+str(ret['code']))
self.handle_log(result='fail', response=ret)
if raise_exception: if raise_exception:
raise ParseError(**err_detail) raise ParseError(**err_detail)
return 'fail', dict(detail=detail, code='dh_'+str(ret['code'])) return 'fail', dict(detail=detail, code='dh_'+str(ret['code']))
self.handle_log(result='success', response=ret)
return 'success', ret['data'] if 'data' in ret else None return 'success', ret['data'] if 'data' in ret else None
self.handle_log(result='error', response=None)
if raise_exception: if raise_exception:
raise APIException(**DH_REQUEST_ERROR) raise APIException(**DH_REQUEST_ERROR)
return 'error', DH_REQUEST_ERROR return 'error', DH_REQUEST_ERROR
def _get_response_ms(self):
"""
Get the duration of the request response cycle is milliseconds.
In case of negative duration 0 is returned.
"""
response_timedelta = now() - self.log["requested_at"]
response_ms = int(response_timedelta.total_seconds() * 1000)
return max(response_ms, 0)
def handle_log(self, result, response=None):
self.log.update({
"result": result,
"response": response,
"response_ms": self._get_response_ms()
})
Tlog(**self.log).save()

4
apps/third/errors.py Normal file
View File

@ -0,0 +1,4 @@
TAPI_CODE_WRONG = {"code": "tapi_code_wrong", "detail": "三方接口请求标识有误"}
XX_REQUEST_ERROR = {"code": "xx_request_error", "detail": "寻息接口访问异常"}
DH_REQUEST_ERROR = {"code": "dh_request_error", "detail": "大华接口访问异常"}
SP_REQUEST_ERROR = {"code": "sp_request_error", "detail": "音响接口访问异常"}

View File

@ -1 +0,0 @@
TAPI_CODE_WRONG = {"code": "tapi_code_wrong", "detail": "三方接口请求标识有误"}

View File

@ -0,0 +1,30 @@
# Generated by Django 3.2.12 on 2022-06-25 01:06
from django.db import migrations, models
import uuid
class Migration(migrations.Migration):
dependencies = [
('third', '0002_tdevice_is_clock'),
]
operations = [
migrations.CreateModel(
name='Tlog',
fields=[
('id', models.UUIDField(default=uuid.uuid4, primary_key=True, serialize=False)),
('target', models.CharField(max_length=20, verbose_name='请求目标')),
('result', models.CharField(max_length=20, verbose_name='请求结果')),
('path', models.CharField(help_text='请求地址', max_length=400)),
('requested_at', models.DateTimeField()),
('response_ms', models.PositiveIntegerField(default=0)),
('response', models.JSONField(blank=True, null=True)),
('method', models.CharField(max_length=10)),
('url', models.TextField(blank=True, null=True)),
('params', models.JSONField(blank=True, null=True)),
('body', models.JSONField(blank=True, null=True)),
],
),
]

View File

@ -42,18 +42,17 @@ class TDevice(BaseModel):
null=False, blank=True) null=False, blank=True)
class Tlog(BaseModel): class Tlog(models.Model):
"""第三方请求与处理日志 """第三方请求与处理日志
""" """
id = models.UUIDField(primary_key=True, default=uuid.uuid4) id = models.UUIDField(primary_key=True, default=uuid.uuid4)
result_type = models.PositiveSmallIntegerField('结果类型', target = models.CharField('请求目标', max_length=20)
default=10, result = models.CharField('请求结果', max_length=20)
help_text='10成功20失败30错误') path = models.CharField(max_length=400, help_text="请求地址")
result = models.JSONField(null=True, blank=True) requested_at = models.DateTimeField()
request_method = models.CharField(max_length=10) response_ms = models.PositiveIntegerField(default=0)
request_url = models.TextField(null=True, blank=True) response = models.JSONField(null=True, blank=True)
request_params = models.JSONField(null=True, blank=True) method = models.CharField(max_length=10)
request_json = models.JSONField(null=True, blank=True) url = models.TextField(null=True, blank=True)
bind_my_request = models.CharField('关联用户请求ID', params = models.JSONField(null=True, blank=True)
max_length=50, body = models.JSONField(null=True, blank=True)
null=True, blank=True)

View File

@ -5,7 +5,7 @@ import requests
from rest_framework.exceptions import APIException, ParseError from rest_framework.exceptions import APIException, ParseError
from django.conf import settings from django.conf import settings
from apps.utils.errors import SP_REQUEST_ERROR from apps.third.errors import SP_REQUEST_ERROR
from apps.utils.tools import print_roundtrip from apps.utils.tools import print_roundtrip
requests.packages.urllib3.disable_warnings() requests.packages.urllib3.disable_warnings()

View File

@ -3,7 +3,7 @@ from rest_framework.exceptions import ParseError, APIException
from apps.ecm.service import EcmService from apps.ecm.service import EcmService
from apps.hrm.services import HrmService from apps.hrm.services import HrmService
from apps.third.tapis import dhapis, xxapis, spapis from apps.third.tapis import dhapis, xxapis, spapis
from apps.third.erros import TAPI_CODE_WRONG from apps.third.errors import TAPI_CODE_WRONG
from apps.third.clients import dhClient, spClient, xxClient from apps.third.clients import dhClient, spClient, xxClient
from apps.utils.mixins import MyLoggingMixin from apps.utils.mixins import MyLoggingMixin
from rest_framework.response import Response from rest_framework.response import Response

29
apps/utils/xunxi.py → apps/third/xunxi.py Executable file → Normal file
View File

@ -1,12 +1,14 @@
import time import time
from threading import Thread from threading import Thread
import uuid
import requests import requests
from django.conf import settings from django.conf import settings
from rest_framework.exceptions import APIException, ParseError from rest_framework.exceptions import APIException, ParseError
from apps.utils.errors import XX_REQUEST_ERROR from apps.third.errors import XX_REQUEST_ERROR
from apps.third.models import Tlog
from apps.utils.tools import print_roundtrip from apps.utils.tools import print_roundtrip
from django.utils.timezone import now
requests.packages.urllib3.disable_warnings() requests.packages.urllib3.disable_warnings()
@ -23,6 +25,7 @@ class XxClient:
self.isGetingToken = False self.isGetingToken = False
self.isRuning = True self.isRuning = True
self.token = '' self.token = ''
self.log = {}
self.t = None self.t = None
self.setup() self.setup()
@ -65,6 +68,8 @@ class XxClient:
params['accessToken'] = self.token params['accessToken'] = self.token
json['username'] = self.username json['username'] = self.username
json['buildId'] = settings.XX_BUILDID json['buildId'] = settings.XX_BUILDID
self.log = {"requested_at": now(), "id": uuid.uuid4(), "path": url, "method": method,
"params": params, "body": json, "target": "xunxi", "result": 10}
if self.isGetingToken: if self.isGetingToken:
req_num = 0 req_num = 0
while True: while True:
@ -87,10 +92,30 @@ class XxClient:
if ret['errorCode'] != 0: if ret['errorCode'] != 0:
err_detail = dict(detail='寻息错误:' + '|'.join(ret['errorMsg']), err_detail = dict(detail='寻息错误:' + '|'.join(ret['errorMsg']),
code='xx_' + str(ret['errorCode'])) code='xx_' + str(ret['errorCode']))
self.handle_log(result='fail', response=None)
if raise_exception: if raise_exception:
raise ParseError(**err_detail) raise ParseError(**err_detail)
return 'fail', err_detail return 'fail', err_detail
self.handle_log(result='success', response=None)
return 'success', ret['data'] return 'success', ret['data']
self.handle_log(result='error', response=None)
if raise_exception: if raise_exception:
raise APIException(**XX_REQUEST_ERROR) raise APIException(**XX_REQUEST_ERROR)
return 'error', XX_REQUEST_ERROR return 'error', XX_REQUEST_ERROR
def _get_response_ms(self):
"""
Get the duration of the request response cycle is milliseconds.
In case of negative duration 0 is returned.
"""
response_timedelta = now() - self.log["requested_at"]
response_ms = int(response_timedelta.total_seconds() * 1000)
return max(response_ms, 0)
def handle_log(self, result, response=None):
self.log.update({
"result": result,
"response": response,
"response_ms": self._get_response_ms()
})
Tlog(**self.log).save()

View File

@ -1,5 +1,2 @@
XX_REQUEST_ERROR = {"code": "xx_request_error", "detail": "寻息接口访问异常"}
DH_REQUEST_ERROR = {"code": "dh_request_error", "detail": "大华接口访问异常"}
SP_REQUEST_ERROR = {"code": "sp_request_error", "detail": "音响接口访问异常"}
SIGN_MAKE_FAIL = {"code": "sign_make_fail", "detail": "签名照生成失败,请重新上传"} SIGN_MAKE_FAIL = {"code": "sign_make_fail", "detail": "签名照生成失败,请重新上传"}
PKS_ERROR = {"code": "pks_error", "detail": "未获取到主键列表"} PKS_ERROR = {"code": "pks_error", "detail": "未获取到主键列表"}