Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

common_service.py 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. #
  2. # Copyright 2024 The InfiniFlow Authors. All Rights Reserved.
  3. #
  4. # Licensed under the Apache License, Version 2.0 (the "License");
  5. # you may not use this file except in compliance with the License.
  6. # You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. #
  16. from datetime import datetime
  17. import peewee
  18. from api.db.db_models import DB
  19. from api.utils import datetime_format, current_timestamp, get_uuid
  20. class CommonService:
  21. model = None
  22. @classmethod
  23. @DB.connection_context()
  24. def query(cls, cols=None, reverse=None, order_by=None, **kwargs):
  25. return cls.model.query(cols=cols, reverse=reverse,
  26. order_by=order_by, **kwargs)
  27. @classmethod
  28. @DB.connection_context()
  29. def get_all(cls, cols=None, reverse=None, order_by=None):
  30. if cols:
  31. query_records = cls.model.select(*cols)
  32. else:
  33. query_records = cls.model.select()
  34. if reverse is not None:
  35. if not order_by or not hasattr(cls, order_by):
  36. order_by = "create_time"
  37. if reverse is True:
  38. query_records = query_records.order_by(
  39. cls.model.getter_by(order_by).desc())
  40. elif reverse is False:
  41. query_records = query_records.order_by(
  42. cls.model.getter_by(order_by).asc())
  43. return query_records
  44. @classmethod
  45. @DB.connection_context()
  46. def get(cls, **kwargs):
  47. return cls.model.get(**kwargs)
  48. @classmethod
  49. @DB.connection_context()
  50. def get_or_none(cls, **kwargs):
  51. try:
  52. return cls.model.get(**kwargs)
  53. except peewee.DoesNotExist:
  54. return None
  55. @classmethod
  56. @DB.connection_context()
  57. def save(cls, **kwargs):
  58. # if "id" not in kwargs:
  59. # kwargs["id"] = get_uuid()
  60. sample_obj = cls.model(**kwargs).save(force_insert=True)
  61. return sample_obj
  62. @classmethod
  63. @DB.connection_context()
  64. def insert(cls, **kwargs):
  65. if "id" not in kwargs:
  66. kwargs["id"] = get_uuid()
  67. kwargs["create_time"] = current_timestamp()
  68. kwargs["create_date"] = datetime_format(datetime.now())
  69. kwargs["update_time"] = current_timestamp()
  70. kwargs["update_date"] = datetime_format(datetime.now())
  71. sample_obj = cls.model(**kwargs).save(force_insert=True)
  72. return sample_obj
  73. @classmethod
  74. @DB.connection_context()
  75. def insert_many(cls, data_list, batch_size=100):
  76. with DB.atomic():
  77. for d in data_list:
  78. d["create_time"] = current_timestamp()
  79. d["create_date"] = datetime_format(datetime.now())
  80. for i in range(0, len(data_list), batch_size):
  81. cls.model.insert_many(data_list[i:i + batch_size]).execute()
  82. @classmethod
  83. @DB.connection_context()
  84. def update_many_by_id(cls, data_list):
  85. with DB.atomic():
  86. for data in data_list:
  87. data["update_time"] = current_timestamp()
  88. data["update_date"] = datetime_format(datetime.now())
  89. cls.model.update(data).where(
  90. cls.model.id == data["id"]).execute()
  91. @classmethod
  92. @DB.connection_context()
  93. def update_by_id(cls, pid, data):
  94. data["update_time"] = current_timestamp()
  95. data["update_date"] = datetime_format(datetime.now())
  96. num = cls.model.update(data).where(cls.model.id == pid).execute()
  97. return num
  98. @classmethod
  99. @DB.connection_context()
  100. def get_by_id(cls, pid):
  101. try:
  102. obj = cls.model.query(id=pid)[0]
  103. return True, obj
  104. except Exception:
  105. return False, None
  106. @classmethod
  107. @DB.connection_context()
  108. def get_by_ids(cls, pids, cols=None):
  109. if cols:
  110. objs = cls.model.select(*cols)
  111. else:
  112. objs = cls.model.select()
  113. return objs.where(cls.model.id.in_(pids))
  114. @classmethod
  115. @DB.connection_context()
  116. def delete_by_id(cls, pid):
  117. return cls.model.delete().where(cls.model.id == pid).execute()
  118. @classmethod
  119. @DB.connection_context()
  120. def filter_delete(cls, filters):
  121. with DB.atomic():
  122. num = cls.model.delete().where(*filters).execute()
  123. return num
  124. @classmethod
  125. @DB.connection_context()
  126. def filter_update(cls, filters, update_data):
  127. with DB.atomic():
  128. return cls.model.update(update_data).where(*filters).execute()
  129. @staticmethod
  130. def cut_list(tar_list, n):
  131. length = len(tar_list)
  132. arr = range(length)
  133. result = [tuple(tar_list[x:(x + n)]) for x in arr[::n]]
  134. return result
  135. @classmethod
  136. @DB.connection_context()
  137. def filter_scope_list(cls, in_key, in_filters_list,
  138. filters=None, cols=None):
  139. in_filters_tuple_list = cls.cut_list(in_filters_list, 20)
  140. if not filters:
  141. filters = []
  142. res_list = []
  143. if cols:
  144. for i in in_filters_tuple_list:
  145. query_records = cls.model.select(
  146. *
  147. cols).where(
  148. getattr(
  149. cls.model,
  150. in_key).in_(i),
  151. *
  152. filters)
  153. if query_records:
  154. res_list.extend(
  155. [query_record for query_record in query_records])
  156. else:
  157. for i in in_filters_tuple_list:
  158. query_records = cls.model.select().where(
  159. getattr(cls.model, in_key).in_(i), *filters)
  160. if query_records:
  161. res_list.extend(
  162. [query_record for query_record in query_records])
  163. return res_list