From e26dc2d07314afbfc85d57b4f0b729a7ddc7e3c8 Mon Sep 17 00:00:00 2001 From: kingmo888 <17401091+kingmo888@users.noreply.github.com> Date: Fri, 9 Aug 2024 18:35:58 +0800 Subject: [PATCH] code for flake8, change menu level --- api/templates/base.html | 10 ++- api/views_api.py | 133 +++++++++++++++++++----------------- api/views_front.py | 146 ++++++++++++++++++++++------------------ db/db.sqlite3 | Bin 163840 -> 163840 bytes 4 files changed, 156 insertions(+), 133 deletions(-) diff --git a/api/templates/base.html b/api/templates/base.html index bad0d35..ec0260e 100644 --- a/api/templates/base.html +++ b/api/templates/base.html @@ -37,10 +37,14 @@
  • {% trans "网页控制" %}
  • {% if u.is_admin %} -
  • {% trans "连接日志" %}
  • -
  • {% trans "文件传输日志" %}
  • -
  • {% trans "管理后台" %} +
  • + {% trans "日志" %} +
    +
    {% trans "连接日志" %}
    +
    {% trans "文件传输日志" %}
    +
  • +
  • {% trans "管理后台" %}
  • {% endif %}
  • {% trans "退出" %}
  • diff --git a/api/views_api.py b/api/views_api.py index e38dc0e..83ca601 100644 --- a/api/views_api.py +++ b/api/views_api.py @@ -3,10 +3,10 @@ from django.http import JsonResponse import json import time import datetime -import hashlib +# import hashlib import math from django.contrib import auth -from django.forms.models import model_to_dict +# from django.forms.models import model_to_dict from api.models import RustDeskToken, UserProfile, RustDeskTag, RustDeskPeer, RustDesDevice, ConnLog, FileLog from django.db.models import Q import copy @@ -21,7 +21,7 @@ def login(request): return JsonResponse(result) data = json.loads(request.body.decode()) - + username = data.get('username', '') password = data.get('password', '') rid = data.get('id', '') @@ -29,19 +29,19 @@ def login(request): autoLogin = data.get('autoLogin', True) rtype = data.get('type', '') deviceInfo = data.get('deviceInfo', '') - user = auth.authenticate(username=username,password=password) + user = auth.authenticate(username=username, password=password) if not user: result['error'] = _('帐号或密码错误!请重试,多次重试后将被锁定IP!') return JsonResponse(result) user.rid = rid user.uuid = uuid user.autoLogin = autoLogin - user.rtype = rtype + user.rtype = rtype user.deviceInfo = json.dumps(deviceInfo) user.save() - + token = RustDeskToken.objects.filter(Q(uid=user.id) & Q(username=user.username) & Q(rid=user.rid)).first() - + # 检查是否过期 if token: now_t = datetime.datetime.now() @@ -49,7 +49,7 @@ def login(request): if nums >= EFFECTIVE_SECONDS: token.delete() token = None - + if not token: # 获取并保存token token = RustDeskToken( @@ -57,33 +57,33 @@ def login(request): uid=user.id, uuid=user.uuid, rid=user.rid, - access_token=getStrMd5(str(time.time())+salt) + access_token=getStrMd5(str(time.time()) + salt) ) token.save() result['access_token'] = token.access_token result['type'] = 'access_token' - result['user'] = {'name':user.username} + result['user'] = {'name': user.username} return JsonResponse(result) def logout(request): if request.method == 'GET': - result = {'error':_('请求方式错误!')} + result = {'error': _('请求方式错误!')} return JsonResponse(result) - + data = json.loads(request.body.decode()) rid = data.get('id', '') uuid = data.get('uuid', '') user = UserProfile.objects.filter(Q(rid=rid) & Q(uuid=uuid)).first() if not user: - result = {'error':_('异常请求!')} + result = {'error': _('异常请求!')} return JsonResponse(result) token = RustDeskToken.objects.filter(Q(uid=user.id) & Q(rid=user.rid)).first() if token: token.delete() - result = {'code':1} + result = {'code': 1} return JsonResponse(result) @@ -92,17 +92,17 @@ def currentUser(request): if request.method == 'GET': result['error'] = _('错误的提交方式!') return JsonResponse(result) - postdata = json.loads(request.body) - rid = postdata.get('id', '') - uuid = postdata.get('uuid', '') - + # postdata = json.loads(request.body) + # rid = postdata.get('id', '') + # uuid = postdata.get('uuid', '') + access_token = request.META.get('HTTP_AUTHORIZATION', '') access_token = access_token.split('Bearer ')[-1] - token = RustDeskToken.objects.filter(Q(access_token=access_token) ).first() + token = RustDeskToken.objects.filter(Q(access_token=access_token)).first() user = None if token: user = UserProfile.objects.filter(Q(id=token.uid)).first() - + if user: if token: result['access_token'] = token.access_token @@ -116,53 +116,53 @@ def ab(request): ''' access_token = request.META.get('HTTP_AUTHORIZATION', '') access_token = access_token.split('Bearer ')[-1] - token = RustDeskToken.objects.filter(Q(access_token=access_token) ).first() + token = RustDeskToken.objects.filter(Q(access_token=access_token)).first() if not token: - result = {'error':_('拉取列表错误!')} + result = {'error': _('拉取列表错误!')} return JsonResponse(result) - + if request.method == 'GET': result = {} uid = token.uid - tags = RustDeskTag.objects.filter(Q(uid=uid) ) + tags = RustDeskTag.objects.filter(Q(uid=uid)) tag_names = [] tag_colors = {} if tags: tag_names = [str(x.tag_name) for x in tags] - tag_colors = {str(x.tag_name):int(x.tag_color) for x in tags if x.tag_color!=''} - + tag_colors = {str(x.tag_name): int(x.tag_color) for x in tags if x.tag_color != ''} + peers_result = [] - peers = RustDeskPeer.objects.filter(Q(uid=uid) ) + peers = RustDeskPeer.objects.filter(Q(uid=uid)) if peers: for peer in peers: tmp = { - 'id':peer.rid, - 'username':peer.username, - 'hostname':peer.hostname, - 'alias':peer.alias, - 'platform':peer.platform, - 'tags':peer.tags.split(','), - 'hash':peer.rhash, + 'id': peer.rid, + 'username': peer.username, + 'hostname': peer.hostname, + 'alias': peer.alias, + 'platform': peer.platform, + 'tags': peer.tags.split(','), + 'hash': peer.rhash, } peers_result.append(tmp) - + result['updated_at'] = datetime.datetime.now() result['data'] = { - 'tags':tag_names, - 'peers':peers_result, - 'tag_colors':json.dumps(tag_colors) + 'tags': tag_names, + 'peers': peers_result, + 'tag_colors': json.dumps(tag_colors) } result['data'] = json.dumps(result['data']) return JsonResponse(result) else: postdata = json.loads(request.body.decode()) data = postdata.get('data', '') - data = {} if data=='' else json.loads(data) + data = {} if data == '' else json.loads(data) tagnames = data.get('tags', []) tag_colors = data.get('tag_colors', '') - tag_colors = {} if tag_colors=='' else json.loads(tag_colors) + tag_colors = {} if tag_colors == '' else json.loads(tag_colors) peers = data.get('peers', []) - + if tagnames: # 删除旧的tag RustDeskTag.objects.filter(uid=token.uid).delete() @@ -189,32 +189,34 @@ def ab(request): platform=one['platform'], tags=','.join(one['tags']), rhash=one['hash'], - - + + ) newlist.append(peer) RustDeskPeer.objects.bulk_create(newlist) result = { - 'code':102, - 'data':_('更新地址簿有误') + 'code': 102, + 'data': _('更新地址簿有误') } return JsonResponse(result) + def ab_get(request): # 兼容 x86-sciter 版客户端,此版客户端通过访问 "POST /api/ab/get" 来获取地址簿 request.method = 'GET' return ab(request) + def sysinfo(request): # 客户端注册服务后,才会发送设备信息 result = {} if request.method == 'GET': result['error'] = _('错误的提交方式!') return JsonResponse(result) - + postdata = json.loads(request.body) - device = RustDesDevice.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid']) ).first() + device = RustDesDevice.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid'])).first() if not device: device = RustDesDevice( rid=postdata['id'], @@ -231,25 +233,27 @@ def sysinfo(request): postdata2 = copy.copy(postdata) postdata2['rid'] = postdata2['id'] postdata2.pop('id') - RustDesDevice.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid']) ).update(**postdata2) + RustDesDevice.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid'])).update(**postdata2) result['data'] = 'ok' return JsonResponse(result) + def heartbeat(request): postdata = json.loads(request.body) - device = RustDesDevice.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid']) ).first() + device = RustDesDevice.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid'])).first() if device: device.save() # token保活 create_time = datetime.datetime.now() + datetime.timedelta(seconds=EFFECTIVE_SECONDS) - RustDeskToken.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid']) ).update(create_time=create_time) + RustDeskToken.objects.filter(Q(rid=postdata['id']) & Q(uuid=postdata['uuid'])).update(create_time=create_time) result = {} result['data'] = _('在线') return JsonResponse(result) + def audit(request): postdata = json.loads(request.body) - #print(postdata) + # print(postdata) audit_type = postdata['action'] if 'action' in postdata else '' if audit_type == 'new': new_conn_log = ConnLog( @@ -263,7 +267,7 @@ def audit(request): uuid=postdata['uuid'] if 'uuid' in postdata else '', ) new_conn_log.save() - elif audit_type =="close": + elif audit_type == "close": ConnLog.objects.filter(Q(conn_id=postdata['conn_id'])).update(conn_end=datetime.datetime.now()) elif 'is_file' in postdata: print(postdata) @@ -284,15 +288,16 @@ def audit(request): peer = postdata['peer'] ConnLog.objects.filter(Q(conn_id=postdata['conn_id'])).update(session_id=postdata['session_id']) ConnLog.objects.filter(Q(conn_id=postdata['conn_id'])).update(from_id=peer[0]) - except: - print(postdata) + except Exception as e: + print(postdata, e) result = { - 'code':1, - 'data':'ok' + 'code': 1, + 'data': 'ok' } return JsonResponse(result) + def convert_filesize(size_bytes): if size_bytes == 0: return "0B" @@ -301,17 +306,19 @@ def convert_filesize(size_bytes): p = math.pow(1024, i) s = round(size_bytes / p, 2) return "%s %s" % (s, size_name[i]) - + + def users(request): result = { - 'code':1, - 'data':_('好的') + 'code': 1, + 'data': _('好的') } return JsonResponse(result) - + + def peers(request): result = { - 'code':1, - 'data':'ok' + 'code': 1, + 'data': 'ok' } - return JsonResponse(result) \ No newline at end of file + return JsonResponse(result) diff --git a/api/views_front.py b/api/views_front.py index 286c8dc..fa43427 100644 --- a/api/views_front.py +++ b/api/views_front.py @@ -28,6 +28,7 @@ from django.utils.translation import gettext as _ salt = 'xiaomo' EFFECTIVE_SECONDS = 7200 + def getStrMd5(s): if not isinstance(s, (str,)): s = str(s) @@ -37,6 +38,7 @@ def getStrMd5(s): return myHash.hexdigest() + def model_to_dict2(instance, fields=None, exclude=None, replace=None, default=None): """ :params instance: 模型对象,不能是queryset数据集 @@ -49,21 +51,21 @@ def model_to_dict2(instance, fields=None, exclude=None, replace=None, default=No if not isinstance(instance, Model): raise Exception(_('model_to_dict接收的参数必须是模型对象')) # 对替换数据库字段名字校验 - if replace and type(replace) == dict: + if replace and type(replace) == dict: # noqa for replace_field in replace.values(): if hasattr(instance, replace_field): raise Exception(_(f'model_to_dict,要替换成{replace_field}字段已经存在了')) # 对要新增的默认值进行校验 - if default and type(default) == dict: + if default and type(default) == dict: # noqa for default_key in default.keys(): if hasattr(instance, default_key): - raise Exception(_(f'model_to_dict,要新增默认值,但字段{default_key}已经存在了')) + raise Exception(_(f'model_to_dict,要新增默认值,但字段{default_key}已经存在了')) # noqa opts = instance._meta data = {} for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many): # 源码下:这块代码会将时间字段剔除掉,我加上一层判断,让其不再剔除时间字段 if not getattr(f, 'editable', False): - if type(f) == DateField or type(f) == DateTimeField: + if type(f) == DateField or type(f) == DateTimeField: # noqa pass else: continue @@ -76,22 +78,22 @@ def model_to_dict2(instance, fields=None, exclude=None, replace=None, default=No key = f.name # 获取字段对应的数据 - if type(f) == DateTimeField: + if type(f) == DateTimeField: # noqa # 字段类型是,DateTimeFiled 使用自己的方式操作 value = getattr(instance, key) value = datetime.datetime.strftime(value, '%Y-%m-%d %H:%M') - elif type(f) == DateField: + elif type(f) == DateField: # noqa # 字段类型是,DateFiled 使用自己的方式操作 value = getattr(instance, key) value = datetime.datetime.strftime(value, '%Y-%m-%d') - elif type(f) == CharField or type(f) == TextField: + elif type(f) == CharField or type(f) == TextField: # noqa # 字符串数据是否可以进行序列化,转成python结构数据 value = getattr(instance, key) try: value = json.loads(value) - except Exception as _: + except Exception as _: # noqa value = value - else:#其他类型的字段 + else: # 其他类型的字段 # value = getattr(instance, key) key = f.name value = f.value_from_object(instance) @@ -100,15 +102,15 @@ def model_to_dict2(instance, fields=None, exclude=None, replace=None, default=No if replace and key in replace.keys(): key = replace.get(key) data[key] = value - #2、新增默认的字段数据 + # 2、新增默认的字段数据 if default: data.update(default) return data def index(request): - print('sdf',sys.argv) - if request.user and request.user.username!='AnonymousUser': + print('sdf', sys.argv) + if request.user and request.user.username != 'AnonymousUser': return HttpResponseRedirect('/api/work') return HttpResponseRedirect('/api/user_action?action=login') @@ -124,6 +126,7 @@ def user_action(request): else: return + def user_login(request): if request.method == 'GET': return render(request, 'login.html') @@ -131,14 +134,15 @@ def user_login(request): username = request.POST.get('account', '') password = request.POST.get('password', '') if not username or not password: - return JsonResponse({'code':0, 'msg':_('出了点问题,未获取用户名或密码。')}) + return JsonResponse({'code': 0, 'msg': _('出了点问题,未获取用户名或密码。')}) - user = auth.authenticate(username=username,password=password) + user = auth.authenticate(username=username, password=password) if user: auth.login(request, user) - return JsonResponse({'code':1, 'url':'/api/work'}) + return JsonResponse({'code': 1, 'url': '/api/work'}) else: - return JsonResponse({'code':0, 'msg':_('帐号或密码错误!')}) + return JsonResponse({'code': 0, 'msg': _('帐号或密码错误!')}) + def user_register(request): info = '' @@ -146,8 +150,8 @@ def user_register(request): return render(request, 'reg.html') ALLOW_REGISTRATION = settings.ALLOW_REGISTRATION result = { - 'code':0, - 'msg':'' + 'code': 0, + 'msg': '' } if not ALLOW_REGISTRATION: result['msg'] = _('当前未开放注册,请联系管理员!') @@ -161,7 +165,7 @@ def user_register(request): result['msg'] = info return JsonResponse(result) - if len(password1)<8 or len(password1)>20: + if len(password1) < 8 or len(password1) > 20: info = _('密码长度不符合要求, 应在8~20位。') result['msg'] = info return JsonResponse(result) @@ -174,28 +178,30 @@ def user_register(request): user = UserProfile( username=username, password=make_password(password1), - is_admin = True if UserProfile.objects.count()==0 else False, - is_superuser = True if UserProfile.objects.count()==0 else False, - is_active = True + is_admin=True if UserProfile.objects.count() == 0 else False, + is_superuser=True if UserProfile.objects.count() == 0 else False, + is_active=True ) user.save() result['msg'] = info result['code'] = 1 return JsonResponse(result) + @login_required(login_url='/api/user_action?action=login') def user_logout(request): - info = '' + # info='' auth.logout(request) return HttpResponseRedirect('/api/user_action?action=login') - + + def get_single_info(uid): peers = RustDeskPeer.objects.filter(Q(uid=uid)) rids = [x.rid for x in peers] - peers = {x.rid:model_to_dict(x) for x in peers} - #print(peers) + peers = {x.rid: model_to_dict(x) for x in peers} + # print(peers) devices = RustDesDevice.objects.filter(rid__in=rids) - devices = {x.rid:x for x in devices} + devices = {x.rid: x for x in devices} now = datetime.datetime.now() for rid, device in devices.items(): peers[rid]['create_time'] = device.create_time.strftime('%Y-%m-%d') @@ -204,39 +210,42 @@ def get_single_info(uid): peers[rid]['memory'] = device.memory peers[rid]['cpu'] = device.cpu peers[rid]['os'] = device.os - peers[rid]['status'] = _('在线') if (now-device.update_time).seconds <=120 else _('离线') + peers[rid]['status'] = _('在线') if (now - device.update_time).seconds <= 120 else _('离线') for rid in peers.keys(): - peers[rid]['has_rhash'] = _('是') if len(peers[rid]['rhash'])>1 else _('否') + peers[rid]['has_rhash'] = _('是') if len(peers[rid]['rhash']) > 1 else _('否') + + return [v for k, v in peers.items()] - return [v for k,v in peers.items()] def get_all_info(): devices = RustDesDevice.objects.all() peers = RustDeskPeer.objects.all() - devices = {x.rid:model_to_dict2(x) for x in devices} + devices = {x.rid: model_to_dict2(x) for x in devices} now = datetime.datetime.now() for peer in peers: user = UserProfile.objects.filter(Q(id=peer.uid)).first() device = devices.get(peer.rid, None) if device: devices[peer.rid]['rust_user'] = user.username - + for k, v in devices.items(): - devices[k]['status'] = _('在线') if (now-datetime.datetime.strptime(v['update_time'], '%Y-%m-%d %H:%M')).seconds <=120 else _('离线') - return [v for k,v in devices.items()] + devices[k]['status'] = _('在线') if (now - datetime.datetime.strptime(v['update_time'], '%Y-%m-%d %H:%M')).seconds <= 120 else _('离线') + return [v for k, v in devices.items()] + @login_required(login_url='/api/user_action?action=login') def work(request): username = request.user u = UserProfile.objects.get(username=username) - + show_type = request.GET.get('show_type', '') show_all = True if show_type == 'admin' and u.is_admin else False paginator = Paginator(get_all_info(), 15) if show_type == 'admin' and u.is_admin else Paginator(get_single_info(u.id), 15) page_number = request.GET.get('page') page_obj = paginator.get_page(page_number) - return render(request, 'show_work.html', {'u':u, 'show_all':show_all, 'page_obj':page_obj}) + return render(request, 'show_work.html', {'u': u, 'show_all': show_all, 'page_obj': page_obj}) + @login_required(login_url='/api/user_action?action=login') def down_peers(request): @@ -246,7 +255,7 @@ def down_peers(request): if not u.is_admin: print(u.is_admin) return HttpResponseRedirect('/api/work') - + all_info = get_all_info() f = xlwt.Workbook(encoding='utf-8') sheet1 = f.add_sheet(_(u'设备信息表'), cell_overwrite_ok=True) @@ -257,7 +266,7 @@ def down_peers(request): if i == 0: # 写入列名 sheet1.write(i, j, name) - sheet1.write(i+1, j, one.get(name, '-')) + sheet1.write(i + 1, j, one.get(name, '-')) sio = BytesIO() f.save(sio) @@ -266,12 +275,13 @@ def down_peers(request): response['Content-Disposition'] = 'attachment; filename=DeviceInfo.xls' response.write(sio.getvalue()) return response - + + def check_sharelink_expired(sharelink): now = datetime.datetime.now() if sharelink.create_time > now: return False - if (now - sharelink.create_time).seconds <15 * 60: + if (now - sharelink.create_time).seconds < 15 * 60: return False else: sharelink.is_expired = True @@ -284,19 +294,18 @@ def share(request): peers = RustDeskPeer.objects.filter(Q(uid=request.user.id)) sharelinks = ShareLink.objects.filter(Q(uid=request.user.id) & Q(is_used=False) & Q(is_expired=False)) - # 省资源:处理已过期请求,不主动定时任务轮询请求,在任意地方请求时,检查是否过期,过期则保存。 now = datetime.datetime.now() for sl in sharelinks: check_sharelink_expired(sl) sharelinks = ShareLink.objects.filter(Q(uid=request.user.id) & Q(is_used=False) & Q(is_expired=False)) - peers = [{'id':ix+1, 'name':f'{p.rid}|{p.alias}'} for ix, p in enumerate(peers)] - sharelinks = [{'shash':s.shash, 'is_used':s.is_used, 'is_expired':s.is_expired, 'create_time':s.create_time, 'peers':s.peers} for ix, s in enumerate(sharelinks)] + peers = [{'id': ix + 1, 'name': f'{p.rid}|{p.alias}'} for ix, p in enumerate(peers)] + sharelinks = [{'shash': s.shash, 'is_used': s.is_used, 'is_expired': s.is_expired, 'create_time': s.create_time, 'peers': s.peers} for ix, s in enumerate(sharelinks)] if request.method == 'GET': url = request.build_absolute_uri() if url.endswith('share'): - return render(request, 'share.html', {'peers':peers, 'sharelinks':sharelinks}) + return render(request, 'share.html', {'peers': peers, 'sharelinks': sharelinks}) else: shash = url.split('/')[-1] sharelink = ShareLink.objects.filter(Q(shash=shash)) @@ -323,15 +332,15 @@ def share(request): for peer in peers_share: if peer.rid in peers_self_ids: continue - #peer = RustDeskPeer.objects.get(rid=peer.rid) + # peer = RustDeskPeer.objects.get(rid=peer.rid) peer_f = RustDeskPeer.objects.filter(Q(rid=peer.rid) & Q(uid=sharelink.uid)) if not peer_f: msg += f"{peer.rid}已存在," continue - + if len(peer_f) > 1: - msg += f'{peer.rid}存在多个,已经跳过。 ' - continue + msg += f'{peer.rid}存在多个,已经跳过。 ' + continue peer = peer_f[0] peer.id = None peer.uid = request.user.id @@ -342,52 +351,52 @@ def share(request): title = _(title) msg = _(msg) - return render(request, 'msg.html', {'title':msg, 'msg':msg}) + return render(request, 'msg.html', {'title': msg, 'msg': msg}) else: data = request.POST.get('data', '[]') data = json.loads(data) if not data: - return JsonResponse({'code':0, 'msg':_('数据为空。')}) + return JsonResponse({'code': 0, 'msg': _('数据为空。')}) rustdesk_ids = [x['title'].split('|')[0] for x in data] rustdesk_ids = ','.join(rustdesk_ids) sharelink = ShareLink( uid=request.user.id, - shash = getStrMd5(str(time.time())+salt), + shash=getStrMd5(str(time.time()) + salt), peers=rustdesk_ids, ) sharelink.save() - return JsonResponse({'code':1, 'shash':sharelink.shash}) + return JsonResponse({'code': 1, 'shash': sharelink.shash}) def get_conn_log(): logs = ConnLog.objects.all() - logs = {x.id:model_to_dict(x) for x in logs} + logs = {x.id: model_to_dict(x) for x in logs} for k, v in logs.items(): try: peer = RustDeskPeer.objects.get(rid=v['rid']) logs[k]['alias'] = peer.alias - except: + except: # noqa logs[k]['alias'] = _('UNKNOWN') try: peer = RustDeskPeer.objects.get(rid=v['from_id']) logs[k]['from_alias'] = peer.alias - except: + except: # noqa logs[k]['from_alias'] = _('UNKNOWN') - #from_zone = tz.tzutc() - #to_zone = tz.tzlocal() - #utc = logs[k]['logged_at'] - #utc = utc.replace(tzinfo=from_zone) - #logs[k]['logged_at'] = utc.astimezone(to_zone) + # from_zone = tz.tzutc() + # to_zone = tz.tzlocal() + # utc = logs[k]['logged_at'] + # utc = utc.replace(tzinfo=from_zone) + # logs[k]['logged_at'] = utc.astimezone(to_zone) try: duration = round((logs[k]['conn_end'] - logs[k]['conn_start']).total_seconds()) m, s = divmod(duration, 60) h, m = divmod(m, 60) - #d, h = divmod(h, 24) + # d, h = divmod(h, 24) logs[k]['duration'] = f'{h:02d}:{m:02d}:{s:02d}' - except: + except: # noqa logs[k]['duration'] = -1 sorted_logs = sorted(logs.items(), key=lambda x: x[1]['conn_start'], reverse=True) @@ -397,20 +406,21 @@ def get_conn_log(): return [v for k, v in new_ordered_dict.items()] + def get_file_log(): logs = FileLog.objects.all() - logs = {x.id:model_to_dict(x) for x in logs} + logs = {x.id: model_to_dict(x) for x in logs} for k, v in logs.items(): try: peer_remote = RustDeskPeer.objects.get(rid=v['remote_id']) logs[k]['remote_alias'] = peer_remote.alias - except: + except: # noqa logs[k]['remote_alias'] = _('UNKNOWN') try: peer_user = RustDeskPeer.objects.get(rid=v['user_id']) logs[k]['user_alias'] = peer_user.alias - except: + except: # noqa logs[k]['user_alias'] = _('UNKNOWN') sorted_logs = sorted(logs.items(), key=lambda x: x[1]['logged_at'], reverse=True) @@ -420,16 +430,18 @@ def get_file_log(): return [v for k, v in new_ordered_dict.items()] + @login_required(login_url='/api/user_action?action=login') def conn_log(request): paginator = Paginator(get_conn_log(), 20) page_number = request.GET.get('page') page_obj = paginator.get_page(page_number) - return render(request, 'show_conn_log.html', {'page_obj':page_obj}) + return render(request, 'show_conn_log.html', {'page_obj': page_obj}) + @login_required(login_url='/api/user_action?action=login') def file_log(request): paginator = Paginator(get_file_log(), 20) page_number = request.GET.get('page') page_obj = paginator.get_page(page_number) - return render(request, 'show_file_log.html', {'page_obj':page_obj}) \ No newline at end of file + return render(request, 'show_file_log.html', {'page_obj': page_obj}) diff --git a/db/db.sqlite3 b/db/db.sqlite3 index 872f8abe71c0a1ea4927aac3fcdbccbe724553b8..afb6fe0444c5438fbb5e8504d213d663f8555df5 100644 GIT binary patch delta 1762 zcmc(fTWB0*6vyX$vpajs?(CY&CfUvA9uu;=`Q|>8Yh#K@*u*6CmKN(KcGtR+Y+^Po zYN^eJJP1{+`H=6Wcqw?nYjlMbTJ=G(Vg;#!pa$_lsTVW~QiKRPi3mwH)<*~CWqxzc zcg}zQ^IuqSE-X0D1$@m6!))CDTqBQ#C83##&OK!{A0htw258{d`RmRFyJ~xgyW$ux zN^%XZtB!ihH2NI{m@k=6Nw2rh#Ra&{E{k22uYJ`6P(eay70Pq#Xdb|yo3*?FY__3< z{K7qh+I{44$0fVh=09pcc9@)Z1j$*KgFNWW0>A9~fs@KOe}64KH)yu$@Q7f|b$Z?g zuFjmUqBk1jt+%8E`5gVGQ$I8h_g;ur|iBUrqWJ8Mi$@v1LiLxrmY8m;yqHaf( zf>jmcSShKk+}Ti43`NmmB_v&d1RaZ#kt`+`E5}NH`5<2=!b z>V~Xq5*ezlEM%H)8bKkacdL^P*>nTBTwNF0uC>`yG7YIoZvGR7#KX4P%}*YmJCT`BBr}QR$<(oA zv5k$`6ZcG}kI%$69TcCMIqtTSSK4%7bJyA`ycb5jukW#VbCwC$9^lMl*7)3?ulg2( zg&|``%)f*TeE`ET*p@Z3_2_=**hC4KMbF3k>`tNN8#%l zw>8BSv8#;dbN8?ABA3;9#Btf~;8v{nS~Au!yPE6uUNQwNX{TM|s0*6usd03W&8j-} z9Y)R2MB5LeN4O4y^N+M_q;ol48%Lp{o6T&sZ>0ZXr$(>sLv_%YckV|405#uq0F47E z^vppNg?c(RVn+I#mPEew5b^@rCeI6SM;y@;;g!HibOfgLsO& R(Th-@U%dl0)LvMr`3vK;uyz0d delta 2107 zcmd5-eQZ-z6z{pOef{q1=+@GGcHJi1x;^guel4)k!369k3=sSXc7-)iGPZ>c6p^?t zOZ)>3&}(uNjNm_hiwZTVMvZ@9f*ONCjfqHCihK@&qv!0201!}ieVf4<}6)B$9j>Wpw^%H##`^PHb)-WQ+AaLEMHqbCrSSbHydWlQKptHJo!yGK#0_%3lJ<`M-u>5#WCxf zz)F>DXjLOUyavLg#~Ebu6#?>vyWnhIU=MAHLB5}idRoW^b|2bML3Vfsz(x*vtH`IG zVP>kuUwpvX0!%)^k+bZ(;3Eg^C%{YMj?3KC-7b459*1ddBC~ZkOY)9j@i|u~pw%qt z@_uZDar#7H>2VoVQMC^OPyr%Op6QoGGCS&ZkSwbzz%+Rjfh>@6(&W+?Ia+zTf zizW|Q#(G@gIfIDdQ6}<_`$eOWSYPe4S*kXZRBfj@bwLm@R>+~+m>I*0qUZ`aSIf`G z1U@cFs!_yXooL2%Nt1L;(shCv(?m^{1oA?iYQ|JaoyC5x>o8-AYG5MK>P;L3Ue>XQ zRkFX{#6jStxF|`OyjOo44q{xCMTwvW$$XxmNU9bmeGS!S%osum3*>;=5A&L=tGY(c zG(!}vu9#QdMvwpS8jYfH#(vPY)q$PXlG_*`)Im6R_Wo< z?OrQ+ZLtohcxiFie`=l8U$id2!JQi9mV>QWF?f|L{`PvsWUX0-3=#Sp8KRG1*amad zsB~R~Hs=4OL#09&6u@fP4v`~Ax|zJ%PWQ^F6{53p^`zBx74}oCAl=%W_qWl(q_Me` zZb_gQnS3llkM+O_XrO&7;C-m4o|SMF>Pk0O!aji7(%w5^0HC_`;VL){P(z)>MH4YxaLh-ss-BKDKTr2lDq|8&4OMbqH%-m);4M`wQLZ)iI(@!iwRUoH>W_jU1qj6i-qZ>nItSVN_Q*?>#fEMc8WfjKr87pNr+H? z4=ki(JrH9Ipv;z@UJgg;S%cSKG-v)`xD3sBqxR5&ewgy+MuxHv(|kWP(u3WIqqqyb z0*$2$U8otrRfIvtU+ZCJEWWS2KY2ZFo9lk(8K=*2&XHgrwKXv_MlC*In5m@-olsB| zT1!+xH2`v{sG@rTB&Q=Hwgt04S5RdK{Z>NDpoP}SXcJlz bqr8F=#yHHK6lU&tyle#g4;}rNd>elUlkpw_