17
0

Compare commits

2 Commits

6 changed files with 27 additions and 101 deletions

View File

@@ -1,55 +1,38 @@
From bb664d9862f1aa427744e34c51e7f2c1a8f35e15 Mon Sep 17 00:00:00 2001
From: jrconlin <jr+git@mozilla.com>
Date: Fri, 14 Jun 2024 14:25:02 -0700
Subject: [PATCH] bug: remove six requirement, add license classifer
There are a few other "poetry" related changes
that should be made, but I'm skipping those for
now.
Closes #166, 167
---
pyproject.toml | 9 ++++++++-
pywebpush/__init__.py | 5 ++---
requirements.txt | 1 -
setup.py | 2 +-
4 files changed, 11 insertions(+), 6 deletions(-)
Index: pywebpush-2.1.0/pywebpush/__init__.py
Index: pywebpush-1.14.0/pywebpush/__init__.py
===================================================================
--- pywebpush-2.1.0.orig/pywebpush/__init__.py
+++ pywebpush-2.1.0/pywebpush/__init__.py
@@ -19,7 +19,6 @@ except ImportError: # pragma nocover
import aiohttp
--- pywebpush-1.14.0.orig/pywebpush/__init__.py
+++ pywebpush-1.14.0/pywebpush/__init__.py
@@ -13,7 +13,6 @@ try:
except ImportError: # pragma nocover
from urlparse import urlparse
-import six
import http_ece
import requests
-import six
from cryptography.hazmat.backends import default_backend
from cryptography.hazmat.primitives.asymmetric import ec
from cryptography.hazmat.primitives import serialization
@@ -175,7 +174,7 @@ class WebPusher:
for k in ["p256dh", "auth"]:
@@ -152,7 +151,7 @@ class WebPusher:
for k in ['p256dh', 'auth']:
if keys.get(k) is None:
raise WebPushException("Missing keys value: {}".format(k))
- if isinstance(keys[k], six.text_type):
+ if isinstance(keys[k], str):
keys[k] = bytes(cast(str, keys[k]).encode("utf8"))
keys[k] = bytes(keys[k].encode('utf8'))
receiver_raw = base64.urlsafe_b64decode(
self._repad(cast(bytes, keys["p256dh"]))
@@ -236,7 +235,7 @@ class WebPusher:
format=serialization.PublicFormat.UncompressedPoint,
self._repad(keys['p256dh']))
@@ -206,7 +205,7 @@ class WebPusher:
format=serialization.PublicFormat.UncompressedPoint
)
- if isinstance(data, six.text_type):
+ if isinstance(data, str):
data = bytes(data.encode("utf8"))
data = bytes(data.encode('utf8'))
if content_encoding == "aes128gcm":
self.verb("Encrypting to aes128gcm...")
Index: pywebpush-2.1.0/requirements.txt
Index: pywebpush-1.14.0/requirements.txt
===================================================================
--- pywebpush-2.1.0.orig/requirements.txt
+++ pywebpush-2.1.0/requirements.txt
@@ -2,5 +2,4 @@ aiohttp
--- pywebpush-1.14.0.orig/requirements.txt
+++ pywebpush-1.14.0/requirements.txt
@@ -1,5 +1,4 @@
cryptography>=2.6.1
http-ece>=1.1.0
requests>=2.21.0

View File

@@ -1,16 +1,3 @@
-------------------------------------------------------------------
Wed Oct 15 03:12:29 UTC 2025 - Steve Kowalik <steven.kowalik@suse.com>
- Update to 2.1.0:
* feat: Add a async_webpush one call func
* set license classifier
* chore: Update to modern python practices (well, Python 3.8)
* Webpusher.encode will now return a NoData exception if no data is
present to encode
- Refresh patch no-more-six.patch from upstream.
- Add patch use-unittest-mock.patch:
* Use unittest.mock rather than mock.
-------------------------------------------------------------------
Wed Jun 11 05:49:38 UTC 2025 - Steve Kowalik <steven.kowalik@suse.com>

View File

@@ -1,7 +1,7 @@
#
# spec file for package python-pywebpush
#
# Copyright (c) 2025 SUSE LLC and contributors
# Copyright (c) 2025 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -17,22 +17,19 @@
Name: python-pywebpush
Version: 2.1.0
Version: 1.14.0
Release: 0
Summary: WebPush publication library
License: MPL-2.0
URL: https://github.com/web-push-libs/pywebpush
Source: https://files.pythonhosted.org/packages/source/p/pywebpush/pywebpush-%{version}.tar.gz
# PATCH-FIX-UPSTREAM Based on gh#web-push-libs/pywebpush#bb664d9862f1aa427744e34c51e7f2c1a8f35e15
# PATCH-FIX-OPENSUSE Do not require six module
Patch0: no-more-six.patch
# PATCH-FIX-UPSTREAM gh#web-push-libs/pywebpush#180
Patch1: use-unittest-mock.patch
BuildRequires: %{python_module pip}
BuildRequires: %{python_module setuptools}
BuildRequires: %{python_module wheel}
BuildRequires: fdupes
BuildRequires: python-rpm-macros
Requires: python-aiohttp
Requires: python-cryptography >= 2.6.1
Requires: python-http-ece >= 1.1.0
Requires: python-py-vapid >= 1.5.0
@@ -42,7 +39,6 @@ Requires(postun): update-alternatives
BuildArch: noarch
# SECTION test requirements
BuildRequires: %{python_module cryptography >= 2.6.1}
BuildRequires: %{python_module aiohttp}
BuildRequires: %{python_module http-ece >= 1.1.0}
BuildRequires: %{python_module py-vapid >= 1.5.0}
BuildRequires: %{python_module pytest}
@@ -65,6 +61,8 @@ WebPush publication library.
%python_expand %fdupes %{buildroot}%{$python_sitelib}
%check
# https://github.com/web-push-libs/pywebpush/issues/146
sed -i 's:from mock:from unittest.mock:' pywebpush/tests/test_webpush.py
%pytest
%post

3
pywebpush-1.14.0.tar.gz Normal file
View File

@@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:6c36e1679268219e693ba940db2bf254c240ca02664de102b7269afc3c545731
size 25497

View File

@@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:3cd55b7d217ab95beb083e68f61b812f0545f74566928312203076b069ff55c8
size 27233

View File

@@ -1,42 +0,0 @@
From 232eb3f7033f9bfa58c6583f68661628eee847a9 Mon Sep 17 00:00:00 2001
From: Steve Kowalik <stevenk@debian.org>
Date: Wed, 15 Oct 2025 13:08:03 +1100
Subject: [PATCH] Use unittest.mock
Drop the use of the external mock module, unittest.mock has been
included in the standard library since Python 3.4.
Closes: #146
---
pywebpush/tests/test_webpush.py | 2 +-
test-requirements.txt | 3 +--
2 files changed, 2 insertions(+), 3 deletions(-)
diff --git a/pywebpush/tests/test_webpush.py b/pywebpush/tests/test_webpush.py
index 324c6d4..b8d2081 100644
--- a/pywebpush/tests/test_webpush.py
+++ b/pywebpush/tests/test_webpush.py
@@ -4,11 +4,11 @@
import unittest
import time
from typing import cast, Union, Dict
+from unittest.mock import patch, Mock, AsyncMock
import http_ece
import py_vapid
import requests
-from mock import patch, Mock, AsyncMock
from cryptography.hazmat.primitives.asymmetric import ec
from cryptography.hazmat.primitives import serialization
from cryptography.hazmat.backends import default_backend
diff --git a/test-requirements.txt b/test-requirements.txt
index c284191..a3e3fb9 100644
--- a/test-requirements.txt
+++ b/test-requirements.txt
@@ -1,4 +1,3 @@
-r requirements.txt
black
-mock
-pytest
\ No newline at end of file
+pytest