Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 19 additions & 2 deletions apps/common/utils/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
@date:2025/4/14 18:23
@desc:
"""
import datetime
import hashlib
import io
import json
Expand All @@ -17,13 +18,15 @@
import uuid
from functools import reduce
from typing import List, Dict

import pytz
from django.contrib.auth.hashers import check_password, make_password
from django.core.files.uploadedfile import InMemoryUploadedFile
from django.db.models import QuerySet
from django.utils.translation import gettext as _
from openpyxl.cell.cell import ILLEGAL_CHARACTERS_RE
from pydub import AudioSegment

from maxkb.settings import TIME_ZONE
from ..database_model_manage.database_model_manage import DatabaseModelManage
from ..exception.app_exception import AppApiException

Expand Down Expand Up @@ -168,7 +171,8 @@ def markdown_to_plain_text(md: str) -> str:
# 使用正则表达式去除所有 HTML 标签
text = re.sub(r'<[^>]+>', '', text)
# 先移除特定媒体标签(优先级高于通用HTML标签移除)
text = re.sub(r'<(?:audio|video)(?:\s+[^>]*)?>.*?(?:</(?:audio|video)>)?', '', text, flags=re.DOTALL | re.IGNORECASE)
text = re.sub(r'<(?:audio|video)(?:\s+[^>]*)?>.*?(?:</(?:audio|video)>)?', '', text,
flags=re.DOTALL | re.IGNORECASE)
text = re.sub(r'<img[^>]*>', '', text) # 匹配图片标签
# 去除多余的空白字符(包括换行符、制表符等)
text = re.sub(r'\s+', ' ', text)
Expand Down Expand Up @@ -409,6 +413,7 @@ def is_valid_uuid(uuid_string):
except ValueError:
return False


def common_convert_value(_type, value):
if value is None:
return None
Expand Down Expand Up @@ -436,3 +441,15 @@ def common_convert_value(_type, value):
return v
raise Exception(_('type error'))
return value


def reset_value(value):
if isinstance(value, str):
value = re.sub(ILLEGAL_CHARACTERS_RE, '', value)
if value.startswith(('=', '+', '-', '@')):
value = "'" + value
if isinstance(value, datetime.datetime):
eastern = pytz.timezone(TIME_ZONE)
c = datetime.timezone(eastern._utcoffset)
value = value.astimezone(c)
return value
37 changes: 37 additions & 0 deletions apps/homepage/api/home_page_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,43 @@ def get_parameters():
]


class RankingBaseExportAPI(APIMixin):

@staticmethod
def get_request():
return None

@staticmethod
def get_parameters():
return [
OpenApiParameter(
name="workspace_id",
type=OpenApiTypes.STR,
location=OpenApiParameter.PATH,
required=True,
description=_("Workspace ID"),
),
OpenApiParameter(
name="start_time",
description="start Time",
type=OpenApiTypes.STR,
required=True,
),
OpenApiParameter(
name="name",
description="Name",
type=OpenApiTypes.STR,
required=False,
),
OpenApiParameter(
name="end_time",
description="end Time",
type=OpenApiTypes.STR,
required=True,
),
]


class ApplicationTokensRankingAPI(RankingBaseAPI):

@staticmethod
Expand Down
Loading
Loading