fastgenerateapi 1.1.7__py2.py3-none-any.whl → 1.1.9__py2.py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of fastgenerateapi might be problematic. Click here for more details.
- fastgenerateapi/__version__.py +1 -1
- fastgenerateapi/api_view/base_view.py +8 -3
- fastgenerateapi/api_view/create_view.py +4 -0
- fastgenerateapi/api_view/delete_filter_view.py +7 -2
- fastgenerateapi/api_view/delete_tree_view.py +8 -2
- fastgenerateapi/api_view/delete_view.py +8 -2
- fastgenerateapi/api_view/get_all_view.py +8 -4
- fastgenerateapi/api_view/get_one_view.py +9 -3
- fastgenerateapi/api_view/get_relation_view.py +3 -0
- fastgenerateapi/api_view/get_tree_view.py +3 -0
- fastgenerateapi/api_view/mixin/base_mixin.py +1 -1
- fastgenerateapi/api_view/mixin/response_mixin.py +4 -4
- fastgenerateapi/api_view/switch_view.py +9 -3
- fastgenerateapi/api_view/update_relation_view.py +4 -0
- fastgenerateapi/api_view/update_view.py +4 -0
- fastgenerateapi/channel/connection_manager.py +30 -0
- fastgenerateapi/channel/consumer.py +25 -20
- fastgenerateapi/channel/websocket_view.py +60 -2
- fastgenerateapi/example/models.py +4 -4
- fastgenerateapi/model/base_model.py +11 -2
- fastgenerateapi/my_fields/enum_field.py +13 -10
- fastgenerateapi/schemas_factory/filter_schema_factory.py +5 -1
- fastgenerateapi/schemas_factory/get_all_schema_factory.py +6 -6
- fastgenerateapi/schemas_factory/response_factory.py +3 -3
- fastgenerateapi/settings/app_settings.py +14 -5
- fastgenerateapi/settings/db_settings.py +22 -31
- fastgenerateapi/settings/file_settings.py +13 -6
- fastgenerateapi/settings/jwt_settings.py +13 -6
- fastgenerateapi/settings/otlp_settings.py +14 -7
- fastgenerateapi/settings/redis_settings.py +13 -6
- fastgenerateapi/settings/sms_settings.py +13 -6
- fastgenerateapi/settings/system_settings.py +8 -2
- fastgenerateapi/utils/auto_discover.py +2 -2
- fastgenerateapi/utils/snowflake.py +1 -1
- {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/METADATA +1 -1
- {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/RECORD +39 -38
- {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/LICENSE +0 -0
- {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/WHEEL +0 -0
- {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/top_level.txt +0 -0
|
@@ -13,7 +13,7 @@ class StaffInfo(Model):
|
|
|
13
13
|
"""
|
|
14
14
|
员工信息
|
|
15
15
|
"""
|
|
16
|
-
|
|
16
|
+
deleted_at: Optional[datetime.datetime] = my_fields.SoftDeleteField()
|
|
17
17
|
created_at: Optional[datetime.datetime] = fields.DatetimeField(null=True, auto_now_add=True, description="创建时间")
|
|
18
18
|
category: Optional[IntEnumClass] = my_fields.IntEnumField(enum_list=["总经理", '主管', '员工'], description="职位分类")
|
|
19
19
|
name: Optional[str] = fields.CharField(description="名字", max_length=255)
|
|
@@ -31,7 +31,7 @@ class StaffInfo(Model):
|
|
|
31
31
|
|
|
32
32
|
class PydanticMeta:
|
|
33
33
|
# 以下内容仅用于演示,存在重复和多余写法
|
|
34
|
-
exclude = ["
|
|
34
|
+
exclude = ["deleted_at", "created_at"]
|
|
35
35
|
get_include = ["category_name", "name"]
|
|
36
36
|
get_all_include = ["company__name"]
|
|
37
37
|
get_one_include = [("test", Optional[str], FieldInfo(default="", description="测试字段")), ]
|
|
@@ -42,7 +42,7 @@ class CompanyInfo(Model):
|
|
|
42
42
|
"""
|
|
43
43
|
公司信息
|
|
44
44
|
"""
|
|
45
|
-
|
|
45
|
+
deleted_at: Optional[datetime.datetime] = my_fields.SoftDeleteField()
|
|
46
46
|
name: str = fields.CharField(description="岗位名称", max_length=255)
|
|
47
47
|
boss_name: str = fields.CharField(description="老板名字", max_length=255)
|
|
48
48
|
parent: fields.ForeignKeyNullableRelation["CompanyInfo"] = fields.ForeignKeyField(
|
|
@@ -53,7 +53,7 @@ class CompanyInfo(Model):
|
|
|
53
53
|
description='父级')
|
|
54
54
|
|
|
55
55
|
class PydanticMeta:
|
|
56
|
-
exclude = ["
|
|
56
|
+
exclude = ["deleted_at"]
|
|
57
57
|
|
|
58
58
|
|
|
59
59
|
|
|
@@ -45,12 +45,21 @@ class BaseActiveMixin(models.Model):
|
|
|
45
45
|
class Meta:
|
|
46
46
|
abstract = True
|
|
47
47
|
|
|
48
|
-
|
|
49
48
|
class TortoiseOrmAbstractModel(PrimaryKeyMixin, TimestampMixin, BaseDeleteMixin):
|
|
50
49
|
...
|
|
51
50
|
|
|
52
51
|
class PydanticMeta:
|
|
53
|
-
exclude = ["
|
|
52
|
+
exclude = ["deleted_at"]
|
|
53
|
+
|
|
54
|
+
class Meta:
|
|
55
|
+
abstract = True
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
class TortoiseOrmAbstractBaseModel(PrimaryKeyMixin, TimestampMixin, BaseActiveMixin):
|
|
59
|
+
...
|
|
60
|
+
|
|
61
|
+
class PydanticMeta:
|
|
62
|
+
exclude = ["is_active"]
|
|
54
63
|
|
|
55
64
|
class Meta:
|
|
56
65
|
abstract = True
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
from enum import IntEnum
|
|
1
|
+
from enum import IntEnum, Enum
|
|
2
2
|
from typing import (
|
|
3
3
|
TYPE_CHECKING,
|
|
4
4
|
Any,
|
|
@@ -23,7 +23,8 @@ if TYPE_CHECKING: # pragma: nocoverage
|
|
|
23
23
|
|
|
24
24
|
class IntEnumField(IntEnumFieldInstance):
|
|
25
25
|
"""
|
|
26
|
-
传入参数数组,默认生成枚举类,数字从
|
|
26
|
+
传入参数数组,默认生成枚举类,数字从 0 开始
|
|
27
|
+
可以通过 start_num=1 设置从1开始
|
|
27
28
|
例如:
|
|
28
29
|
enum_list = ["A", "B"]
|
|
29
30
|
相当于枚举
|
|
@@ -33,10 +34,11 @@ class IntEnumField(IntEnumFieldInstance):
|
|
|
33
34
|
通过方法 get_name 获取对应的值, "A"
|
|
34
35
|
"""
|
|
35
36
|
|
|
36
|
-
def __init__(self, enum_list: List[any], **kwargs: Any) -> None:
|
|
37
|
+
def __init__(self, enum_list: List[any], start_num=0, **kwargs: Any) -> None:
|
|
37
38
|
self.enum_list = enum_list
|
|
38
|
-
self.description = kwargs.get("description", "") + " >> " + self.get_description(enum_list)
|
|
39
|
-
|
|
39
|
+
self.description = kwargs.get("description", "") + " >> " + self.get_description(enum_list, start_num)
|
|
40
|
+
kwargs["description"] = self.description
|
|
41
|
+
super().__init__(enum_type=self.create_enum(enum_list, start_num=start_num), **kwargs)
|
|
40
42
|
|
|
41
43
|
@property
|
|
42
44
|
def constraints(self) -> dict:
|
|
@@ -65,18 +67,19 @@ class IntEnumField(IntEnumFieldInstance):
|
|
|
65
67
|
if value is not None:
|
|
66
68
|
value = int(value) # pylint: disable=E1102
|
|
67
69
|
self.validate(value)
|
|
68
|
-
return
|
|
70
|
+
return value
|
|
69
71
|
|
|
70
|
-
|
|
72
|
+
@staticmethod
|
|
73
|
+
def get_description(enum_list, start_num=0):
|
|
71
74
|
description = ""
|
|
72
|
-
for index, val in enumerate(enum_list,
|
|
75
|
+
for index, val in enumerate(enum_list, start_num):
|
|
73
76
|
description += f"{index}:{val};"
|
|
74
77
|
return description
|
|
75
78
|
|
|
76
|
-
def create_enum(self, enum_list):
|
|
79
|
+
def create_enum(self, enum_list, start_num=0) -> Type[IntEnum]:
|
|
77
80
|
# 创建枚举类的成员字典,确保值是唯一的
|
|
78
81
|
|
|
79
|
-
members = {self.number_to_words(name): name for name, _ in enumerate(enum_list,
|
|
82
|
+
members = {self.number_to_words(name): name for name, _ in enumerate(enum_list, start_num)}
|
|
80
83
|
|
|
81
84
|
# 使用Enum的元类EnumMeta来动态创建枚举类
|
|
82
85
|
enum_class = IntEnum("CategoryEnum", members)
|
|
@@ -32,7 +32,11 @@ def filter_schema_factory(model_class: Type[Model], fields: list[str, tuple[str,
|
|
|
32
32
|
))
|
|
33
33
|
})
|
|
34
34
|
|
|
35
|
-
filter_params_model: Type[BaseModel] = create_model(
|
|
35
|
+
filter_params_model: Type[BaseModel] = create_model(
|
|
36
|
+
model_class.__name__+"CommonFilterParams",
|
|
37
|
+
**model_fields,
|
|
38
|
+
__config__=model_config
|
|
39
|
+
)
|
|
36
40
|
|
|
37
41
|
return filter_params_model
|
|
38
42
|
|
|
@@ -81,22 +81,22 @@ def get_all_schema_factory(
|
|
|
81
81
|
return schema
|
|
82
82
|
|
|
83
83
|
|
|
84
|
-
def get_list_schema_factory(schema_cls: Type[T] = None) -> Type[T]:
|
|
84
|
+
def get_list_schema_factory(schema_cls: Type[T] = None, name: str = "") -> Type[T]:
|
|
85
85
|
if schema_cls:
|
|
86
86
|
fields = {
|
|
87
87
|
settings.app_settings.LIST_RESPONSE_FIELD: (Optional[List[schema_cls]], FieldInfo(default=[], description="数据返回")),
|
|
88
88
|
}
|
|
89
|
-
name = schema_cls.__name__ + "GetListSchema"
|
|
89
|
+
name = schema_cls.__name__ + name + "GetListSchema"
|
|
90
90
|
else:
|
|
91
91
|
fields = {
|
|
92
92
|
settings.app_settings.LIST_RESPONSE_FIELD: (Optional[List], FieldInfo(default=[], description="数据返回")),
|
|
93
93
|
}
|
|
94
|
-
name = "GetListSchema"
|
|
94
|
+
name = name + "GetListSchema"
|
|
95
95
|
schema: Type[T] = create_model(name, **fields, __config__=model_config)
|
|
96
96
|
return schema
|
|
97
97
|
|
|
98
98
|
|
|
99
|
-
def get_page_schema_factory(schema_cls: Type[T] = None) -> Type[T]:
|
|
99
|
+
def get_page_schema_factory(schema_cls: Type[T] = None, name: str = "") -> Type[T]:
|
|
100
100
|
fields = {
|
|
101
101
|
settings.app_settings.CURRENT_PAGE_FIELD: (Optional[int], FieldInfo(default=1, description="当前页")),
|
|
102
102
|
settings.app_settings.PAGE_SIZE_FIELD: (Optional[int], FieldInfo(default=settings.app_settings.DEFAULT_PAGE_SIZE, description="每页数量")),
|
|
@@ -104,10 +104,10 @@ def get_page_schema_factory(schema_cls: Type[T] = None) -> Type[T]:
|
|
|
104
104
|
}
|
|
105
105
|
if schema_cls:
|
|
106
106
|
fields.update({settings.app_settings.LIST_RESPONSE_FIELD: (Optional[List[schema_cls]], FieldInfo(default=[], description="数据返回"))})
|
|
107
|
-
name = schema_cls.__name__ + "GetPageSchema"
|
|
107
|
+
name = schema_cls.__name__ + name + "GetPageSchema"
|
|
108
108
|
else:
|
|
109
109
|
fields.update({settings.app_settings.LIST_RESPONSE_FIELD: (Optional[List], FieldInfo(default=[], description="数据返回"))})
|
|
110
|
-
name = "GetPageSchema"
|
|
110
|
+
name = name + "GetPageSchema"
|
|
111
111
|
schema: Type[T] = create_model(name, **fields, __config__=model_config)
|
|
112
112
|
return schema
|
|
113
113
|
|
|
@@ -29,13 +29,13 @@ def response_factory(schema_cls: Union[Type[T], BaseModel, None] = None, name: s
|
|
|
29
29
|
else:
|
|
30
30
|
fields.setdefault(
|
|
31
31
|
settings.app_settings.DATA_RESPONSE_FIELD,
|
|
32
|
-
(Union[dict, str, None], FieldInfo(default={}, description="数据内容"))
|
|
32
|
+
(Union[dict, list, str, None], FieldInfo(default={}, description="数据内容"))
|
|
33
33
|
)
|
|
34
34
|
|
|
35
35
|
try:
|
|
36
|
-
name = schema_cls.__name__ + name + "Response"
|
|
36
|
+
name = schema_cls.__name__ + name + "Response"
|
|
37
37
|
except:
|
|
38
|
-
name = "CommonResponse"
|
|
38
|
+
name = name + "CommonResponse"
|
|
39
39
|
schema: Type[T] = create_model(name, **fields, __config__=model_config)
|
|
40
40
|
|
|
41
41
|
return schema
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
from typing import Optional
|
|
2
2
|
|
|
3
3
|
from pydantic import Field
|
|
4
|
+
from pydantic_settings import SettingsConfigDict
|
|
5
|
+
|
|
4
6
|
from fastgenerateapi.pydantic_utils.base_settings import BaseSettings
|
|
5
7
|
|
|
6
8
|
|
|
@@ -79,11 +81,18 @@ class AppSettings(BaseSettings):
|
|
|
79
81
|
FILTER_UNDERLINE_WHETHER_DOUBLE_TO_SINGLE: Optional[bool] = Field(default=True, description="筛选是否双下划线转单下划线")
|
|
80
82
|
SCHEMAS_UNDERLINE_WHETHER_DOUBLE_TO_SINGLE: Optional[bool] = Field(default=True, description="序列化字段是否双下划线转单下划线")
|
|
81
83
|
|
|
82
|
-
|
|
83
|
-
env_prefix
|
|
84
|
-
env_file
|
|
85
|
-
case_sensitive
|
|
86
|
-
extra
|
|
84
|
+
model_config = SettingsConfigDict(
|
|
85
|
+
env_prefix="APP_",
|
|
86
|
+
env_file=".env",
|
|
87
|
+
case_sensitive=True,
|
|
88
|
+
extra='ignore'
|
|
89
|
+
)
|
|
90
|
+
|
|
91
|
+
# class Config:
|
|
92
|
+
# env_prefix = "APP_"
|
|
93
|
+
# env_file = "./.env"
|
|
94
|
+
# case_sensitive = True
|
|
95
|
+
# extra = 'allow'
|
|
87
96
|
|
|
88
97
|
|
|
89
98
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
from typing import Optional
|
|
2
2
|
|
|
3
3
|
from pydantic import Field
|
|
4
|
-
from pydantic_settings import BaseSettings
|
|
4
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
class DBSettings(BaseSettings):
|
|
@@ -9,22 +9,29 @@ class DBSettings(BaseSettings):
|
|
|
9
9
|
Database Settings
|
|
10
10
|
"""
|
|
11
11
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
12
|
+
DB_TYPE: Optional[str] = Field(default='mysql', description="数据库类型")
|
|
13
|
+
DB_HOST: Optional[str] = Field(default='127.0.0.1', description="数据库域名")
|
|
14
|
+
DB_PORT: Optional[str] = Field(default='3306', description="数据库端口")
|
|
15
|
+
DB_DATABASE: Optional[str] = Field(default='admin', description="数据库名")
|
|
16
|
+
DB_USERNAME: Optional[str] = Field(default='root', description="数据库用户名")
|
|
17
|
+
DB_PASSWORD: Optional[str] = Field(default='', description="数据库密码")
|
|
18
18
|
|
|
19
19
|
@property
|
|
20
20
|
def dsn(self):
|
|
21
|
-
return f"{self.
|
|
21
|
+
return f"{self.DB_TYPE.lower()}://{self.DB_USERNAME}:{self.DB_PASSWORD}@{self.DB_HOST}:{self.DB_PORT}/{self.DB_DATABASE}"
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
env_prefix
|
|
25
|
-
env_file
|
|
26
|
-
case_sensitive
|
|
27
|
-
extra
|
|
23
|
+
model_config = SettingsConfigDict(
|
|
24
|
+
env_prefix="",
|
|
25
|
+
env_file=".env",
|
|
26
|
+
case_sensitive=True,
|
|
27
|
+
extra='ignore'
|
|
28
|
+
)
|
|
29
|
+
|
|
30
|
+
# class Config:
|
|
31
|
+
# env_prefix = ''
|
|
32
|
+
# env_file = "./.env"
|
|
33
|
+
# case_sensitive = True
|
|
34
|
+
# extra = 'allow'
|
|
28
35
|
|
|
29
36
|
|
|
30
37
|
class PostgresqlSettings(DBSettings):
|
|
@@ -33,36 +40,20 @@ class PostgresqlSettings(DBSettings):
|
|
|
33
40
|
"""
|
|
34
41
|
TYPE: Optional[str] = Field(default='postgres', description="数据库类型")
|
|
35
42
|
|
|
36
|
-
class Config:
|
|
37
|
-
env_prefix = 'Postgresql_'
|
|
38
|
-
env_file = "./.env"
|
|
39
|
-
case_sensitive = True
|
|
40
|
-
extra = 'allow'
|
|
41
|
-
|
|
42
43
|
|
|
43
44
|
class MySQLSettings(DBSettings):
|
|
44
45
|
"""
|
|
45
46
|
MySQL Settings
|
|
46
47
|
"""
|
|
47
|
-
|
|
48
|
-
class Config:
|
|
49
|
-
env_prefix = 'MYSQL_'
|
|
50
|
-
env_file = "./.env"
|
|
51
|
-
case_sensitive = True
|
|
52
|
-
extra = 'allow'
|
|
48
|
+
...
|
|
53
49
|
|
|
54
50
|
|
|
55
51
|
class LocalSettings(DBSettings):
|
|
56
52
|
"""
|
|
57
|
-
|
|
53
|
+
Local Settings
|
|
58
54
|
"""
|
|
59
55
|
TYPE: str = Field(..., description="数据库类型")
|
|
60
56
|
|
|
61
|
-
class Config:
|
|
62
|
-
env_prefix = 'LOCAL_'
|
|
63
|
-
env_file = "./.env"
|
|
64
|
-
case_sensitive = True
|
|
65
|
-
extra = 'allow'
|
|
66
57
|
|
|
67
58
|
|
|
68
59
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
from typing import Optional
|
|
2
2
|
|
|
3
3
|
from pydantic import Field
|
|
4
|
-
from pydantic_settings import BaseSettings
|
|
4
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
class FileServerSettings(BaseSettings):
|
|
@@ -12,11 +12,18 @@ class FileServerSettings(BaseSettings):
|
|
|
12
12
|
FILE_URL: Optional[str] = Field(default='/static/', description="文件路径前缀", title="file url prefix")
|
|
13
13
|
FILE_ROOT: Optional[str] = Field(default='static', description="文件储存路径", title="file storage path")
|
|
14
14
|
|
|
15
|
-
|
|
16
|
-
env_prefix
|
|
17
|
-
env_file
|
|
18
|
-
case_sensitive
|
|
19
|
-
extra
|
|
15
|
+
model_config = SettingsConfigDict(
|
|
16
|
+
env_prefix="FILESERVER_",
|
|
17
|
+
env_file=".env",
|
|
18
|
+
case_sensitive=True,
|
|
19
|
+
extra='ignore'
|
|
20
|
+
)
|
|
21
|
+
|
|
22
|
+
# class Config:
|
|
23
|
+
# env_prefix = 'FILESERVER_'
|
|
24
|
+
# env_file = "./.env"
|
|
25
|
+
# case_sensitive = True
|
|
26
|
+
# extra = 'allow'
|
|
20
27
|
|
|
21
28
|
|
|
22
29
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
from typing import Optional
|
|
2
2
|
|
|
3
3
|
from pydantic import Field
|
|
4
|
-
from pydantic_settings import BaseSettings
|
|
4
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
class JWTSettings(BaseSettings):
|
|
@@ -13,11 +13,18 @@ class JWTSettings(BaseSettings):
|
|
|
13
13
|
ACCESS_TOKEN_EXPIRE_MINUTES: Optional[int] = Field(default=30, description="过期时间 (分钟)", title="JWT Access Token")
|
|
14
14
|
REFRESH_TOKEN_EXPIRE_MINUTES: Optional[int] = Field(default=60, description="过期时间(分钟)", title="JWT Refresh Token")
|
|
15
15
|
|
|
16
|
-
|
|
17
|
-
env_prefix
|
|
18
|
-
env_file
|
|
19
|
-
case_sensitive
|
|
20
|
-
extra
|
|
16
|
+
model_config = SettingsConfigDict(
|
|
17
|
+
env_prefix="JWT_",
|
|
18
|
+
env_file=".env",
|
|
19
|
+
case_sensitive=True,
|
|
20
|
+
extra='ignore'
|
|
21
|
+
)
|
|
22
|
+
|
|
23
|
+
# class Config:
|
|
24
|
+
# env_prefix = 'JWT_'
|
|
25
|
+
# env_file = "./.env"
|
|
26
|
+
# case_sensitive = True
|
|
27
|
+
# extra = 'allow'
|
|
21
28
|
|
|
22
29
|
|
|
23
30
|
|
|
@@ -15,14 +15,14 @@ from opentelemetry.sdk.trace import TracerProvider
|
|
|
15
15
|
from opentelemetry.sdk.trace.export import BatchSpanProcessor
|
|
16
16
|
|
|
17
17
|
from pydantic import Field
|
|
18
|
-
from pydantic_settings import BaseSettings
|
|
18
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
|
19
19
|
|
|
20
20
|
|
|
21
21
|
class OpenTelemetrySettings(BaseSettings):
|
|
22
22
|
"""
|
|
23
23
|
跟踪和指标配置
|
|
24
24
|
"""
|
|
25
|
-
ENDPOINT: Optional[str] = Field(default=None, description="访问接口",
|
|
25
|
+
ENDPOINT: Optional[str] = Field(default=None, description="访问接口", examples=["http://127.0.0.1"])
|
|
26
26
|
AUTHORIZATION: Optional[str] = Field(default=None, description="认证字符串")
|
|
27
27
|
|
|
28
28
|
def setup_open_telemetry(self, app: FastAPI, service_name: str):
|
|
@@ -62,8 +62,15 @@ class OpenTelemetrySettings(BaseSettings):
|
|
|
62
62
|
TortoiseORMInstrumentor().instrument(tracer_provider=tracer_provider)
|
|
63
63
|
HTTPXClientInstrumentor().instrument(tracer_provider=tracer_provider)
|
|
64
64
|
|
|
65
|
-
|
|
66
|
-
env_prefix
|
|
67
|
-
env_file
|
|
68
|
-
case_sensitive
|
|
69
|
-
extra
|
|
65
|
+
model_config = SettingsConfigDict(
|
|
66
|
+
env_prefix="OTLP_",
|
|
67
|
+
env_file=".env",
|
|
68
|
+
case_sensitive=True,
|
|
69
|
+
extra='ignore'
|
|
70
|
+
)
|
|
71
|
+
|
|
72
|
+
# class Config:
|
|
73
|
+
# env_prefix = 'OTLP_'
|
|
74
|
+
# env_file = "./.env"
|
|
75
|
+
# case_sensitive = True
|
|
76
|
+
# extra = 'allow'
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
from typing import Optional
|
|
2
2
|
|
|
3
3
|
from pydantic import Field
|
|
4
|
-
from pydantic_settings import BaseSettings
|
|
4
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
class RedisSettings(BaseSettings):
|
|
@@ -9,8 +9,15 @@ class RedisSettings(BaseSettings):
|
|
|
9
9
|
PORT: Optional[int] = Field(default=6379, description="映射端口")
|
|
10
10
|
PASSWORD: Optional[str] = Field(default="", description="密码")
|
|
11
11
|
|
|
12
|
-
|
|
13
|
-
env_prefix
|
|
14
|
-
env_file
|
|
15
|
-
case_sensitive
|
|
16
|
-
extra
|
|
12
|
+
model_config = SettingsConfigDict(
|
|
13
|
+
env_prefix="REDIS_",
|
|
14
|
+
env_file=".env",
|
|
15
|
+
case_sensitive=True,
|
|
16
|
+
extra='ignore'
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
# class Config:
|
|
20
|
+
# env_prefix = 'REDIS_'
|
|
21
|
+
# env_file = "./.env"
|
|
22
|
+
# case_sensitive = True
|
|
23
|
+
# extra = 'allow'
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
from typing import Optional
|
|
2
2
|
|
|
3
3
|
from pydantic import Field
|
|
4
|
-
from pydantic_settings import BaseSettings
|
|
4
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
class SmsSettings(BaseSettings):
|
|
@@ -15,11 +15,18 @@ class SmsSettings(BaseSettings):
|
|
|
15
15
|
CHECK_CODE_RESEND_TIME: Optional[int] = Field(default=1, description="验证码重新发送时间", title="check code resend time (minute)")
|
|
16
16
|
DEFAULT_CODE: Optional[int] = Field(default="654123", description="默认验证码", title="sms default code")
|
|
17
17
|
|
|
18
|
-
|
|
19
|
-
env_prefix
|
|
20
|
-
env_file
|
|
21
|
-
case_sensitive
|
|
22
|
-
extra
|
|
18
|
+
model_config = SettingsConfigDict(
|
|
19
|
+
env_prefix="SMS_",
|
|
20
|
+
env_file=".env",
|
|
21
|
+
case_sensitive=True,
|
|
22
|
+
extra='ignore'
|
|
23
|
+
)
|
|
24
|
+
|
|
25
|
+
# class Config:
|
|
26
|
+
# env_prefix = 'SMS_'
|
|
27
|
+
# env_file = "./.env"
|
|
28
|
+
# case_sensitive = True
|
|
29
|
+
# extra = 'allow'
|
|
23
30
|
|
|
24
31
|
|
|
25
32
|
|
|
@@ -22,9 +22,15 @@ class SystemSettings(BaseSettings):
|
|
|
22
22
|
DATACENTER_ID: Optional[int] = Field(default='1', description="机器ID")
|
|
23
23
|
|
|
24
24
|
class Config:
|
|
25
|
-
env_prefix = ''
|
|
25
|
+
env_prefix = 'SYSTEM_'
|
|
26
26
|
env_file = "./.env"
|
|
27
27
|
case_sensitive = True
|
|
28
|
-
extra = '
|
|
28
|
+
extra = 'ignore'
|
|
29
|
+
|
|
30
|
+
# class Config:
|
|
31
|
+
# env_prefix = 'SYSTEM_'
|
|
32
|
+
# env_file = "./.env"
|
|
33
|
+
# case_sensitive = True
|
|
34
|
+
# extra = 'allow'
|
|
29
35
|
|
|
30
36
|
|
|
@@ -125,7 +125,7 @@ class IdWorker(object):
|
|
|
125
125
|
|
|
126
126
|
new_id = ((timestamp - TWEPOCH) << TIMESTAMP_LEFT_SHIFT) | (self.datacenter_id << DATACENTER_ID_SHIFT) | \
|
|
127
127
|
(self.worker_id << WOKER_ID_SHIFT) | self.sequence
|
|
128
|
-
return new_id
|
|
128
|
+
return str(new_id)
|
|
129
129
|
|
|
130
130
|
def _til_next_millis(self, last_timestamp):
|
|
131
131
|
"""
|