60 lines
2.1 KiB
Python
60 lines
2.1 KiB
Python
import logging
|
||
from typing import TYPE_CHECKING
|
||
|
||
from browser.chrome import ChromeDriver
|
||
from common import Singleton
|
||
|
||
if TYPE_CHECKING:
|
||
from typing import Type, List
|
||
from browser.IDriver import IDriver
|
||
from config import ConfigManager
|
||
from common.items import TabInfo
|
||
|
||
_log = logging.getLogger("BrowserManager")
|
||
|
||
|
||
class BrowserManager(metaclass=Singleton):
|
||
_config_manager: "ConfigManager"
|
||
_mapping: "dict[str, Type[IDriver]]" = {
|
||
"chrome": ChromeDriver,
|
||
}
|
||
|
||
def __init__(self, config_manager: "ConfigManager"):
|
||
self._config_manager = config_manager
|
||
_config = self._config_manager.config["webdriver"]["use"]
|
||
if _config not in self._mapping:
|
||
_log.error("不支持的浏览器:%s", _config)
|
||
raise Exception("不支持的浏览器")
|
||
self._driver: IDriver = self._mapping[_config](self._config_manager)
|
||
self._tabs: "List[TabInfo]" = []
|
||
_log.debug("初始化完毕")
|
||
|
||
@property
|
||
def driver(self):
|
||
return self._driver
|
||
|
||
def open_tab(self, tab_info: "TabInfo"):
|
||
if not tab_info.tab_handler:
|
||
tab_handler = self._driver.new_tab()
|
||
tab_info.tab_handler = tab_handler
|
||
if not tab_info.tab_type:
|
||
tab_info.tab_type = TabInfo.TAB_TYPE_OTHER
|
||
_log.debug("打开URL:【%s】@%s", tab_info.url, tab_info.tab_handler)
|
||
self.driver.open_url(tab_info.url, tab_info.tab_handler)
|
||
_log.info("打开URL完毕:【%s】@%s", tab_info.url, tab_info.tab_handler)
|
||
if tab_info not in self._tabs:
|
||
self._tabs.append(tab_info)
|
||
|
||
def close_tab(self, tab_info: "TabInfo"):
|
||
if tab_info not in self._tabs:
|
||
_log.warning("提供的标签不在标签组中,不予执行")
|
||
return
|
||
_log.debug("关闭标签:%s", tab_info.tab_handler)
|
||
self._driver.close_tab(tab_info.tab_handler)
|
||
_log.info("关闭标签完毕:%s", tab_info.tab_handler)
|
||
self._tabs.remove(tab_info)
|
||
|
||
def terminate(self):
|
||
if self._driver:
|
||
self._driver.terminate()
|