mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Improve filter validation for test report
This commit is contained in:
parent
ce28b84f34
commit
59e37b2526
35
InvenTree/report/migrations/0005_auto_20210119_0815.py
Normal file
35
InvenTree/report/migrations/0005_auto_20210119_0815.py
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# Generated by Django 3.0.7 on 2021-01-18 21:15
|
||||||
|
|
||||||
|
import django.core.validators
|
||||||
|
from django.db import migrations, models
|
||||||
|
import report.models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('report', '0004_auto_20200823_1104'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='testreport',
|
||||||
|
name='description',
|
||||||
|
field=models.CharField(help_text='Report template description', max_length=250, verbose_name='Description'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='testreport',
|
||||||
|
name='filters',
|
||||||
|
field=models.CharField(blank=True, help_text='Part query filters (comma-separated list of key=value pairs)', max_length=250, validators=[report.models.validate_stock_item_report_filters], verbose_name='Filters'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='testreport',
|
||||||
|
name='name',
|
||||||
|
field=models.CharField(help_text='Template name', max_length=100, unique=True, verbose_name='Name'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='testreport',
|
||||||
|
name='template',
|
||||||
|
field=models.FileField(help_text='Report template file', upload_to=report.models.rename_template, validators=[django.core.validators.FileExtensionValidator(allowed_extensions=['html', 'htm', 'tex'])], verbose_name='Template'),
|
||||||
|
),
|
||||||
|
]
|
@ -57,6 +57,11 @@ def rename_template(instance, filename):
|
|||||||
return os.path.join('report', 'report_template', instance.getSubdir(), filename)
|
return os.path.join('report', 'report_template', instance.getSubdir(), filename)
|
||||||
|
|
||||||
|
|
||||||
|
def validate_stock_item_report_filters(filters):
|
||||||
|
|
||||||
|
return validateFilterString(filters, model=stock.models.StockItem)
|
||||||
|
|
||||||
|
|
||||||
class WeasyprintReportMixin(WeasyTemplateResponseMixin):
|
class WeasyprintReportMixin(WeasyTemplateResponseMixin):
|
||||||
"""
|
"""
|
||||||
Class for rendering a HTML template to a PDF.
|
Class for rendering a HTML template to a PDF.
|
||||||
@ -144,29 +149,28 @@ class ReportTemplateBase(models.Model):
|
|||||||
|
|
||||||
name = models.CharField(
|
name = models.CharField(
|
||||||
blank=False, max_length=100,
|
blank=False, max_length=100,
|
||||||
|
verbose_name=_('Name'),
|
||||||
help_text=_('Template name'),
|
help_text=_('Template name'),
|
||||||
unique=True,
|
unique=True,
|
||||||
)
|
)
|
||||||
|
|
||||||
template = models.FileField(
|
template = models.FileField(
|
||||||
upload_to=rename_template,
|
upload_to=rename_template,
|
||||||
|
verbose_name=_('Template'),
|
||||||
help_text=_("Report template file"),
|
help_text=_("Report template file"),
|
||||||
validators=[FileExtensionValidator(allowed_extensions=['html', 'htm', 'tex'])],
|
validators=[FileExtensionValidator(allowed_extensions=['html', 'htm', 'tex'])],
|
||||||
)
|
)
|
||||||
|
|
||||||
description = models.CharField(max_length=250, help_text=_("Report template description"))
|
description = models.CharField(
|
||||||
|
max_length=250,
|
||||||
|
verbose_name=_('Description'),
|
||||||
|
help_text=_("Report template description")
|
||||||
|
)
|
||||||
|
|
||||||
enabled = models.BooleanField(
|
enabled = models.BooleanField(
|
||||||
default=True,
|
default=True,
|
||||||
|
verbose_name=_('Enabled'),
|
||||||
help_text=_('Report template is enabled'),
|
help_text=_('Report template is enabled'),
|
||||||
verbose_name=_('Enabled')
|
|
||||||
)
|
|
||||||
|
|
||||||
filters = models.CharField(
|
|
||||||
blank=True,
|
|
||||||
max_length=250,
|
|
||||||
help_text=_("Part query filters (comma-separated list of key=value pairs)"),
|
|
||||||
validators=[validateFilterString]
|
|
||||||
)
|
)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
@ -184,6 +188,16 @@ class TestReport(ReportTemplateBase):
|
|||||||
# Requires a stock_item object to be given to it before rendering
|
# Requires a stock_item object to be given to it before rendering
|
||||||
stock_item = None
|
stock_item = None
|
||||||
|
|
||||||
|
filters = models.CharField(
|
||||||
|
blank=True,
|
||||||
|
max_length=250,
|
||||||
|
verbose_name=_('Filters'),
|
||||||
|
help_text=_("Part query filters (comma-separated list of key=value pairs)"),
|
||||||
|
validators=[
|
||||||
|
validate_stock_item_report_filters
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
def matches_stock_item(self, item):
|
def matches_stock_item(self, item):
|
||||||
"""
|
"""
|
||||||
Test if this report template matches a given StockItem objects
|
Test if this report template matches a given StockItem objects
|
||||||
|
Loading…
Reference in New Issue
Block a user