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.

database_retrieval.py 3.5KB

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