Skip to content

Commit

Permalink
fixed notifcations catalog
Browse files Browse the repository at this point in the history
Change-Id: I25249dcb78b68d1569997af0960adcfe03e8a059
  • Loading branch information
schnetzzz committed Dec 20, 2024
1 parent 01fbaf1 commit 610772c
Show file tree
Hide file tree
Showing 5 changed files with 75 additions and 59 deletions.
3 changes: 2 additions & 1 deletion cmk/gui/wato/pages/notifications/modes.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@
from cmk.gui.breadcrumb import Breadcrumb
from cmk.gui.config import active_config
from cmk.gui.exceptions import MKUserError
from cmk.gui.form_specs.converter import TransformDataForLegacyFormatOrRecomposeFunction
from cmk.gui.form_specs.private import Catalog, LegacyValueSpec
from cmk.gui.form_specs.vue.form_spec_visitor import parse_data_from_frontend, render_form_spec
from cmk.gui.form_specs.vue.visitors import DataOrigin, DEFAULT_VALUE
Expand Down Expand Up @@ -3630,7 +3631,7 @@ def _log_text(self, edit_nr: int) -> str:
return _("Created new notification parameter")
return _("Changed notification parameter #%s") % edit_nr

def _form_spec(self) -> Catalog:
def _form_spec(self) -> TransformDataForLegacyFormatOrRecomposeFunction:
return notification_parameter_registry.form_spec(self._method())

def action(self) -> ActionResult:
Expand Down
110 changes: 68 additions & 42 deletions cmk/gui/watolib/notification_parameter/_registry.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
import cmk.gui.rulespec as _rulespec
import cmk.gui.watolib.rulespecs as _rulespecs
from cmk.gui.exceptions import MKUserError
from cmk.gui.form_specs.converter import TransformDataForLegacyFormatOrRecomposeFunction
from cmk.gui.form_specs.private import (
Catalog,
CommentTextArea,
Expand All @@ -27,6 +28,7 @@
Topic,
)
from cmk.gui.form_specs.private.catalog import TopicElement
from cmk.gui.form_specs.vue.visitors import DefaultValue
from cmk.gui.utils.rule_specs.loader import LoadedRuleSpec
from cmk.gui.valuespec import Dictionary as ValueSpecDictionary
from cmk.gui.valuespec import Migrate as ValueSpecMigrate
Expand Down Expand Up @@ -88,7 +90,7 @@ def parameter_called(self) -> Dictionary:
},
)

def form_spec(self, method: str) -> Catalog:
def form_spec(self, method: str) -> TransformDataForLegacyFormatOrRecomposeFunction:
try:
param_form_spec = self._entries[method]()._form_spec()
except KeyError:
Expand All @@ -108,48 +110,72 @@ def form_spec(self, method: str) -> Catalog:
% (method, e),
)

return Catalog(
elements={
"general": Topic(
title=Title("Parameter properties"),
elements={
"description": TopicElement(
parameter_form=String(
title=Title("Description"),
field_size=FieldSize.LARGE,
custom_validate=[not_empty()],
),
required=True,
),
"comment": TopicElement(
parameter_form=CommentTextArea(
title=Title("Comment"),
)
),
"docu_url": TopicElement(
parameter_form=String(
title=Title("Documentation URL"),
help_text=Help(
"An optional URL pointing to documentation or any other page. This will be "
"displayed as an icon and open "
"a new page when clicked. You can use either global URLs (beginning with "
"<tt>http://</tt>), absolute local urls (beginning with <tt>/</tt>) or relative "
"URLs (that are relative to <tt>check_mk/</tt>)."
def _add_method_key(value: object) -> object:
if not isinstance(value, dict):
return value

if parameter_properties := value.get("parameter_properties"):
if isinstance(parameter_properties, DefaultValue):
return value
if "method_parameters" not in parameter_properties:
value["parameter_properties"] = {"method_parameters": parameter_properties}

return value

def _remove_method_key(value: object) -> object:
if not isinstance(value, dict):
return value
if parameter_properties := value.get("parameter_properties"):
if "method_parameters" in parameter_properties:
value["parameter_properties"] = parameter_properties["method_parameters"]
return value

return TransformDataForLegacyFormatOrRecomposeFunction(
from_disk=_add_method_key,
to_disk=_remove_method_key,
wrapped_form_spec=Catalog(
elements={
"general": Topic(
title=Title("Parameter properties"),
elements={
"description": TopicElement(
parameter_form=String(
title=Title("Description"),
field_size=FieldSize.LARGE,
custom_validate=[not_empty()],
),
)
),
},
),
"parameter_properties": Topic(
title=Title("Parameter properties"),
elements={
"method_parameters": TopicElement(
required=True,
parameter_form=param_form_spec,
),
},
),
}
required=True,
),
"comment": TopicElement(
parameter_form=CommentTextArea(
title=Title("Comment"),
)
),
"docu_url": TopicElement(
parameter_form=String(
title=Title("Documentation URL"),
help_text=Help(
"An optional URL pointing to documentation or any other page. This will be "
"displayed as an icon and open "
"a new page when clicked. You can use either global URLs (beginning with "
"<tt>http://</tt>), absolute local urls (beginning with <tt>/</tt>) or relative "
"URLs (that are relative to <tt>check_mk/</tt>)."
),
)
),
},
),
"parameter_properties": Topic(
title=Title("Parameter properties"),
elements={
"method_parameters": TopicElement(
required=True,
parameter_form=param_form_spec,
),
},
),
}
),
)

def _construct_form_spec_from_valuespec(self, method: str) -> Dictionary:
Expand Down
12 changes: 2 additions & 10 deletions cmk/gui/watolib/notification_parameter/_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ def _to_param_item(data: object) -> NotificationParameterItem:
comment=general.get("comment", ""),
docu_url=general.get("docu_url", ""),
),
parameter_properties=data["parameter_properties"]["method_parameters"],
parameter_properties=data["parameter_properties"],
)
except KeyError as exc:
raise ValueError from exc
Expand Down Expand Up @@ -121,14 +121,6 @@ class NotificationParameter(NamedTuple):
data: Mapping


def _add_method_key(item: object) -> object:
if not isinstance(item, dict):
return item
if "parameter_properties" in item:
item["parameter_properties"] = {"method_parameters": item["parameter_properties"]}
return item


def get_notification_parameter(
registry: NotificationParameterRegistry,
parameter_id: NotificationParameterID,
Expand All @@ -141,7 +133,7 @@ def get_notification_parameter(
notification_parameter = NotificationParameterConfigFile().load_for_reading()
method, item = next(
(
(method, _add_method_key(item.get(parameter_id)))
(method, item.get(parameter_id))
for method, item in notification_parameter.items()
if parameter_id in item
),
Expand Down
7 changes: 2 additions & 5 deletions cmk/update_config/plugins/actions/migrate_notifications.py
Original file line number Diff line number Diff line change
Expand Up @@ -123,18 +123,15 @@ def _get_data_for_disk(
comment="Auto migrated on update",
docu_url="",
),
parameter_properties={"method_parameters": parameter},
parameter_properties=parameter,
)
form_spec = notification_parameter_registry.form_spec(method)
visitor = get_visitor(form_spec, VisitorOptions(DataOrigin.DISK))

validation_errors = visitor.validate(data)
process_validation_messages(validation_errors)

# The catalog formspec uses "method_parameters" as additional nested key, we don't need it
disk_data = visitor.to_disk(data)
disk_data["parameter_properties"] = disk_data["parameter_properties"]["method_parameters"]
return disk_data
return visitor.to_disk(data)


update_action_registry.register(
Expand Down
2 changes: 1 addition & 1 deletion tests/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -420,7 +420,7 @@ test-cycles:
$$($(UVENV) scripts/find_cmk_namespace_package_paths.py) \
$$(realpath -L ..)/omd/packages/omd/omdlib \
--strategy johnson \
--threshold 114 \
--threshold 116 \
--verbose

test-cycles-docker:
Expand Down

0 comments on commit 610772c

Please sign in to comment.