diff options
author | Sébastien Helleu <flashcode@flashtux.org> | 2024-05-16 07:45:02 +0200 |
---|---|---|
committer | Sébastien Helleu <flashcode@flashtux.org> | 2024-05-16 07:45:02 +0200 |
commit | 47f40f961a6ae86130428adfd413ea93e2377717 (patch) | |
tree | 464d50cf28313e48580858ac82ae86c7ed488123 /src | |
parent | 1100b0e69497e9714c8119b2a7b6ca1f13d27616 (diff) | |
download | weechat-47f40f961a6ae86130428adfd413ea93e2377717.zip |
relay/remote: add, update and remove buffer local variables received from remote
Diffstat (limited to 'src')
-rw-r--r-- | src/plugins/relay/api/remote/relay-remote-event.c | 111 |
1 files changed, 109 insertions, 2 deletions
diff --git a/src/plugins/relay/api/remote/relay-remote-event.c b/src/plugins/relay/api/remote/relay-remote-event.c index caed639e9..60de6f88c 100644 --- a/src/plugins/relay/api/remote/relay-remote-event.c +++ b/src/plugins/relay/api/remote/relay-remote-event.c @@ -467,6 +467,69 @@ error: } /* + * Checks if a local variable received in JSON object "local_variables" can + * be used. + * + * The following variables are ignored and must NOT be used: + * - "plugin": contains the plugin name + * - "name": contains the buffer name + * - "relay_remote*": variables reserved for relay remote (in case of nested + * remotes, the variables are not propagated) + * + * Returns: + * 1: variable can be used + * 0: variable must NOT be used (reserved) + */ + +int +relay_remote_event_check_local_var (const char *name) +{ + if (!name) + return 0; + + return ((strcmp (name, "plugin") != 0) + && (strcmp (name, "name") != 0) + && (strncmp (name, "relay_remote", 12) != 0)) ? + 1 : 0; +} + +/* + * Remove local variables in buffer that are not in the JSON object + * "local_variables". + */ + +void +relay_remote_event_remove_localvar_cb (void *data, + struct t_hashtable *hashtable, + const void *key, + const void *value) +{ + void **pointers; + struct t_gui_buffer *buffer; + cJSON *json; + char str_local_var[1024]; + + /* make C compiler happy */ + (void) hashtable; + (void) value; + + pointers = (void **)data; + buffer = pointers[0]; + json = pointers[1]; + + if (!relay_remote_event_check_local_var (key)) + return; + + if (!cJSON_GetObjectItem (json, key)) + { + /* local variable removed on remote? => remove it locally */ + snprintf (str_local_var, sizeof (str_local_var), + "localvar_del_%s", (const char *)key); + weechat_buffer_set (buffer, str_local_var, ""); + } +} + +/* * Callback for a buffer event or response to GET /api/buffers. */ @@ -475,11 +538,13 @@ RELAY_REMOTE_EVENT_CALLBACK(buffer) struct t_gui_buffer *ptr_buffer; struct t_hashtable *buffer_props; struct t_relay_remote_event event_line; + struct t_hashtable *local_variables; cJSON *json_obj, *json_keys, *json_key, *json_key_name, *json_key_command; - cJSON *json_lines, *json_line, *json_nicklist_root; + cJSON *json_vars, *json_var, *json_lines, *json_line, *json_nicklist_root; + void *pointers[2]; const char *name, *short_name, *type, *title, *modes, *input_prompt, *input; const char *ptr_key, *ptr_command; - char *full_name, str_number[64], *property; + char *full_name, str_number[64], str_local_var[1024], *property; long long id; int number, nicklist, nicklist_case_sensitive, nicklist_display_groups; int apply_props, input_position, input_multiline; @@ -574,6 +639,48 @@ RELAY_REMOTE_EVENT_CALLBACK(buffer) &relay_remote_event_apply_props, ptr_buffer); } + json_vars = cJSON_GetObjectItem (event->json, "local_variables"); + if (json_vars && cJSON_IsObject (json_vars)) + { + if (weechat_strcmp (event->name, "buffer_localvar_removed") == 0) + { + /* + * we don't know which variables have been removed, so we remove any + * local variable in the buffer that is not defined in the JSON + * object "local_variables" received + */ + pointers[0] = ptr_buffer; + pointers[1] = json_vars; + local_variables = weechat_hdata_pointer (relay_hdata_buffer, + ptr_buffer, + "local_variables"); + if (local_variables) + { + weechat_hashtable_map (local_variables, + &relay_remote_event_remove_localvar_cb, + pointers); + } + } + else + { + /* add/update local variables */ + cJSON_ArrayForEach (json_var, json_vars) + { + if (json_var->string + && cJSON_IsString (json_var) + && relay_remote_event_check_local_var (json_var->string)) + { + snprintf (str_local_var, sizeof (str_local_var), + "localvar_set_%s", + json_var->string); + weechat_buffer_set (ptr_buffer, + str_local_var, + cJSON_GetStringValue (json_var)); + } + } + } + } + /* add keys */ json_keys = cJSON_GetObjectItem (event->json, "keys"); if (json_keys && cJSON_IsArray (json_keys)) |