database_retrieval.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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": recommended_app.app,
  50. "app_id": recommended_app.app_id,
  51. "description": site.description,
  52. "copyright": site.copyright,
  53. "privacy_policy": site.privacy_policy,
  54. "custom_disclaimer": site.custom_disclaimer,
  55. "category": recommended_app.category,
  56. "position": recommended_app.position,
  57. "is_listed": recommended_app.is_listed,
  58. }
  59. recommended_apps_result.append(recommended_app_result)
  60. categories.add(recommended_app.category)
  61. return {"recommended_apps": recommended_apps_result, "categories": sorted(categories)}
  62. @classmethod
  63. def fetch_recommended_app_detail_from_db(cls, app_id: str) -> Optional[dict]:
  64. """
  65. Fetch recommended app detail from db.
  66. :param app_id: App ID
  67. :return:
  68. """
  69. # is in public recommended list
  70. recommended_app = (
  71. db.session.query(RecommendedApp)
  72. .filter(RecommendedApp.is_listed == True, RecommendedApp.app_id == app_id)
  73. .first()
  74. )
  75. if not recommended_app:
  76. return None
  77. # get app detail
  78. app_model = db.session.query(App).filter(App.id == app_id).first()
  79. if not app_model or not app_model.is_public:
  80. return None
  81. return {
  82. "id": app_model.id,
  83. "name": app_model.name,
  84. "icon": app_model.icon,
  85. "icon_background": app_model.icon_background,
  86. "mode": app_model.mode,
  87. "export_data": AppDslService.export_dsl(app_model=app_model),
  88. }