Skip to content

Commit

Permalink
17500 FIX Custom & forecast graphs: Fix editing of foreign, non-publi…
Browse files Browse the repository at this point in the history
…c graphs

When editing a custom/forecast graph, we need to know the ID of the graph and
the owner, because:
* Users can edit custom/forecast graphs of other users if they have sufficient
  permissions.
* The IDs must only be unique per user, not site-wide.

CMK-20198

Change-Id: I5fe419f78316b6793db98f07f7a0db39698f9ea7
  • Loading branch information
jherbel committed Jan 9, 2025
1 parent 19f8799 commit 8f70d27
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 3 deletions.
17 changes: 17 additions & 0 deletions .werks/17500.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
[//]: # (werk v2)
# Custom & forecast graphs: Fix editing of foreign, non-public graphs

key | value
---------- | ---
date | 2025-01-07T12:40:14+00:00
version | 2.3.0p25
class | fix
edition | cee
component | multisite
level | 1
compatible | yes

Users with the permissions "Edit foreign custom/forecast graphs" can edit custom/forecast graphs
owned by other users, even if they haven't been published. However, attempting to edit the design
(custom graph)/the model (forecast graph) of an unpublished custom/forecast graph owned by another
user resulted in the error message "No graph with the ID ...".
7 changes: 4 additions & 3 deletions cmk/gui/pagetypes.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@
from cmk.gui.htmllib.generator import HTMLWriter
from cmk.gui.htmllib.header import make_header
from cmk.gui.htmllib.html import html
from cmk.gui.http import request
from cmk.gui.http import request, response
from cmk.gui.i18n import _, _l, _u
from cmk.gui.logged_in import LoggedInUser, save_user_file, user
from cmk.gui.main_menu import mega_menu_registry
Expand Down Expand Up @@ -1785,8 +1785,9 @@ def ajax_add_element(cls) -> None:
if target_page:
if not isinstance(target_page, str):
target_page = target_page.page_url()
html.write_text(target_page)
html.write_text("\n%s" % ("true" if need_sidebar_reload else "false"))

response.set_content_type("text/plain")
response.set_data(f"{target_page or ""}\n{"true" if need_sidebar_reload else "false"}")

# Default implementation for generic containers - used e.g. by GraphCollection
@classmethod
Expand Down

0 comments on commit 8f70d27

Please sign in to comment.