Compare commits
2 Commits
| Author | SHA256 | Date | |
|---|---|---|---|
| d9dd481dba | |||
| b336a4e804 |
@@ -1,55 +1,38 @@
|
|||||||
From bb664d9862f1aa427744e34c51e7f2c1a8f35e15 Mon Sep 17 00:00:00 2001
|
Index: pywebpush-1.14.0/pywebpush/__init__.py
|
||||||
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-2.1.0.orig/pywebpush/__init__.py
|
--- pywebpush-1.14.0.orig/pywebpush/__init__.py
|
||||||
+++ pywebpush-2.1.0/pywebpush/__init__.py
|
+++ pywebpush-1.14.0/pywebpush/__init__.py
|
||||||
@@ -19,7 +19,6 @@ except ImportError: # pragma nocover
|
@@ -13,7 +13,6 @@ try:
|
||||||
import aiohttp
|
except ImportError: # pragma nocover
|
||||||
|
from urlparse import urlparse
|
||||||
|
|
||||||
|
-import six
|
||||||
import http_ece
|
import http_ece
|
||||||
import requests
|
import requests
|
||||||
-import six
|
|
||||||
from cryptography.hazmat.backends import default_backend
|
from cryptography.hazmat.backends import default_backend
|
||||||
from cryptography.hazmat.primitives.asymmetric import ec
|
@@ -152,7 +151,7 @@ class WebPusher:
|
||||||
from cryptography.hazmat.primitives import serialization
|
for k in ['p256dh', 'auth']:
|
||||||
@@ -175,7 +174,7 @@ class WebPusher:
|
|
||||||
for k in ["p256dh", "auth"]:
|
|
||||||
if keys.get(k) is None:
|
if keys.get(k) is None:
|
||||||
raise WebPushException("Missing keys value: {}".format(k))
|
raise WebPushException("Missing keys value: {}".format(k))
|
||||||
- if isinstance(keys[k], six.text_type):
|
- if isinstance(keys[k], six.text_type):
|
||||||
+ if isinstance(keys[k], str):
|
+ 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(
|
receiver_raw = base64.urlsafe_b64decode(
|
||||||
self._repad(cast(bytes, keys["p256dh"]))
|
self._repad(keys['p256dh']))
|
||||||
@@ -236,7 +235,7 @@ class WebPusher:
|
@@ -206,7 +205,7 @@ class WebPusher:
|
||||||
format=serialization.PublicFormat.UncompressedPoint,
|
format=serialization.PublicFormat.UncompressedPoint
|
||||||
)
|
)
|
||||||
|
|
||||||
- if isinstance(data, six.text_type):
|
- if isinstance(data, six.text_type):
|
||||||
+ if isinstance(data, str):
|
+ if isinstance(data, str):
|
||||||
data = bytes(data.encode("utf8"))
|
data = bytes(data.encode('utf8'))
|
||||||
if content_encoding == "aes128gcm":
|
if content_encoding == "aes128gcm":
|
||||||
self.verb("Encrypting to 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-1.14.0.orig/requirements.txt
|
||||||
+++ pywebpush-2.1.0/requirements.txt
|
+++ pywebpush-1.14.0/requirements.txt
|
||||||
@@ -2,5 +2,4 @@ aiohttp
|
@@ -1,5 +1,4 @@
|
||||||
cryptography>=2.6.1
|
cryptography>=2.6.1
|
||||||
http-ece>=1.1.0
|
http-ece>=1.1.0
|
||||||
requests>=2.21.0
|
requests>=2.21.0
|
||||||
|
|||||||
@@ -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>
|
Wed Jun 11 05:49:38 UTC 2025 - Steve Kowalik <steven.kowalik@suse.com>
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# spec file for package python-pywebpush
|
# 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
|
# All modifications and additions to the file contributed by third parties
|
||||||
# remain the property of their copyright owners, unless otherwise agreed
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
@@ -17,22 +17,19 @@
|
|||||||
|
|
||||||
|
|
||||||
Name: python-pywebpush
|
Name: python-pywebpush
|
||||||
Version: 2.1.0
|
Version: 1.14.0
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: WebPush publication library
|
Summary: WebPush publication library
|
||||||
License: MPL-2.0
|
License: MPL-2.0
|
||||||
URL: https://github.com/web-push-libs/pywebpush
|
URL: https://github.com/web-push-libs/pywebpush
|
||||||
Source: https://files.pythonhosted.org/packages/source/p/pywebpush/pywebpush-%{version}.tar.gz
|
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
|
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 pip}
|
||||||
BuildRequires: %{python_module setuptools}
|
BuildRequires: %{python_module setuptools}
|
||||||
BuildRequires: %{python_module wheel}
|
BuildRequires: %{python_module wheel}
|
||||||
BuildRequires: fdupes
|
BuildRequires: fdupes
|
||||||
BuildRequires: python-rpm-macros
|
BuildRequires: python-rpm-macros
|
||||||
Requires: python-aiohttp
|
|
||||||
Requires: python-cryptography >= 2.6.1
|
Requires: python-cryptography >= 2.6.1
|
||||||
Requires: python-http-ece >= 1.1.0
|
Requires: python-http-ece >= 1.1.0
|
||||||
Requires: python-py-vapid >= 1.5.0
|
Requires: python-py-vapid >= 1.5.0
|
||||||
@@ -42,7 +39,6 @@ Requires(postun): update-alternatives
|
|||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
# SECTION test requirements
|
# SECTION test requirements
|
||||||
BuildRequires: %{python_module cryptography >= 2.6.1}
|
BuildRequires: %{python_module cryptography >= 2.6.1}
|
||||||
BuildRequires: %{python_module aiohttp}
|
|
||||||
BuildRequires: %{python_module http-ece >= 1.1.0}
|
BuildRequires: %{python_module http-ece >= 1.1.0}
|
||||||
BuildRequires: %{python_module py-vapid >= 1.5.0}
|
BuildRequires: %{python_module py-vapid >= 1.5.0}
|
||||||
BuildRequires: %{python_module pytest}
|
BuildRequires: %{python_module pytest}
|
||||||
@@ -65,6 +61,8 @@ WebPush publication library.
|
|||||||
%python_expand %fdupes %{buildroot}%{$python_sitelib}
|
%python_expand %fdupes %{buildroot}%{$python_sitelib}
|
||||||
|
|
||||||
%check
|
%check
|
||||||
|
# https://github.com/web-push-libs/pywebpush/issues/146
|
||||||
|
sed -i 's:from mock:from unittest.mock:' pywebpush/tests/test_webpush.py
|
||||||
%pytest
|
%pytest
|
||||||
|
|
||||||
%post
|
%post
|
||||||
|
|||||||
3
pywebpush-1.14.0.tar.gz
Normal file
3
pywebpush-1.14.0.tar.gz
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:6c36e1679268219e693ba940db2bf254c240ca02664de102b7269afc3c545731
|
||||||
|
size 25497
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:3cd55b7d217ab95beb083e68f61b812f0545f74566928312203076b069ff55c8
|
|
||||||
size 27233
|
|
||||||
@@ -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
|
|
||||||
Reference in New Issue
Block a user