Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

User Annotation Improvements #182

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open

Conversation

jacdavi
Copy link
Contributor

@jacdavi jacdavi commented May 30, 2024

This adds a few features in the UI for making notes and customizing the way a VM appears in the SOH graph. The intent is to make it easier for users to track/manage the status of VMs within an experiment (e.g., a user may mark a node red and add a note "reached by red team")

  • Adds a new modal for viewing/editing the labels of a VM

    • Separate "notes" section that allows multiline, maintains insertion order, and hides key
    • Available in experiment pages and SOH
    • Treats minimega tags and phenix labels as one (meaning persistent across experiment runs, and also available in mm cli)
  • Changes SOH details modal to show notes at the top

    • Adds buttons to edit labels and override style
    • New style modal lets user override the fill color, stroke color, and stroke style of a node. This takes precedence over any default styling

labels_modal
style_modal

@activeshadow
Copy link
Collaborator

Thanks @jacdavi, I'll take a look at this ASAP. Looks cool!

@jacdavi
Copy link
Contributor Author

jacdavi commented Jun 7, 2024

Thanks @jacdavi, I'll take a look at this ASAP. Looks cool!

Sounds good. There's one more PR coming soon. No rush on any of them since we have everything in an internal fork. Thanks!

@activeshadow
Copy link
Collaborator

@jacdavi I squashed and rebased this branch on top of the latest main (which has PR #181 merged in) and everything is compiling fine. However, notes and tags are not getting added for VMs and I'm not sure why. I took a cursory look at the code and I'm not noticing anything obvious but I haven't tried attaching a debugger to follow along in real time. Can you take a look when you have time?

Also, I'm wondering if it wouldn't make sense to use an annotation for notes instead of a special tag name. Annotation values can be whatever type you want them to be, so they could be an array of strings for example, or a map with the date of the note as the key and the text as the value. Just a thought.

This adds a few features in the UI for making notes and customizing the
way a VM appears in the SOH graph. The intent is to make it easier for
users to track/manage the status of VMs within an experiment (e.g., a
user may mark a node red and add a note "reached by red team").

* Adds a new modal for viewing/editing the labels of a VM
  * Separate "notes" section that allows multiline, maintains insertion
    order, and hides key
  * Available in experiment pages and SOH
  * Treats minimega tags and phenix labels as one (meaning persistent
    across experiment runs, and also available in mm cli)

* Changes SOH details modal to show notes at the top
  * Adds buttons to edit labels and override style
  * New style modal lets user override the fill color, stroke color, and
    stroke style of a node. This takes precedence over any default
    styling
@jacdavi
Copy link
Contributor Author

jacdavi commented Oct 4, 2024

@activeshadow sorry I was OOO for a few days, but appreciate the help! I took a look and it was just that the backend was expecting tag_update_mode in the update json, but the frontend was using the key tagUpdateMode.

For annotations/labels it's been a while, so I don't remember the exact differences. I know one feature that was requested was being able to see everything as tags in minimega, so I believe the drove the use of labels since those were already getting copied over.

@activeshadow
Copy link
Collaborator

For annotations/labels it's been a while, so I don't remember the exact differences. I know one feature that was requested was being able to see everything as tags in minimega, so I believe the drove the use of labels since those were already getting copied over.

@jacdavi I'm curious what a note looks like as a tag in minimega, especially when it's a long note? I can deploy and test myself, just curious if you might have an example already.

@jacdavi
Copy link
Contributor Author

jacdavi commented Dec 9, 2024

For annotations/labels it's been a while, so I don't remember the exact differences. I know one feature that was requested was being able to see everything as tags in minimega, so I believe the drove the use of labels since those were already getting copied over.

@jacdavi I'm curious what a note looks like as a tag in minimega, especially when it's a long note? I can deploy and test myself, just curious if you might have an example already.

Yeah not particularly great, but useable.

Here's vm info with a filter showing you can search by tag

minimega:/tmp/minimega/minimega$ .filter tag=multiple vm info
host      | id | name | state   | uptime          | type | uuid                                 | cc_active | pid    | vlan          | bridge   | tap         | mac                 | ip          | ip6 | qos | qinq | bond | memory | vcpus | disks                                                                     | snapshot | initrd | kernel | cdrom | migrate | append | serial-ports | virtio-ports | vnc_port | usb-use-xhci | tpm-socket | bidirectional-copy-paste | filesystem | hostname | init | preinit | fifo | volume | console_port | tags
ccc19.40g | 0  | AD01 | RUNNING | 3m30.033506836s | kvm  | 906900fc-c70d-43dc-b242-30ee0f484c3f | true      | 805868 | [admin (101)] | [phenix] | [mega_tap0] | [mac] | [ip] | []  | []  | []   | []   | 8192   | 4     | image,writeback | true     |        |        |       |         | []     | 0            |              | port    | true         |            | false                    | N/A        | N/A      | N/A  | N/A     | N/A  | N/A    | N/A          | {"__notes_2024-12-09T20:13:17.829Z":"note #1","__notes_2024-12-09T20:13:25.910Z":"A much longer note with many filler words to make it long","__notes_2024-12-09T20:13:37.749Z":"A note that has multiple\nlines of text which probably won't\nlook great in minimega","labelkey":"labelvalue"}

And here's the output of vm tags. Realizing I probably need to update minimega to prevent newlines, but that would be an existing bug

minimega:/tmp/minimega/minimega$ vm tag AD01
host      | name | tag                              | value
ccc19.40g | AD01 | __notes_2024-12-09T20:13:17.829Z | note #1
ccc19.40g | AD01 | __notes_2024-12-09T20:13:25.910Z | A much longer note with many filler words to make it long
ccc19.40g | AD01 | __notes_2024-12-09T20:13:37.749Z | A note that has multiple
lines of text which probably won't
look great in minimega
ccc19.40g | AD01 | labelkey | labelvalue

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants