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.

Files changed (39) hide show
  1. fastgenerateapi/__version__.py +1 -1
  2. fastgenerateapi/api_view/base_view.py +8 -3
  3. fastgenerateapi/api_view/create_view.py +4 -0
  4. fastgenerateapi/api_view/delete_filter_view.py +7 -2
  5. fastgenerateapi/api_view/delete_tree_view.py +8 -2
  6. fastgenerateapi/api_view/delete_view.py +8 -2
  7. fastgenerateapi/api_view/get_all_view.py +8 -4
  8. fastgenerateapi/api_view/get_one_view.py +9 -3
  9. fastgenerateapi/api_view/get_relation_view.py +3 -0
  10. fastgenerateapi/api_view/get_tree_view.py +3 -0
  11. fastgenerateapi/api_view/mixin/base_mixin.py +1 -1
  12. fastgenerateapi/api_view/mixin/response_mixin.py +4 -4
  13. fastgenerateapi/api_view/switch_view.py +9 -3
  14. fastgenerateapi/api_view/update_relation_view.py +4 -0
  15. fastgenerateapi/api_view/update_view.py +4 -0
  16. fastgenerateapi/channel/connection_manager.py +30 -0
  17. fastgenerateapi/channel/consumer.py +25 -20
  18. fastgenerateapi/channel/websocket_view.py +60 -2
  19. fastgenerateapi/example/models.py +4 -4
  20. fastgenerateapi/model/base_model.py +11 -2
  21. fastgenerateapi/my_fields/enum_field.py +13 -10
  22. fastgenerateapi/schemas_factory/filter_schema_factory.py +5 -1
  23. fastgenerateapi/schemas_factory/get_all_schema_factory.py +6 -6
  24. fastgenerateapi/schemas_factory/response_factory.py +3 -3
  25. fastgenerateapi/settings/app_settings.py +14 -5
  26. fastgenerateapi/settings/db_settings.py +22 -31
  27. fastgenerateapi/settings/file_settings.py +13 -6
  28. fastgenerateapi/settings/jwt_settings.py +13 -6
  29. fastgenerateapi/settings/otlp_settings.py +14 -7
  30. fastgenerateapi/settings/redis_settings.py +13 -6
  31. fastgenerateapi/settings/sms_settings.py +13 -6
  32. fastgenerateapi/settings/system_settings.py +8 -2
  33. fastgenerateapi/utils/auto_discover.py +2 -2
  34. fastgenerateapi/utils/snowflake.py +1 -1
  35. {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/METADATA +1 -1
  36. {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/RECORD +39 -38
  37. {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/LICENSE +0 -0
  38. {fastgenerateapi-1.1.7.dist-info → fastgenerateapi-1.1.9.dist-info}/WHEEL +0 -0
  39. {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
- delete_at: Optional[datetime.datetime] = my_fields.SoftDeleteField()
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 = ["delete_at", "created_at"]
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
- delete_at: Optional[datetime.datetime] = my_fields.SoftDeleteField()
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 = ["delete_at"]
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 = ["delete_at"]
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
- 传入参数数组,默认生成枚举类,数字从 1 开始
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
- super().__init__(enum_type=self.create_enum(enum_list), **kwargs)
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 IntEnumClass(value, self.enum_list)
70
+ return value
69
71
 
70
- def get_description(self, enum_list):
72
+ @staticmethod
73
+ def get_description(enum_list, start_num=0):
71
74
  description = ""
72
- for index, val in enumerate(enum_list, 1):
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, 0)}
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("CommonFilterParams", **model_fields, __config__=model_config)
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" + str(time.time())
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" + str(time.time())
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" + str(time.time())
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
- class Config:
83
- env_prefix = "APP_"
84
- env_file = "./.env"
85
- case_sensitive = True
86
- extra = 'allow'
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
- TYPE: Optional[str] = Field(default='mysql', description="数据库类型")
13
- HOST: Optional[str] = Field(default='127.0.0.1', description="数据库域名")
14
- PORT: Optional[str] = Field(default='3306', description="数据库端口")
15
- DATABASE: Optional[str] = Field(default='admin', description="数据库名")
16
- USERNAME: Optional[str] = Field(default='root', description="数据库用户名")
17
- PASSWORD: Optional[str] = Field(default='', description="数据库密码")
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.TYPE.lower()}://{self.USERNAME}:{self.PASSWORD}@{self.HOST}:{self.PORT}/{self.DATABASE}"
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
- class Config:
24
- env_prefix = 'DB_'
25
- env_file = "./.env"
26
- case_sensitive = True
27
- extra = 'allow'
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
- MySQL Settings
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
- class Config:
16
- env_prefix = 'FileServer_'
17
- env_file = "./.env"
18
- case_sensitive = True
19
- extra = 'allow'
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
- class Config:
17
- env_prefix = 'JWT_'
18
- env_file = "./.env"
19
- case_sensitive = True
20
- extra = 'allow'
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="访问接口", example="http://127.0.0.1")
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
- class Config:
66
- env_prefix = 'OTLP_'
67
- env_file = "./.env"
68
- case_sensitive = True
69
- extra = 'allow'
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
- class Config:
13
- env_prefix = 'REDIS_'
14
- env_file = "./.env"
15
- case_sensitive = True
16
- extra = 'allow'
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
- class Config:
19
- env_prefix = 'Sms_'
20
- env_file = "./.env"
21
- case_sensitive = True
22
- extra = 'allow'
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 = 'allow'
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
 
@@ -55,7 +55,7 @@ def discover_routes(
55
55
 
56
56
 
57
57
  if __name__ == '__main__':
58
- # print(discover_models("../../modules"))
59
- print(get_path_list("../../modules", "router"))
58
+ print(discover_models("../../apps"))
59
+ # print(get_path_list("../../apps", "router"))
60
60
 
61
61
 
@@ -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
  """
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: fastgenerateapi
3
- Version: 1.1.7
3
+ Version: 1.1.9
4
4
  Summary: FastAPIView Class View
5
5
  Author: ShiLiang
6
6
  Author-email: 2509144896@qq.com