diff options
Diffstat (limited to 'www/py-binarycookies/files')
-rw-r--r-- | www/py-binarycookies/files/patch-src_binarycookies_____main____.py | 49 | ||||
-rw-r--r-- | www/py-binarycookies/files/patch-src_binarycookies___deserialize.py | 21 |
2 files changed, 70 insertions, 0 deletions
diff --git a/www/py-binarycookies/files/patch-src_binarycookies_____main____.py b/www/py-binarycookies/files/patch-src_binarycookies_____main____.py new file mode 100644 index 000000000000..da43dac8dabd --- /dev/null +++ b/www/py-binarycookies/files/patch-src_binarycookies_____main____.py @@ -0,0 +1,49 @@ +--- src/binarycookies/__main__.py.orig 2025-04-08 19:50:17 UTC ++++ src/binarycookies/__main__.py +@@ -5,6 +5,8 @@ from sys import stdout + from typing import Type + + import typer ++# https://github.com/Textualize/rich/issues/271 ++println = print + from rich import print + + from binarycookies import load +@@ -20,6 +22,7 @@ class DateTimeEncoder(json.JSONEncoder): + class OutputType(str, Enum): + json = "json" + ascii = "ascii" ++ netscape = "netscape" + + + def cli(file_path: str, output: str = "json"): +@@ -27,7 +30,7 @@ def cli(file_path: str, output: str = "json"): + with open(file_path, "rb") as f: + cookies = load(f) + if output == OutputType.json: +- json.dump([cookie.model_dump() for cookie in cookies], indent=2, cls=DateTimeEncoder, fp=stdout) ++ json.dump([cookie.dict() for cookie in cookies], indent=2, cls=DateTimeEncoder, fp=stdout) + elif output == OutputType.ascii: + for cookie in cookies: + print(f"Name: {cookie.name}") +@@ -38,6 +41,20 @@ def cli(file_path: str, output: str = "json"): + print(f"Expires: {cookie.expiry_datetime.isoformat()}") + print(f"Flag: {cookie.flag.value}") + print("-" * 40) ++ elif output == OutputType.netscape: ++ # http://www.cookiecentral.com/faq/#3.5 ++ println("# Netscape HTTP Cookie File") ++ for cookie in cookies: ++ println("%(domain)s\t%(flag)s\t%(path)s\t%(secure)s\t%(expiry)d\t%(name)s\t%(value)s" % dict( ++ domain = cookie.url, ++ flag = str(cookie.url.startswith('.')).upper(), ++ path = cookie.path, ++ secure = str('Secure' in cookie.flag.value).upper(), ++ expiry = cookie.expiry_datetime.timestamp(), ++ name = cookie.name, ++ value = cookie.value)) ++ else: ++ print(f"Unsupported output format, can only do {', '.join('[green]%s[/green]' % ot.name for ot in OutputType)}.") + + + def main(): diff --git a/www/py-binarycookies/files/patch-src_binarycookies___deserialize.py b/www/py-binarycookies/files/patch-src_binarycookies___deserialize.py new file mode 100644 index 000000000000..3aec2539907c --- /dev/null +++ b/www/py-binarycookies/files/patch-src_binarycookies___deserialize.py @@ -0,0 +1,21 @@ +--- src/binarycookies/_deserialize.py.orig 2025-04-08 19:50:17 UTC ++++ src/binarycookies/_deserialize.py +@@ -1,6 +1,7 @@ + from datetime import datetime, timezone + from io import BytesIO + from struct import unpack ++from sys import maxsize + from typing import BinaryIO, List, Union + + from binarycookies.models import ( +@@ -28,7 +29,9 @@ def interpret_flag(flags: int) -> Flag: + + def mac_epoch_to_date(epoch: int) -> datetime: + """Converts a mac epoch time to a datetime object.""" +- return datetime.fromtimestamp(epoch + 978307200, tz=timezone.utc) ++ unix_epoch = epoch + 978307200 ++ if unix_epoch > maxsize: unix_epoch = maxsize ++ return datetime.fromtimestamp(unix_epoch, tz=timezone.utc) + + + def read_string(data: BytesIO, size: int) -> str: |