From fe8eee009228c75b441927263a73806de6ca4a22 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Guillot?= Date: Tue, 3 Sep 2024 20:55:25 -0700 Subject: [PATCH 1/2] ci: add older Python versions to test matrix --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 8c9ecc0..42aa664 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -13,7 +13,7 @@ jobs: max-parallel: 4 matrix: os: [ubuntu-latest] - python-version: ["3.11", "3.12"] + python-version: ["3.7", "3.8", "3.9", "3.10", "3.11", "3.12"] steps: - uses: actions/checkout@v4 From f43517daecd92b37af50916ff0fc07dd5e20a640 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Guillot?= Date: Tue, 3 Sep 2024 20:59:41 -0700 Subject: [PATCH 2/2] fix: type hints should be backward compatible with old Python versions --- miniflux.py | 31 ++++++++++++++++--------------- pyproject.toml | 2 +- 2 files changed, 17 insertions(+), 16 deletions(-) diff --git a/miniflux.py b/miniflux.py index 8e904f9..6d046a2 100644 --- a/miniflux.py +++ b/miniflux.py @@ -21,6 +21,7 @@ # THE SOFTWARE. import json +from typing import List, Optional, Union import requests @@ -104,10 +105,10 @@ class Client: def __init__( self, base_url: str, - username: str | None = None, - password: str | None = None, + username: Optional[str] = None, + password: Optional[str] = None, timeout: float = 30.0, - api_key: str | None = None, + api_key: Optional[str] = None, user_agent: str = DEFAULT_USER_AGENT, ): self._base_url = base_url @@ -115,7 +116,7 @@ def __init__( self._username = username self._password = password self._timeout = timeout - self._auth: tuple | None = ( + self._auth: Optional[tuple] = ( (self._username, self._password) if not api_key else None ) self._headers = {"User-Agent": user_agent} @@ -128,7 +129,7 @@ def _get_endpoint(self, path: str) -> str: return f"{self._base_url}/v{self.API_VERSION}{path}" - def _get_params(self, **kwargs) -> dict | None: + def _get_params(self, **kwargs) -> Optional[dict]: params = {k: v for k, v in kwargs.items() if v} return params if len(params) > 0 else None @@ -248,7 +249,7 @@ def import_feeds(self, opml: str) -> dict: return response.json() self._handle_error_response(response) - def discover(self, website_url: str, **kwargs) -> list[dict]: + def discover(self, website_url: str, **kwargs) -> List[dict]: """ Discover feeds from a website. @@ -274,7 +275,7 @@ def discover(self, website_url: str, **kwargs) -> list[dict]: return response.json() self._handle_error_response(response) - def get_category_feeds(self, category_id: int) -> list[dict]: + def get_category_feeds(self, category_id: int) -> List[dict]: """ Retrieves a list of feeds for a given category. @@ -293,7 +294,7 @@ def get_category_feeds(self, category_id: int) -> list[dict]: return response.json() self._handle_error_response(response) - def get_feeds(self) -> list[dict]: + def get_feeds(self) -> List[dict]: """ Retrieves a list of all feeds. @@ -381,7 +382,7 @@ def get_icon_by_feed_id(self, feed_id: int) -> dict: return self.get_feed_icon(feed_id) def create_feed( - self, feed_url: str, category_id: int | None = None, **kwargs + self, feed_url: str, category_id: Optional[int] = None, **kwargs ) -> int: """ Create a new feed. @@ -608,7 +609,7 @@ def get_entries(self, **kwargs) -> dict: self._handle_error_response(response) def update_entry( - self, entry_id: int, title: str | None = None, content: str | None = None + self, entry_id: int, title: Optional[str] = None, content: Optional[str] = None ) -> dict: """ Update an entry. @@ -640,7 +641,7 @@ def update_entry( return response.json() self._handle_error_response(response) - def update_entries(self, entry_ids: list[int], status: str) -> bool: + def update_entries(self, entry_ids: List[int], status: str) -> bool: """ Change the status of multiple entries. @@ -742,7 +743,7 @@ def get_enclosure(self, enclosure_id: int) -> dict: self._handle_error_response(response) def update_enclosure( - self, enclosure_id: int, media_progression: int | None = None + self, enclosure_id: int, media_progression: Optional[int] = None ) -> bool: """ Update an enclosure. @@ -768,7 +769,7 @@ def update_enclosure( self._handle_error_response(response) return True - def get_categories(self) -> list[dict]: + def get_categories(self) -> List[dict]: """ Fetch all categories. @@ -910,7 +911,7 @@ def mark_category_entries_as_read(self, category_id: int) -> None: if response.status_code != 204: self._handle_error_response(response) - def get_users(self) -> list[dict]: + def get_users(self) -> List[dict]: """ Fetch all users. @@ -953,7 +954,7 @@ def get_user_by_username(self, username: str) -> dict: """ return self._get_user(username) - def _get_user(self, user_id_or_username: str | int) -> dict: + def _get_user(self, user_id_or_username: Union[str, int]) -> dict: endpoint = self._get_endpoint(f"/users/{user_id_or_username}") response = requests.get( endpoint, headers=self._headers, auth=self._auth, timeout=self._timeout diff --git a/pyproject.toml b/pyproject.toml index 1c5a316..0846667 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "miniflux" -version = "1.1.0" +version = "1.1.1" description = "Client library for Miniflux" readme = "README.rst" requires-python = ">=3.7"