database_retrieval.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. from typing import Optional
  2. from constants.languages import languages
  3. from extensions.ext_database import db
  4. from models.model import App, RecommendedApp
  5. from services.app_dsl_service import AppDslService
  6. from services.recommend_app.recommend_app_base import RecommendAppRetrievalBase
  7. from services.recommend_app.recommend_app_type import RecommendAppType
  8. class DatabaseRecommendAppRetrieval(RecommendAppRetrievalBase):
  9. """
  10. Retrieval recommended app from database
  11. """
  12. def get_recommended_apps_and_categories(self, language: str) -> dict:
  13. result = self.fetch_recommended_apps_from_db(language)
  14. return result
  15. def get_recommend_app_detail(self, app_id: str):
  16. result = self.fetch_recommended_app_detail_from_db(app_id)
  17. return result
  18. def get_type(self) -> str:
  19. return RecommendAppType.DATABASE
  20. @classmethod
  21. def fetch_recommended_apps_from_db(cls, language: str) -> dict:
  22. """
  23. Fetch recommended apps from db.
  24. :param language: language
  25. :return:
  26. """
  27. recommended_apps = (
  28. db.session.query(RecommendedApp)
  29. .filter(RecommendedApp.is_listed == True, RecommendedApp.language == language)
  30. .all()
  31. )
  32. if len(recommended_apps) == 0:
  33. recommended_apps = (
  34. db.session.query(RecommendedApp)
  35. .filter(RecommendedApp.is_listed == True, RecommendedApp.language == languages[0])
  36. .all()
  37. )
  38. categories = set()
  39. recommended_apps_result = []
  40. for recommended_app in recommended_apps:
  41. app = recommended_app.app
  42. if not app or not app.is_public:
  43. continue
  44. site = app.site
  45. if not site:
  46. continue
  47. recommended_app_result = {
  48. "id": recommended_app.id,
  49. "app": {
  50. "id": app.id,
  51. "name": app.name,
  52. "mode": app.mode,
  53. "icon": app.icon,
  54. "icon_background": app.icon_background,
  55. },
  56. "app_id": recommended_app.app_id,
  57. "description": site.description,
  58. "copyright": site.copyright,
  59. "privacy_policy": site.privacy_policy,
  60. "custom_disclaimer": site.custom_disclaimer,
  61. "category": recommended_app.category,
  62. "position": recommended_app.position,
  63. "is_listed": recommended_app.is_listed,
  64. }
  65. recommended_apps_result.append(recommended_app_result)
  66. categories.add(recommended_app.category)
  67. return {"recommended_apps": recommended_apps_result, "categories": sorted(categories)}
  68. @classmethod
  69. def fetch_recommended_app_detail_from_db(cls, app_id: str) -> Optional[dict]:
  70. """
  71. Fetch recommended app detail from db.
  72. :param app_id: App ID
  73. :return:
  74. """
  75. # is in public recommended list
  76. recommended_app = (
  77. db.session.query(RecommendedApp)
  78. .filter(RecommendedApp.is_listed == True, RecommendedApp.app_id == app_id)
  79. .first()
  80. )
  81. if not recommended_app:
  82. return None
  83. # get app detail
  84. app_model = db.session.query(App).filter(App.id == app_id).first()
  85. if not app_model or not app_model.is_public:
  86. return None
  87. return {
  88. "id": app_model.id,
  89. "name": app_model.name,
  90. "icon": app_model.icon,
  91. "icon_background": app_model.icon_background,
  92. "mode": app_model.mode,
  93. "export_data": AppDslService.export_dsl(app_model=app_model),
  94. }