forked from pool/python-pywebpush
Compare commits
4 Commits
| Author | SHA256 | Date | |
|---|---|---|---|
| 2b445d029c | |||
| fa76b01dd8 | |||
| 20c8d27dd4 | |||
| a0299904fc |
@@ -1,38 +1,55 @@
|
||||
Index: pywebpush-1.14.0/pywebpush/__init__.py
|
||||
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
|
||||
===================================================================
|
||||
--- 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
|
||||
--- 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
|
||||
import http_ece
|
||||
import requests
|
||||
-import six
|
||||
from cryptography.hazmat.backends import default_backend
|
||||
@@ -152,7 +151,7 @@ class WebPusher:
|
||||
for k in ['p256dh', 'auth']:
|
||||
from cryptography.hazmat.primitives.asymmetric import ec
|
||||
from cryptography.hazmat.primitives import serialization
|
||||
@@ -175,7 +174,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(keys[k].encode('utf8'))
|
||||
keys[k] = bytes(cast(str, keys[k]).encode("utf8"))
|
||||
receiver_raw = base64.urlsafe_b64decode(
|
||||
self._repad(keys['p256dh']))
|
||||
@@ -206,7 +205,7 @@ class WebPusher:
|
||||
format=serialization.PublicFormat.UncompressedPoint
|
||||
self._repad(cast(bytes, keys["p256dh"]))
|
||||
@@ -236,7 +235,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-1.14.0/requirements.txt
|
||||
Index: pywebpush-2.1.0/requirements.txt
|
||||
===================================================================
|
||||
--- pywebpush-1.14.0.orig/requirements.txt
|
||||
+++ pywebpush-1.14.0/requirements.txt
|
||||
@@ -1,5 +1,4 @@
|
||||
--- pywebpush-2.1.0.orig/requirements.txt
|
||||
+++ pywebpush-2.1.0/requirements.txt
|
||||
@@ -2,5 +2,4 @@ aiohttp
|
||||
cryptography>=2.6.1
|
||||
http-ece>=1.1.0
|
||||
requests>=2.21.0
|
||||
|
||||
@@ -1,3 +1,21 @@
|
||||
-------------------------------------------------------------------
|
||||
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>
|
||||
|
||||
- Switch to pyproject macros.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Wed Jun 28 06:43:49 UTC 2023 - Steve Kowalik <steven.kowalik@suse.com>
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
#
|
||||
# spec file for package python-pywebpush
|
||||
#
|
||||
# Copyright (c) 2023 SUSE LLC
|
||||
# Copyright (c) 2025 SUSE LLC and contributors
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
@@ -17,26 +17,32 @@
|
||||
|
||||
|
||||
Name: python-pywebpush
|
||||
Version: 1.14.0
|
||||
Version: 2.1.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-OPENSUSE Do not require six module
|
||||
# PATCH-FIX-UPSTREAM Based on gh#web-push-libs/pywebpush#bb664d9862f1aa427744e34c51e7f2c1a8f35e15
|
||||
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
|
||||
Requires: python-requests >= 2.21.0
|
||||
Requires(post): update-alternatives
|
||||
Requires(postun):update-alternatives
|
||||
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}
|
||||
@@ -51,16 +57,14 @@ WebPush publication library.
|
||||
%autosetup -p1 -n pywebpush-%{version}
|
||||
|
||||
%build
|
||||
%python_build
|
||||
%pyproject_wheel
|
||||
|
||||
%install
|
||||
%python_install
|
||||
%pyproject_install
|
||||
%python_clone -a %{buildroot}%{_bindir}/pywebpush
|
||||
%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
|
||||
@@ -74,6 +78,6 @@ sed -i 's:from mock:from unittest.mock:' pywebpush/tests/test_webpush.py
|
||||
%license LICENSE
|
||||
%python_alternative %{_bindir}/pywebpush
|
||||
%{python_sitelib}/pywebpush
|
||||
%{python_sitelib}/pywebpush-%{version}*-*info
|
||||
%{python_sitelib}/pywebpush-%{version}.dist-info
|
||||
|
||||
%changelog
|
||||
|
||||
@@ -1,3 +0,0 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:6c36e1679268219e693ba940db2bf254c240ca02664de102b7269afc3c545731
|
||||
size 25497
|
||||
3
pywebpush-2.1.0.tar.gz
Normal file
3
pywebpush-2.1.0.tar.gz
Normal file
@@ -0,0 +1,3 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:3cd55b7d217ab95beb083e68f61b812f0545f74566928312203076b069ff55c8
|
||||
size 27233
|
||||
42
use-unittest-mock.patch
Normal file
42
use-unittest-mock.patch
Normal file
@@ -0,0 +1,42 @@
|
||||
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
|
||||
Reference in New Issue
Block a user