nedm-socket(7) "Version 3.0.1" "NEDM Manual" # NAME *nedm-socket* NEDM socket # SYNOPSIS *ipc-socket-capable-tool \$NEDM_SOCKET* # DESCRIPTION The nedm socket is an ipc socket. The socket is enabled if nedm is invoked with the `-e` flag. The socket accepts nedm commands as input (see *nedm-config(5)* for more information). Events are provided as output as specified in this man page. ## EVENTS Events have a general structure as follows: ``` "cg-ipc"json object depending on the eventNULL ``` Here is an example of how this works using *only* as a command sent over the socket. ``` only cg-ipc{"event_name":"fullscreen", "tile_id":2, "workspace":1, "output":"eDP-1"} ``` This documentation describes the trigger for the events, the keys and the data type of the values of each event. *background* - Trigger: *background* command - JSON - event_name: "background" - old_bg: list of three floating point numbers denoting the old background in rgb - new_bg: list of three floating point numbers denoting the new background in rgb ``` background 0 1.0 0 cg-ipc{"event_name":"background", "old_bg":[0.000000,1.000000,1.000000], "new_bg":[0.000000,1.000000,0.000000]} ``` *close* - Trigger: *close* command - JSON - event_name: "close" - view_id: view id as an integer - tile_id: tile id as an integer - view_pid: pid of the process - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer ``` close cg-ipc{"event_name":"close", "view_id":47, "view_pid":30456, "tile_id":47, "workspace":1, "output":"eDP-1", "output_id":1} ``` *configure_input* - Trigger: *input* command - JSON - event_name: "configure_input" - input: the input as a string, as per cagebreak-config(5) ``` input * accel_profile flat cg-ipc{"event_name":"configure_input","input":"*"} ``` *configure_message* - Trigger: *configure_message* command - JSON - event_name: "configure_message" ``` configure_message fg_color 1.0 1.0 0 0 cg-ipc{"event_name":"configure_message"} ``` *configure_output* - Trigger: *output* command - JSON - event_name: "configure_output" - output: name of the output as a string - output_id: id of the output as an integer ``` output eDP-1 rotate 0 cg-ipc{"event_name":"configure_output","output":"eDP-1","output_id":1} ``` *cursor_switch_tile* - Trigger: Cursor crosses the border between tiles - JSON - event_name: "cursor_switch_tile" - old_output: name of the old output as a string - old_output_id: old output id as an integer - old_tile: number of the old tile as an integer - new_output: name of the new output as a string - new_output_id: new output id as an integer - new_tile: number of the new tile as an integer ``` # Cursor switches tile cg-ipc{"event_name":"cursor_switch_tile", "old_output":"eDP-1", "old_output_id":1, "old_tile":2, "new_output":"eDP-1", "new_output_id":1, "new_tile":3} ``` *custom_event* - Trigger: NEDM receives the *custom_event* command, either in the config file or via the IPC socket (see *nedm-config(5)*). - JSON - event_name: "custom_event" - message: The message passed to the *custom_event* command ``` custom_event Hello World! cg-ipc{"event_name":"custom_event","message":"Hello World!"} ``` *cycle_outputs* - Trigger: *nextscreen* and *prevscreen* commands - JSON - event_name: "cycle_outputs" - old_output: old output name as string - old_output_id: old output id as an integer - new_output: new output name as string - new_output_id: new output id as an integer - reverse: "0" if *nextscreen* or "1" if *prevscreen* ``` nextscreen cg-ipc{"event_name":"cycle_outputs", "old_output":"eDP-1", "old_output_id":1, "new_output":"HDMI-A-1", "new_output_id":2, "reverse":0} ``` *cycle_views* - Trigger: *next* and *prev* commands - JSON - event_name: "cycle_views" - old_view_id: old view id as an integer - old_view_pid: pid of old view - new_view_id: new view id as an interger - new_view_pid: pid of new view - tile_id: tile id as an integer - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer ``` next cg-ipc{"event_name":"cycle_views", "old_view_id":11, "old_view_pid":32223, "new_view_id":4, "old_view_pid";53221, "tile_id":13, "workspace":1, "output":"eDP-1", "output_id":1} ``` *definekey* - Trigger: *definekey* command - JSON - event_name: "definekey" - modifiers: number denoting the modifier as described below - 0: no modifier - 1: shift - 2: alt - 3: ctrl - 4: logo key - 5: modifier 2 - 6: modifier 3 - 7: modifier 5 - key: key as a number - command: command as a string - CAVEAT: This is an internal representation of commands which is not in one-to-one correspondance with the commands available in the config file. The differences are as follows: - "cycle_tiles": represents any *exchange* command (e.g. *exchangeright*) - "cycle_views": represents both the *next* and the *prev* command - "cycle_outputs": represents *nextscreen*, *movetoprevscreen* and *prevscreen* commands - "resize_tile_vertical": represents *resizedown* and *resizeup* commands - "resize_tile_horizontal": represents *resizeleft* and *resizeright* commands ``` definemode foo cg-ipc{"event_name":"definemode","mode":"foo"} definekey foo e only cg-ipc{"event_name":"definekey","modifiers":0,"key":101,"command":"only"} ``` *definemode* - Trigger: *definemode* command - JSON - event_name: "definemode" - mode: name of mode as string ``` definemode foo cg-ipc{"event_name":"definemode","mode":"foo"} ``` *destroy_output* - Trigger: removal of an output - JSON - event_name: "destroy_output" - output: name of the output as a string - output_id: id of the output as an integer ``` # remove output from the device cg-ipc{"event_name":"destroy_output","output":"HDMI-A-1","output_id":2} ``` *dump* - Trigger: *dump* command - JSON - event_name: "dump" - nws: number of workspaces as an integer - bg_color: list of three floating point numbers denoting the new background in rgb - views_curr_id: id of the currently focussed view as an integer - tiles_curr_id: id of the currently focussed tile as in integer - curr_output: current output as a string - default_mode: name of the default mode as a string - modes: list of names of modes as strings - message_config: the current configuration of the cagebreak messages - font: the font used to display the messages - display_time: the duration in seconds that the cagebreak messages are displayed - bg_color: list of four floating point numbers denoting the background color in rgba - fg_color: list of four floating point numbers denoting the foreground color in rgba - anchor: the positioning of the messages on the screen (see *nedm-config(5)* for more information) - outputs: object of objects for each output - output name as string - priority: priority as per *output* prio in *nedm-config(5)* or default - coords: object of x and y coordinates of output - size: object of width and height as integers - refresh_rate: refresh rate as float - permanent: 0 if peripheral, 1 if permanent - active: 1 if the output is active, 0 if not - curr_workspace: current workspace as an integer - workspaces: list of objects for each workspace - views: list of objects for each view - id: view id as an integer - pid: pid of the process which opened the view as an integer - coords: object of x and y coordinates - type: ["xdg"|"xwayland"] - tiles: list of objects for all tiles - id: tile id as an integer - coords: object of x and y coordinates - size: object of width and height - view: view id as an integer - keyboards: object of objects for each keyboard group - keyboard name as a string - commands_enabled: 0 if keybindings are disabled for the keyboard, 1 otherwise - repeat_delay: repeat delay in milliseconds as an integer - repeat_rate: repeat rate in 1/sec as an integer - input_devices: object of objects for each keyboard - identifier for a keyboard as a string - is_virtual: 1 if virtual, 0 otherwise - type: [keyboard|pointer|switch] - cursor_coords: object of x and y coordinates ``` dump cg-ipc{"event_name":"dump","nws":1, "bg_color":[0.000000,0.000000,0.000000], "views_curr_id":80, "tiles_curr_id":8, "curr_output":"eDP-1", "default_mode":"top", "modes":["top","root","resize"], "message_config": {"font": "pango:Monospace 10", "display_time": 2, "bg_color": [0.900000,0.850000,0.850000,1.000000], "fg_color": [0.000000,0.000000,0.000000,1.000000], "anchor": "top_right" },"outputs": {"eDP-1": { "priority": -1, "coords": {"x":0,"y":0}, "size": {"width":2560,"height":1440}, "refresh_rate": 60.012000, "permanent": 0, "active": 1, "curr_workspace": 0, "workspaces": [{"views": [{ "id": 16, "pid": 2505, "coords": {"x":0,"y":0}, "type": "xwayland" },{ "id": 72, "pid": 11243, "coords": {"x":0,"y":0}, "type": "xdg" },{ "id": 56, "pid": 6700, "coords": {"x":1280,"y":0}, "type": "xdg" }],"tiles": [{ "id": 6, "coords": {"x":0,"y":0}, "size": {"width":1280,"height":1440}, "view": 78 },{ "id": 7, "coords": {"x":1280,"y":0}, "size": {"width":1280,"height":1440}, "view": 42 }]}] }} ,"keyboards": {"0:1:Power_Button": { "commands_enabled": 1, "repeat_delay": 600, "repeat_rate": 25 }} ,"input_devices": {"6058:20564:ThinkPad_Extra_Buttons": { "is_virtual": 0, "type": "switch", },"6058:20564:ThinkPad_Extra_Buttons": { "is_virtual": 0, "type": "keyboard", },"2:10:TPPS/2_Elan_TrackPoint": { "is_virtual": 0, "type": "pointer", },"1:1:AT_Translated_Set_2_keyboard": { "is_virtual": 0, "type": "keyboard", },"0:0:sof-hda-dsp_Headphone": { "is_virtual": 0, "type": "keyboard", },"1739:52619:SYNA8004:00_06CB:CD8B_Touchpad": { "is_virtual": 0, "type": "pointer", },"1739:52619:SYNA8004:00_06CB:CD8B_Mouse": { "is_virtual": 0, "type": "pointer", },"0:3:Sleep_Button": { "is_virtual": 0, "type": "keyboard", },"0:5:Lid_Switch": { "is_virtual": 0, "type": "switch", },"0:6:Video_Bus": { "is_virtual": 0, "type": "keyboard", },"0:1:Power_Button": { "is_virtual": 0, "type": "keyboard", }} ,"cursor_coords":{"x":972.821761,"y":670.836215} } ``` *focus_tile* - Trigger: *focus* command - JSON - event_name: "focus_tile" - old_tile_id: old tile id as an integer - new_tile_id: new tile id as an integer - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer ``` focus cg-ipc{"event_name":"focus_tile", "old_tile_id":14, "new_tile_id":13, "workspace":1, "output":"eDP-1", "output_id":1} ``` *fullscreen* - Trigger: *only* command - JSON - event_name: "fullscreen" - tile_id: tile id as an integer - workspace: workspace number as an integer - output: output as a string - output_id: id of the output as an integer ``` only cg-ipc{"event_name":"fullscreen", "tile_id":3, "workspace":1, "output":"eDP-1", "output_id":1} ``` *move_view_to_cycle_output* - Trigger: *movetonextscreen* and similar commands - JSON - event_name: "move_view_to_cycle_output" - view_id: view id as an integer - view_pid: pid of the process - old_output: name of the old output as a string - old_output_id: old output id as an integer - new_output: name of the new output as a string - old_output_id: old output id as an integer ``` movetonextscreen cg-ipc{"event_name":"cycle_outputs", "old_output":"eDP-1", "new_output":"HDMI-A-1", "reverse":0} cg-ipc{"event_name":"move_view_to_cycle_output", "view_id":11, "view_pid":43123, "old_output":"eDP-1", "old_output_id":1, "new_output":"HDMI-A-1", "new_output_id":2} ``` *move_view_to_output* - Trigger: *movetoscreen* command - JSON - event_name: "move_view_to_output" - view_id: view id as an integer - old_output: old output name as string - new_output: new output name as string ``` movetoscreen 2 cg-ipc{"event_name":"switch_output", "old_output":"eDP-1", "new_output":"HDMI-A-1"} cg-ipc{"event_name":"move_view_to_output", "view_id":78, "old_output":"eDP-1", "new_output":"HDMI-A-1"} ``` *move_view_to_ws* - Trigger: *movetoworkspace* command - JSON - event_name: "move_view_to_ws" - view_id: view id as an integer - old_workspace: old workspace number as an integer - new_workspace: new workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer - view_pid: pid of the process ``` movetoworkspace 1 cg-ipc{"event_name":"switch_ws", "old_workspace":1, "new_workspace":1, "output":"eDP-1"} cg-ipc{"event_name":"move_view_to_ws", "view_id":43, "old_workspace":0, "new_workspace":0, "output":"eDP-1", "output_id":1, "view_pid":64908} ``` *new_output* - Trigger: a new output is physically attached - JSON - event_name: "new_output" - output: new output name as a string - output_id: id of the new output as an integer - priority: priority as per *output* prio in *nedm-config(5)* or default ``` # a new output is attached cg-ipc{"event_name":"new_output","output":"HDMI-A-1","output_id":2,"priority":-1} ``` *resize_tile* - Trigger: the *resize* family of commands - JSON - event_name: "resize_tile" - tile_id: tile id as an integer - old_dims: list of coordinates [x coordinate of lower left corner, y coordinate of lower left corner, x coordinate of upper right corner, y coordinate of upper right corner] - new_dims: list of coordinate [x coordinate of lower left corner, y coordinate of lower left corner, x coordinate of upper right corner, y coordinate of upper right corner] - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer ``` resizeleft cg-ipc{"event_name":"resize_tile", "tile_id":14, "old_dims":"[1280,0,1440,1280]", "new_dims":"[1270,0,1440,1290]", "workspace":1,"output":"eDP-1", "output_id":1} cg-ipc{"event_name":"resize_tile", "tile_id":13, "old_dims":"[0,0,1440,1280]", "new_dims":"[0,0,1440,1270]", "workspace":1, "output":"eDP-1", "output_id":1} ``` *set_nws* - Trigger: *workspaces* command - JSON - event_name: "set_nws" - old_nws: old number of workspaces as an integer - new_nws: new number of workspaces as an integer ``` workspaces 2 cg-ipc{"event_name":"set_nws","old_nws":1,"new_nws":2} ``` *split* - Trigger: *split* command - JSON - event_name: "split" - tile_id: old tile id as an integer - new_tile_id: new tile id as an integer - workspace: workspace number as an integer - output: output as a string - output_id: id of the output as an integer - vertical: 0 if horizontal split, 1 if not ``` hsplit cg-ipc{"event_name":"split", "tile_id":11, "new_tile_id":12, "workspace":1, "output":"eDP-1", "output_id":1, "vertical":0} ``` *swap_tile* - Trigger: the *exchange* family of commands - JSON - event_name: "swap_tile" - tile_id: previous tile id as an integer - tile_pid: pid of previous tile - swap_tile_id: swap tile id as an integer - swap_tile_pid: pid of swap tile - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer ``` exchangeright cg-ipc{"event_name":"swap_tile", "tile_id":1, "tile_pid":53478, "swap_tile_id":3, "swap_tile_pid":98234, "workspace":1, "output":"eDP-1"} ``` *switch_default_mode* - Trigger: *setmode* command - JSON - event_name: "switch_default_mode" - old_mode: old mode name - mode: new mode name ``` setmode top cg-ipc{"event_name":"switch_default_mode","old_mode":"top","mode":"root"} ``` switch_output - Trigger. *screen* command - JSON - event_name: "switch_output" - old_output: name of the old output as a string - old_output_id: old output id as an integer - new_output: name of the new output as a string - new_output_id: new output id as an integer ``` screen 2 cg-ipc{"event_name":"switch_output", "old_output":"eDP-1", "old_output_id":1, "new_output":"HDMI-A-1", "new_output_id":2} ``` switch_ws - Trigger: *workspace* command - JSON - event_name: "switch_ws" - old_workspace: old workspace number as an integer - new_workspace: new workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer ``` workspace 2 cg-ipc{"event_name":"switch_ws", "old_workspace":1, "new_workspace":2, "output":"eDP-1", "output_id":1} ``` *view_map* - Trigger: view is opened by a process - JSON - event_name: "view_map" - view_id: view id as an integer - tile_id: tile id as an integer - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer - view_pid: pid of the process ``` # process opens a view cg-ipc{"event_name":"view_map", "view_id":28, "tile_id":14, "workspace":1, "output":"eDP-1", "output_id":1, "view_pid":39827} ``` *view_unmap* - Trigger: view is closed by a process - JSON - event_name: "view_unmap" - view_id: view id as an integer - tile_id: tile id as an integer - workspace: workspace number as an integer - output: name of the output as a string - output_id: id of the output as an integer - view_pid: pid of the process ``` # view is closed by the process cg-ipc{"event_name":"view_unmap", "view_id":24, "tile_id":13, "workspace":1, "output":"eDP-1", "output_id":1, "view_pid":39544} ``` ## SECURITY The socket has to be explicitly enabled using the `-e` flag. The socket is restricted to the user for reading, writing and execution (700). All user software can execute arbitrary code while the nedm socket is running. ## EXAMPLES *nc -U $NEDM_SOCKET* *ncat -U $NEDM_SOCKET* # SEE ALSO *nedm(1)* *nedm-config(5)* # BUGS See GitHub Issues: Mail contact: `nedm @ project-repo . co` GPG Fingerprints: - 0A268C188D7949FEB39FD1462F2AD980247E4918 - 283D10F54201B0C6CCEE2C561DE04E4B056C749D # LICENSE Copyright (c) 2022 - 2024 The NEDM authors Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.