mirror of
https://github.com/inventree/InvenTree.git
synced 2025-04-28 11:36:44 +00:00
* Adds a very simple sample plugin for label printing * Test mixin install status and API query * Better error reporting for label printing API * pep fixes * fix assertation * remove broken assertation * igonre for coverage * test the base process of printing * refactor tests * clean up basic test * refactor url * fix url creation * test printing multiples * test all printing endpoints * test all list options - move api tests * test for invalid filters * refactor * test with no part * these should not happen checks are in place upstream * fix assertation * do not cover continue parts * test for wrong implementation * ignore DB not ready * remove covage from default parts * fix url generation * test debug mode * fix url assertation * check that nothing was rendered Co-authored-by: Oliver Walters <oliver.henry.walters@gmail.com>
53 lines
1.6 KiB
Python
53 lines
1.6 KiB
Python
"""Functions to print a label to a mixin printer"""
|
|
import logging
|
|
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
import common.notifications
|
|
from plugin.registry import registry
|
|
|
|
logger = logging.getLogger('inventree')
|
|
|
|
|
|
def print_label(plugin_slug, label_image, label_instance=None, user=None):
|
|
"""
|
|
Print label with the provided plugin.
|
|
|
|
This task is nominally handled by the background worker.
|
|
|
|
If the printing fails (throws an exception) then the user is notified.
|
|
|
|
Arguments:
|
|
plugin_slug: The unique slug (key) of the plugin
|
|
label_image: A PIL.Image image object to be printed
|
|
"""
|
|
|
|
logger.info(f"Plugin '{plugin_slug}' is printing a label")
|
|
|
|
plugin = registry.plugins.get(plugin_slug, None)
|
|
|
|
if plugin is None: # pragma: no cover
|
|
logger.error(f"Could not find matching plugin for '{plugin_slug}'")
|
|
return
|
|
|
|
try:
|
|
plugin.print_label(label_image, width=label_instance.width, height=label_instance.height)
|
|
except Exception as e: # pragma: no cover
|
|
# Plugin threw an error - notify the user who attempted to print
|
|
|
|
ctx = {
|
|
'name': _('Label printing failed'),
|
|
'message': str(e),
|
|
}
|
|
|
|
logger.error(f"Label printing failed: Sending notification to user '{user}'")
|
|
|
|
# Throw an error against the plugin instance
|
|
common.notifications.trigger_notifaction(
|
|
plugin.plugin_config(),
|
|
'label.printing_failed',
|
|
targets=[user],
|
|
context=ctx,
|
|
delivery_methods=[common.notifications.UIMessageNotification]
|
|
)
|