From 18e29064c29b9af49639febed55ef8dbe0ae8ac0 Mon Sep 17 00:00:00 2001 From: Martyn Date: Sun, 9 Jul 2023 12:46:12 +0100 Subject: [PATCH 1/3] Ensure string encoding is consistent when creating RequestData elements --- httpie_hmac/httpie_hmac.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/httpie_hmac/httpie_hmac.py b/httpie_hmac/httpie_hmac.py index a50977e..698d15b 100644 --- a/httpie_hmac/httpie_hmac.py +++ b/httpie_hmac/httpie_hmac.py @@ -143,6 +143,8 @@ def __call__(self, r): content_type = r.headers.get('content-type') if not content_type: content_type = '' + else: + content_type = content_type.decode('utf-8') # If content-md5 is already given, use it, otherwise calculate # it ourselves and add it to the headers @@ -151,10 +153,12 @@ def __call__(self, r): if content_type and r.body: m = hashlib.md5() m.update(r.body) - content_md5 = base64.b64encode(m.digest()).rstrip() + content_md5 = base64.b64encode(m.digest()).rstrip().decode('utf-8') r.headers['Content-MD5'] = content_md5 else: content_md5 = '' + else: + content_md5 = content_md5.decode('utf-8') # If date is given already, use it - otherwise generate it # ourselves and add it to the headers @@ -163,6 +167,8 @@ def __call__(self, r): now = datetime.datetime.utcnow() http_date = now.strftime('%a, %d %b %Y %H:%M:%S GMT') r.headers['Date'] = http_date + else: + http_date = http_date.decode('utf-8') # Get the path from the UL url = urlparse(r.url) From 184b4e1ac56d5b6a67e9e1a8e3126315599699a4 Mon Sep 17 00:00:00 2001 From: Martyn Date: Sun, 9 Jul 2023 20:57:37 +0100 Subject: [PATCH 2/3] Fix linting error and consume buffer type inputs to body content --- httpie_hmac/httpie_hmac.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/httpie_hmac/httpie_hmac.py b/httpie_hmac/httpie_hmac.py index 698d15b..0057fc0 100644 --- a/httpie_hmac/httpie_hmac.py +++ b/httpie_hmac/httpie_hmac.py @@ -10,6 +10,7 @@ import hashlib import hmac import importlib.machinery +import io import os import requests import types @@ -152,8 +153,16 @@ def __call__(self, r): if not content_md5: if content_type and r.body: m = hashlib.md5() + body = r.body + # If we have a buffer, convert it in to a string + if type(r.body) == io.BufferedReader: + body = body.read() + r.body = body m.update(r.body) - content_md5 = base64.b64encode(m.digest()).rstrip().decode('utf-8') + content_md5 = base64 \ + .b64encode(m.digest()) \ + .rstrip() \ + .decode('utf-8') r.headers['Content-MD5'] = content_md5 else: content_md5 = '' From adc2f55e167fb1119c5e5d567d70e4c6207c17bb Mon Sep 17 00:00:00 2001 From: Martyn Date: Sun, 9 Jul 2023 20:58:18 +0100 Subject: [PATCH 3/3] Increment minor version number --- pyproject.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index ba384b5..092a15f 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta" [project] name = "httpie-hmac" -version = "1.1.1" +version = "1.2.0" authors = [ {name = "Martyn Pittuck-Schols", email = "martyn@rustfoo.com"}, ]