You've already forked Douyin_Web_Live
							
							
		
			
				
	
	
		
			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()
 |