mpt-extension-sdk 4.1.0__tar.gz → 4.2.0__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/PKG-INFO +1 -1
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/constants.py +0 -7
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/key_vault/base.py +2 -2
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/mpt_http/mpt.py +5 -3
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/conf/default.py +0 -6
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/management/commands/consume_events.py +1 -1
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/middleware.py +1 -1
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/producers.py +2 -3
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/master.py +4 -4
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/pyproject.toml +1 -1
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/LICENSE +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/README.md +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/airtable/wrap_http_error.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/events/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/events/dataclasses.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/events/registry.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/extension.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/security.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/utils.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/flows/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/flows/context.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/flows/pipeline.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/key_vault/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/mpt_http/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/mpt_http/base.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/mpt_http/utils.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/mpt_http/wrap_http_error.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/commands/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/commands/django.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/commands/run.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/apps.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/conf/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/management/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/management/commands/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/__init__.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/dispatcher.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/utils.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/initializer.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/logging.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/swoext.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/utils.py +0 -0
- {mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/workers.py +0 -0
|
@@ -1,7 +1,3 @@
|
|
|
1
|
-
from enum import Enum, unique
|
|
2
|
-
|
|
3
|
-
from django.conf import settings
|
|
4
|
-
|
|
5
1
|
EVENT_TYPES = "orders"
|
|
6
2
|
SECURITY_ALGORITHM = "HS256"
|
|
7
3
|
USER_AGENT = "swo-extensions/1.0"
|
|
@@ -9,6 +5,3 @@ CONSUME_EVENTS_HELP_TEXT = "Consume events from the MPT platform"
|
|
|
9
5
|
DEFAULT_APP_CONFIG_GROUP = "swo.mpt.sdk"
|
|
10
6
|
DEFAULT_APP_CONFIG_NAME = "app_config"
|
|
11
7
|
DJANGO_SETTINGS_MODULE = "mpt_extension_sdk.runtime.djapp.conf.default"
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
NotifyCategories = unique(Enum("NotifyCategories", settings.MPT_NOTIFY_CATEGORIES))
|
|
@@ -74,7 +74,7 @@ class KeyVault(Session):
|
|
|
74
74
|
)
|
|
75
75
|
return None
|
|
76
76
|
|
|
77
|
-
def _get_key_vault_url(self, key_vault_name: str):
|
|
77
|
+
def _get_key_vault_url(self, key_vault_name: str): # pragma: no cover
|
|
78
78
|
"""
|
|
79
79
|
Construct the Key Vault URL using the provided Key Vault name.
|
|
80
80
|
|
|
@@ -88,7 +88,7 @@ class KeyVault(Session):
|
|
|
88
88
|
# Construct the Key Vault URL
|
|
89
89
|
return f"https://{key_vault_name}.vault.azure.net/"
|
|
90
90
|
|
|
91
|
-
def _get_key_vault_client(self, key_vault_name: str):
|
|
91
|
+
def _get_key_vault_client(self, key_vault_name: str): # pragma: no cover
|
|
92
92
|
"""
|
|
93
93
|
Create a Key Vault client using the provided Key Vault URL and secret name.
|
|
94
94
|
|
|
@@ -1,16 +1,18 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from datetime import date
|
|
3
|
+
from enum import Enum
|
|
3
4
|
from functools import cache
|
|
4
5
|
from itertools import batched
|
|
5
6
|
|
|
6
7
|
from django.conf import settings
|
|
7
8
|
|
|
8
|
-
from mpt_extension_sdk.constants import NotifyCategories
|
|
9
9
|
from mpt_extension_sdk.mpt_http.base import MPTClient
|
|
10
10
|
from mpt_extension_sdk.mpt_http.wrap_http_error import wrap_mpt_http_error
|
|
11
11
|
|
|
12
12
|
logger = logging.getLogger(__name__)
|
|
13
13
|
|
|
14
|
+
NotifyCategories = Enum("NotifyCategories", settings.MPT_NOTIFY_CATEGORIES)
|
|
15
|
+
|
|
14
16
|
|
|
15
17
|
def _has_more_pages(page):
|
|
16
18
|
if not page:
|
|
@@ -381,7 +383,7 @@ def get_buyer(mpt_client, buyer_id):
|
|
|
381
383
|
@wrap_mpt_http_error
|
|
382
384
|
def notify(
|
|
383
385
|
mpt_client: MPTClient,
|
|
384
|
-
category_id:
|
|
386
|
+
category_id: str,
|
|
385
387
|
account_id: str,
|
|
386
388
|
buyer_id: str,
|
|
387
389
|
subject: str,
|
|
@@ -396,7 +398,7 @@ def notify(
|
|
|
396
398
|
|
|
397
399
|
Args:
|
|
398
400
|
mpt_client (MPTClient): Client object for interacting with MPT service.
|
|
399
|
-
category_id (
|
|
401
|
+
category_id (str): Identifier for the category of recipients or messages.
|
|
400
402
|
account_id (str): Identifier for the associated account.
|
|
401
403
|
buyer_id (str): Identifier for the buyer related to the notification.
|
|
402
404
|
subject (str): Subject/title of the notification to be sent.
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/conf/default.py
RENAMED
|
@@ -26,12 +26,6 @@ BASE_DIR = Path(__file__).resolve().parent.parent
|
|
|
26
26
|
# Quick-start development settings - unsuitable for production
|
|
27
27
|
# See https://docs.djangoproject.com/en/4.2/howto/deployment/checklist/
|
|
28
28
|
|
|
29
|
-
# SECURITY WARNING: keep the secret key used in production secret!
|
|
30
|
-
SECRET_KEY = os.getenv(
|
|
31
|
-
"MPT_DJANGO_SECRET_KEY",
|
|
32
|
-
"django-insecure-6r_%9ku+bg0=@xw1ah$wh+liwbsyhwpn#6alt*ppjn8t_uyp-u",
|
|
33
|
-
)
|
|
34
|
-
|
|
35
29
|
# SECURITY WARNING: don't run with debug turned on in production!
|
|
36
30
|
DEBUG = True
|
|
37
31
|
|
|
@@ -8,7 +8,7 @@ from mpt_extension_sdk.runtime.events.dispatcher import Dispatcher
|
|
|
8
8
|
from mpt_extension_sdk.runtime.events.producers import OrderEventProducer
|
|
9
9
|
|
|
10
10
|
|
|
11
|
-
class Command(BaseCommand):
|
|
11
|
+
class Command(BaseCommand): # pragma: no cover
|
|
12
12
|
help = CONSUME_EVENTS_HELP_TEXT
|
|
13
13
|
producer_classes = [
|
|
14
14
|
OrderEventProducer,
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/producers.py
RENAMED
|
@@ -32,7 +32,7 @@ class EventProducer(ABC):
|
|
|
32
32
|
self.producer.join()
|
|
33
33
|
|
|
34
34
|
@contextmanager
|
|
35
|
-
def sleep(self, secs, interval=0.5):
|
|
35
|
+
def sleep(self, secs, interval=0.5): # pragma: no cover
|
|
36
36
|
yield
|
|
37
37
|
sleeped = 0
|
|
38
38
|
while sleeped < secs and self.running_event.is_set():
|
|
@@ -61,7 +61,7 @@ class OrderEventProducer(EventProducer):
|
|
|
61
61
|
for order in orders:
|
|
62
62
|
self.dispatcher.dispatch_event(Event(order["id"], "orders", order))
|
|
63
63
|
|
|
64
|
-
def produce_events_with_context(self):
|
|
64
|
+
def produce_events_with_context(self): # pragma: no cover
|
|
65
65
|
while self.running:
|
|
66
66
|
with self.sleep(settings.MPT_ORDERS_API_POLLING_INTERVAL_SECS):
|
|
67
67
|
orders = self.get_processing_orders()
|
|
@@ -89,7 +89,6 @@ class OrderEventProducer(EventProducer):
|
|
|
89
89
|
except requests.RequestException:
|
|
90
90
|
logger.exception("Cannot retrieve orders")
|
|
91
91
|
return []
|
|
92
|
-
|
|
93
92
|
if response.status_code == 200:
|
|
94
93
|
page = response.json()
|
|
95
94
|
orders.extend(page["data"])
|
|
@@ -79,7 +79,7 @@ class Master:
|
|
|
79
79
|
self.workers[worker_type] = p
|
|
80
80
|
logger.info(f"{worker_type.capitalize()} worker pid: {p.pid}")
|
|
81
81
|
|
|
82
|
-
def monitor_processes(self):
|
|
82
|
+
def monitor_processes(self): # pragma: no cover
|
|
83
83
|
while self.monitor_event.is_set():
|
|
84
84
|
exited_workers = []
|
|
85
85
|
for worker_type, p in self.workers.items():
|
|
@@ -112,16 +112,16 @@ class Master:
|
|
|
112
112
|
self.stop()
|
|
113
113
|
self.start()
|
|
114
114
|
|
|
115
|
-
def __iter__(self):
|
|
115
|
+
def __iter__(self): # pragma: no cover
|
|
116
116
|
return self
|
|
117
117
|
|
|
118
|
-
def __next__(self):
|
|
118
|
+
def __next__(self): # pragma: no cover
|
|
119
119
|
changes = next(self.watcher)
|
|
120
120
|
if changes:
|
|
121
121
|
return list({Path(c[1]) for c in changes})
|
|
122
122
|
return None
|
|
123
123
|
|
|
124
|
-
def run(self):
|
|
124
|
+
def run(self): # pragma: no cover
|
|
125
125
|
self.start()
|
|
126
126
|
if self.options.get("reload"):
|
|
127
127
|
for files_changed in self:
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/airtable/wrap_http_error.py
RENAMED
|
File without changes
|
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/events/__init__.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/events/dataclasses.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/core/events/registry.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/mpt_http/wrap_http_error.py
RENAMED
|
File without changes
|
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/commands/__init__.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/commands/django.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/commands/run.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/djapp/conf/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/__init__.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/dispatcher.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/events/utils.py
RENAMED
|
File without changes
|
{mpt_extension_sdk-4.1.0 → mpt_extension_sdk-4.2.0}/mpt_extension_sdk/runtime/initializer.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|