From d800ccfea9bbfee3b872ee073dda867b5cc5753a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ztripez=20von=20Mat=C3=A9rn?= Date: Thu, 16 Jan 2025 18:25:53 +0100 Subject: [PATCH] fixed popup flow, disabled internal cache. --- music_assistant/providers/audible/__init__.py | 7 ++++--- music_assistant/providers/audible/audible_helper.py | 11 +++++++---- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/music_assistant/providers/audible/__init__.py b/music_assistant/providers/audible/__init__.py index 4d4d3c351..e7d8820fa 100644 --- a/music_assistant/providers/audible/__init__.py +++ b/music_assistant/providers/audible/__init__.py @@ -4,7 +4,6 @@ import asyncio import os -import webbrowser from collections.abc import AsyncGenerator from logging import getLevelName from typing import TYPE_CHECKING, cast @@ -17,7 +16,7 @@ ConfigValueType, ProviderConfig, ) -from music_assistant_models.enums import ConfigEntryType, MediaType, ProviderFeature +from music_assistant_models.enums import ConfigEntryType, EventType, MediaType, ProviderFeature from music_assistant_models.errors import LoginFailed from music_assistant.models.music_provider import MusicProvider @@ -111,7 +110,9 @@ async def get_config_entries( values[CONF_CODE_VERIFIER] = code_verifier values[CONF_SERIAL] = serial values[CONF_LOGIN_URL] = login_url - webbrowser.open_new_tab(login_url) + session_id = str(values["session_id"]) + mass.signal_event(EventType.AUTH_SESSION, session_id, login_url) + await asyncio.sleep(15) if action == CONF_ACTION_VERIFY: code_verifier = str(values.get(CONF_CODE_VERIFIER)) diff --git a/music_assistant/providers/audible/audible_helper.py b/music_assistant/providers/audible/audible_helper.py index d8682cfc9..37bcfcb94 100644 --- a/music_assistant/providers/audible/audible_helper.py +++ b/music_assistant/providers/audible/audible_helper.py @@ -74,6 +74,7 @@ async def get_library(self) -> AsyncGenerator[Audiobook, None]: while True: library = await self._call_api( "library", + use_cache=False, response_groups=",".join(response_groups), page=page, num_results=page_size, @@ -204,13 +205,15 @@ async def set_last_position(self, asin: str, pos: int) -> Any: """Report last position.""" async def _call_api(self, path: str, **kwargs: Any) -> Any: + response = None + use_cache = False params_str = json.dumps(kwargs, sort_keys=True) params_hash = hashlib.md5(params_str.encode()).hexdigest() cache_key_with_params = f"{path}:{params_hash}" - - response = await self.mass.cache.get( - key=cache_key_with_params, base_key=CACHE_DOMAIN, category=CACHE_CATEGORY_API - ) + if use_cache: + response = await self.mass.cache.get( + key=cache_key_with_params, base_key=CACHE_DOMAIN, category=CACHE_CATEGORY_API + ) if not response: response = await self.client.get(path, **kwargs) await self.mass.cache.set(