2019-02-27 00:45:00 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
|
|
|
import re
|
2022-03-25 06:45:08 +00:00
|
|
|
|
2019-02-27 00:45:00 +00:00
|
|
|
from django.conf import settings
|
2022-03-25 06:45:08 +00:00
|
|
|
from django.db import models
|
|
|
|
from django.db.models.signals import post_save, pre_save
|
2022-11-29 06:42:04 +00:00
|
|
|
from django.shortcuts import reverse as dj_reverse
|
|
|
|
from django.utils import timezone
|
2019-02-27 00:45:00 +00:00
|
|
|
|
|
|
|
UUID_PATTERN = re.compile(r'[0-9a-zA-Z\-]{36}')
|
|
|
|
|
|
|
|
|
2022-07-18 11:24:17 +00:00
|
|
|
def reverse(
|
|
|
|
view_name, urlconf=None, args=None, kwargs=None,
|
|
|
|
current_app=None, external=False, api_to_ui=False,
|
|
|
|
is_console=False, is_audit=False, is_workbench=False
|
|
|
|
):
|
2019-02-27 00:45:00 +00:00
|
|
|
url = dj_reverse(view_name, urlconf=urlconf, args=args,
|
|
|
|
kwargs=kwargs, current_app=current_app)
|
|
|
|
|
|
|
|
if external:
|
|
|
|
site_url = settings.SITE_URL
|
|
|
|
url = site_url.strip('/') + url
|
2020-10-27 03:35:31 +00:00
|
|
|
if api_to_ui:
|
2022-07-18 11:24:17 +00:00
|
|
|
replace_str = 'ui/#'
|
|
|
|
if is_console:
|
|
|
|
replace_str += '/console'
|
|
|
|
elif is_audit:
|
|
|
|
replace_str += '/audit'
|
|
|
|
elif is_workbench:
|
|
|
|
replace_str += '/workbench'
|
|
|
|
|
|
|
|
url = url.replace('api/v1', replace_str).rstrip('/')
|
2019-02-27 00:45:00 +00:00
|
|
|
return url
|
|
|
|
|
|
|
|
|
|
|
|
def get_object_or_none(model, **kwargs):
|
|
|
|
try:
|
|
|
|
obj = model.objects.get(**kwargs)
|
|
|
|
except model.DoesNotExist:
|
|
|
|
return None
|
|
|
|
return obj
|
|
|
|
|
|
|
|
|
|
|
|
def date_expired_default():
|
|
|
|
try:
|
|
|
|
years = int(settings.DEFAULT_EXPIRED_YEARS)
|
|
|
|
except TypeError:
|
|
|
|
years = 70
|
2022-07-18 11:24:17 +00:00
|
|
|
return timezone.now() + timezone.timedelta(days=365 * years)
|
2019-02-27 00:45:00 +00:00
|
|
|
|
2020-02-05 07:56:28 +00:00
|
|
|
|
|
|
|
def union_queryset(*args, base_queryset=None):
|
|
|
|
if len(args) == 1:
|
|
|
|
return args[0]
|
|
|
|
elif len(args) == 0:
|
|
|
|
raise ValueError("args is empty")
|
|
|
|
args = [q.order_by() for q in args]
|
|
|
|
sub_query = args[0].union(*args[1:])
|
|
|
|
queryset_id = list(sub_query.values_list('id', flat=True))
|
|
|
|
if not base_queryset:
|
|
|
|
base_queryset = args[0].model.objects
|
|
|
|
queryset = base_queryset.filter(id__in=queryset_id)
|
|
|
|
return queryset
|
2020-10-26 06:13:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
def get_log_keep_day(s, defaults=200):
|
|
|
|
try:
|
|
|
|
days = int(getattr(settings, s))
|
|
|
|
except ValueError:
|
|
|
|
days = defaults
|
|
|
|
return days
|
2022-03-25 06:45:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
def bulk_create_with_signal(cls: models.Model, items, **kwargs):
|
|
|
|
for i in items:
|
|
|
|
pre_save.send(sender=cls, instance=i)
|
|
|
|
result = cls.objects.bulk_create(items, **kwargs)
|
|
|
|
for i in items:
|
|
|
|
post_save.send(sender=cls, instance=i, created=True)
|
|
|
|
return result
|
2022-11-29 06:42:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
def get_request_os(request):
|
|
|
|
"""获取请求的操作系统"""
|
|
|
|
agent = request.META.get('HTTP_USER_AGENT', '').lower()
|
|
|
|
|
|
|
|
if agent is None:
|
|
|
|
return 'unknown'
|
|
|
|
if 'windows' in agent.lower():
|
|
|
|
return 'windows'
|
|
|
|
if 'mac' in agent.lower():
|
|
|
|
return 'mac'
|
|
|
|
if 'linux' in agent.lower():
|
|
|
|
return 'linux'
|
|
|
|
return 'unknown'
|