From 23e886ed5eb7fd8d53239aaf5d6266a08b01156a Mon Sep 17 00:00:00 2001 From: DebXWoody Date: Sat, 16 Oct 2021 08:43:55 +0200 Subject: [PATCH 1/5] Add xep-0107: User Mood support Implementation of XEP 0107 - User Mood --- src/command/cmd_ac.c | 114 ++++++++++++++++++++++++++++++++++++++++ src/command/cmd_defs.c | 13 +++++ src/command/cmd_funcs.c | 15 ++++++ src/command/cmd_funcs.h | 1 + src/xmpp/iq.c | 52 ++++++++++++++++++ src/xmpp/message.c | 9 +++- src/xmpp/session.c | 35 ++++++++++++ src/xmpp/xmpp.h | 2 + 8 files changed, 240 insertions(+), 1 deletion(-) diff --git a/src/command/cmd_ac.c b/src/command/cmd_ac.c index ee0f717e..475d02ff 100644 --- a/src/command/cmd_ac.c +++ b/src/command/cmd_ac.c @@ -129,6 +129,7 @@ static char* _url_autocomplete(ProfWin* window, const char* const input, gboolea static char* _executable_autocomplete(ProfWin* window, const char* const input, gboolean previous); static char* _lastactivity_autocomplete(ProfWin* window, const char* const input, gboolean previous); static char* _intype_autocomplete(ProfWin* window, const char* const input, gboolean previous); +static char* _mood_autocomplete(ProfWin* window, const char* const input, gboolean previous); static char* _script_autocomplete_func(const char* const prefix, gboolean previous, void* context); @@ -269,6 +270,8 @@ static Autocomplete avatar_ac; static Autocomplete url_ac; static Autocomplete executable_ac; static Autocomplete intype_ac; +static Autocomplete mood_ac; +static Autocomplete mood_type_ac; /*! * \brief Initialization of auto completion for commands. @@ -1057,6 +1060,90 @@ cmd_ac_init(void) intype_ac = autocomplete_new(); autocomplete_add(intype_ac, "console"); autocomplete_add(intype_ac, "titlebar"); + + mood_ac = autocomplete_new(); + autocomplete_add(mood_ac, "set"); + mood_type_ac = autocomplete_new(); + autocomplete_add(mood_type_ac, "afraid"); + autocomplete_add(mood_type_ac, "amazed"); + autocomplete_add(mood_type_ac, "angry"); + autocomplete_add(mood_type_ac, "amorous"); + autocomplete_add(mood_type_ac, "annoyed"); + autocomplete_add(mood_type_ac, "anxious"); + autocomplete_add(mood_type_ac, "aroused"); + autocomplete_add(mood_type_ac, "ashamed"); + autocomplete_add(mood_type_ac, "bored"); + autocomplete_add(mood_type_ac, "brave"); + autocomplete_add(mood_type_ac, "calm"); + autocomplete_add(mood_type_ac, "cautious"); + autocomplete_add(mood_type_ac, "cold"); + autocomplete_add(mood_type_ac, "confident"); + autocomplete_add(mood_type_ac, "confused"); + autocomplete_add(mood_type_ac, "contemplative"); + autocomplete_add(mood_type_ac, "contented"); + autocomplete_add(mood_type_ac, "cranky"); + autocomplete_add(mood_type_ac, "crazy"); + autocomplete_add(mood_type_ac, "creative"); + autocomplete_add(mood_type_ac, "curious"); + autocomplete_add(mood_type_ac, "dejected"); + autocomplete_add(mood_type_ac, "depressed"); + autocomplete_add(mood_type_ac, "disappointed"); + autocomplete_add(mood_type_ac, "disgusted"); + autocomplete_add(mood_type_ac, "dismayed"); + autocomplete_add(mood_type_ac, "distracted"); + autocomplete_add(mood_type_ac, "embarrassed"); + autocomplete_add(mood_type_ac, "envious"); + autocomplete_add(mood_type_ac, "excited"); + autocomplete_add(mood_type_ac, "flirtatious"); + autocomplete_add(mood_type_ac, "frustrated"); + autocomplete_add(mood_type_ac, "grumpy"); + autocomplete_add(mood_type_ac, "guilty"); + autocomplete_add(mood_type_ac, "happy"); + autocomplete_add(mood_type_ac, "hopeful"); + autocomplete_add(mood_type_ac, "hot"); + autocomplete_add(mood_type_ac, "humbled"); + autocomplete_add(mood_type_ac, "humiliated"); + autocomplete_add(mood_type_ac, "hungry"); + autocomplete_add(mood_type_ac, "hurt"); + autocomplete_add(mood_type_ac, "impressed"); + autocomplete_add(mood_type_ac, "in_awe"); + autocomplete_add(mood_type_ac, "in_love"); + autocomplete_add(mood_type_ac, "indignant"); + autocomplete_add(mood_type_ac, "interested"); + autocomplete_add(mood_type_ac, "intoxicated"); + autocomplete_add(mood_type_ac, "invincible"); + autocomplete_add(mood_type_ac, "jealous"); + autocomplete_add(mood_type_ac, "lonely"); + autocomplete_add(mood_type_ac, "lucky"); + autocomplete_add(mood_type_ac, "mean"); + autocomplete_add(mood_type_ac, "moody"); + autocomplete_add(mood_type_ac, "nervous"); + autocomplete_add(mood_type_ac, "neutral"); + autocomplete_add(mood_type_ac, "offended"); + autocomplete_add(mood_type_ac, "outraged"); + autocomplete_add(mood_type_ac, "playful"); + autocomplete_add(mood_type_ac, "proud"); + autocomplete_add(mood_type_ac, "relaxed"); + autocomplete_add(mood_type_ac, "relieved"); + autocomplete_add(mood_type_ac, "remorseful"); + autocomplete_add(mood_type_ac, "restless"); + autocomplete_add(mood_type_ac, "sad"); + autocomplete_add(mood_type_ac, "sarcastic"); + autocomplete_add(mood_type_ac, "serious"); + autocomplete_add(mood_type_ac, "shocked"); + autocomplete_add(mood_type_ac, "shy"); + autocomplete_add(mood_type_ac, "sick"); + autocomplete_add(mood_type_ac, "sleepy"); + autocomplete_add(mood_type_ac, "spontaneous"); + autocomplete_add(mood_type_ac, "stressed"); + autocomplete_add(mood_type_ac, "strong"); + autocomplete_add(mood_type_ac, "surprised"); + autocomplete_add(mood_type_ac, "thankful"); + autocomplete_add(mood_type_ac, "thirsty"); + autocomplete_add(mood_type_ac, "tired"); + autocomplete_add(mood_type_ac, "undefined"); + autocomplete_add(mood_type_ac, "weak"); + autocomplete_add(mood_type_ac, "worried"); } void @@ -1372,6 +1459,7 @@ cmd_ac_reset(ProfWin* window) autocomplete_reset(url_ac); autocomplete_reset(executable_ac); autocomplete_reset(intype_ac); + autocomplete_reset(mood_ac); autocomplete_reset(script_ac); if (script_show_ac) { @@ -1801,6 +1889,7 @@ _cmd_ac_complete_params(ProfWin* window, const char* const input, gboolean previ g_hash_table_insert(ac_funcs, "/executable", _executable_autocomplete); g_hash_table_insert(ac_funcs, "/lastactivity", _lastactivity_autocomplete); g_hash_table_insert(ac_funcs, "/intype", _intype_autocomplete); + g_hash_table_insert(ac_funcs, "/mood", _mood_autocomplete); int len = strlen(input); char parsed[len + 1]; @@ -4147,3 +4236,28 @@ _intype_autocomplete(ProfWin* window, const char* const input, gboolean previous result = autocomplete_param_with_ac(input, "/intype", intype_ac, FALSE, previous); return result; } + +static char* +_mood_autocomplete(ProfWin* window, const char* const input, gboolean previous) +{ + char* result = NULL; + + result = autocomplete_param_with_ac(input, "/mood", status_ac, TRUE, previous); + if (result) { + return result; + } + + //jabber_conn_status_t conn_status = connection_get_status(); + //if (conn_status == JABBER_CONNECTED) { + result = autocomplete_param_with_ac(input, "/mood set", mood_type_ac, FALSE, previous); + if (result) { + return result; + } + + // result = autocomplete_param_with_func(input, "/mood get", roster_barejid_autocomplete, previous, NULL); + // if (result) { + // return result; + // } + //} + return result; +} diff --git a/src/command/cmd_defs.c b/src/command/cmd_defs.c index 7bc4a1ff..fc4c8dca 100644 --- a/src/command/cmd_defs.c +++ b/src/command/cmd_defs.c @@ -2679,6 +2679,19 @@ static struct cmd_t command_defs[] = { "/register someuser my.xmppserv.er port 5443 tls force") }, + { "/mood", + parse_args, 2, 3, NULL, + CMD_NOSUBFUNCS + CMD_MAINFUNC(cmd_mood) + CMD_TAGS( + CMD_TAG_CHAT) + CMD_SYN( + "/mood set [\"Text\"]") + CMD_DESC( + "Set your mood") + CMD_NOARGS + CMD_NOEXAMPLES + }, // NEXT-COMMAND (search helper) }; diff --git a/src/command/cmd_funcs.c b/src/command/cmd_funcs.c index 74bbc5e0..5e6b3cc2 100644 --- a/src/command/cmd_funcs.c +++ b/src/command/cmd_funcs.c @@ -9645,3 +9645,18 @@ cmd_register(ProfWin* window, const char* const command, gchar** args) log_info("we are leaving the registration process"); return TRUE; } + +gboolean +cmd_mood(ProfWin* window, const char* const command, gchar** args) +{ + + if (g_strcmp0(args[0], "set") == 0) { + cons_show("Your mood: %s", args[1]); + if (args[2]) { + publish_user_mood(args[1], args[2]); + } else { + publish_user_mood(args[1], args[1]); + } + } + return TRUE; +} diff --git a/src/command/cmd_funcs.h b/src/command/cmd_funcs.h index 5e2a7876..f4cbe0bf 100644 --- a/src/command/cmd_funcs.h +++ b/src/command/cmd_funcs.h @@ -249,5 +249,6 @@ gboolean cmd_editor(ProfWin* window, const char* const command, gchar** args); gboolean cmd_correct_editor(ProfWin* window, const char* const command, gchar** args); gboolean cmd_silence(ProfWin* window, const char* const command, gchar** args); gboolean cmd_register(ProfWin* window, const char* const command, gchar** args); +gboolean cmd_mood(ProfWin* window, const char* const command, gchar** args); #endif diff --git a/src/xmpp/iq.c b/src/xmpp/iq.c index ebc052fc..4d140013 100644 --- a/src/xmpp/iq.c +++ b/src/xmpp/iq.c @@ -2798,3 +2798,55 @@ iq_muc_register_nick(const char* const roomjid) xmpp_stanza_release(iq); xmpp_stanza_release(query); } + +void +publish_user_mood(const char* const mood, const char* const text) +{ + xmpp_ctx_t* const ctx = connection_get_ctx(); + char* id = connection_create_stanza_id(); + + xmpp_stanza_t* iq = xmpp_iq_new(ctx, STANZA_TYPE_SET, id); + + xmpp_stanza_t* pubsub = xmpp_stanza_new(ctx); + xmpp_stanza_set_name(pubsub, "pubsub"); + xmpp_stanza_set_ns(pubsub, "http://jabber.org/protocol/pubsub"); + xmpp_stanza_add_child(iq, pubsub); + + xmpp_stanza_t* publish = xmpp_stanza_new(ctx); + xmpp_stanza_set_name(publish, "publish"); + xmpp_stanza_set_attribute(publish, "node", "http://jabber.org/protocol/mood"); + xmpp_stanza_add_child(pubsub, publish); + + xmpp_stanza_t* item = xmpp_stanza_new(ctx); + xmpp_stanza_set_name(item, "item"); + xmpp_stanza_set_attribute(item, "id", "current"); + xmpp_stanza_add_child(publish, item); + + xmpp_stanza_t* mood_t = xmpp_stanza_new(ctx); + xmpp_stanza_set_name(mood_t, "mood"); + xmpp_stanza_set_ns(mood_t, "http://jabber.org/protocol/mood"); + xmpp_stanza_add_child(item, mood_t); + + xmpp_stanza_t* x = xmpp_stanza_new(ctx); + xmpp_stanza_set_name(x, mood); + xmpp_stanza_add_child(mood_t, x); + + xmpp_stanza_t* text_t = xmpp_stanza_new(ctx); + xmpp_stanza_set_name(text_t, "text"); + xmpp_stanza_add_child(mood_t, text_t); + + xmpp_stanza_t* t = xmpp_stanza_new(ctx); + xmpp_stanza_set_text(t, text); + xmpp_stanza_add_child(text_t, t); + + iq_send_stanza(iq); + + xmpp_stanza_release(iq); + xmpp_stanza_release(pubsub); + xmpp_stanza_release(publish); + xmpp_stanza_release(item); + xmpp_stanza_release(mood_t); + xmpp_stanza_release(x); + xmpp_stanza_release(text_t); + xmpp_stanza_release(t); +} diff --git a/src/xmpp/message.c b/src/xmpp/message.c index 1a964846..17ef979b 100644 --- a/src/xmpp/message.c +++ b/src/xmpp/message.c @@ -161,8 +161,13 @@ _message_handler(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* con } else if (type && g_strcmp0(type, STANZA_TYPE_GROUPCHAT) == 0) { // XEP-0045: Multi-User Chat _handle_groupchat(stanza); + } else if (type && g_strcmp0(type, STANZA_TYPE_HEADLINE) == 0) { - _handle_headline(stanza); + xmpp_stanza_t* event = xmpp_stanza_get_child_by_ns(stanza, STANZA_NS_PUBSUB_EVENT); + if (event) { + _handle_pubsub(stanza, event); + return 1; + } } else if (type == NULL || g_strcmp0(type, STANZA_TYPE_CHAT) == 0 || g_strcmp0(type, STANZA_TYPE_NORMAL) == 0) { // type: chat, normal (==NULL) @@ -247,6 +252,8 @@ _message_handler(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* con if (msg_stanza) { _handle_chat(msg_stanza, FALSE, is_carbon, NULL, NULL); } + } else if (type && g_strcmp0(type, STANZA_TYPE_HEADLINE) == 0) { + _handle_headline(stanza); } else { // none of the allowed types char* text; diff --git a/src/xmpp/session.c b/src/xmpp/session.c index 046d4fd2..a58ab1f7 100644 --- a/src/xmpp/session.c +++ b/src/xmpp/session.c @@ -286,6 +286,38 @@ session_get_account_name(void) return saved_account.name; } +static int _receive_mood(xmpp_stanza_t* const stanza, void* const userdata); + +static int +_receive_mood(xmpp_stanza_t* const stanza, void* const userdata) +{ + const char* from = xmpp_stanza_get_from(stanza); + xmpp_stanza_t* event = xmpp_stanza_get_child_by_name_and_ns(stanza, "event", "http://jabber.org/protocol/pubsub#event"); + if (event) { + xmpp_stanza_t* items = xmpp_stanza_get_child_by_name(event, "items"); + if (items) { + xmpp_stanza_t* item = xmpp_stanza_get_child_by_name(items, "item"); + if (item) { + xmpp_stanza_t* mood = xmpp_stanza_get_child_by_name_and_ns(item, "mood", "http://jabber.org/protocol/mood"); + if (mood) { + xmpp_stanza_t* c = xmpp_stanza_get_children(mood); + if (c) { + const char* m = xmpp_stanza_get_name(c); + xmpp_stanza_t* t = xmpp_stanza_get_child_by_name(mood, "text"); + if (t) { + const char* text = xmpp_stanza_get_text(t); + cons_show("Mood from %s %s (%s)", from, m, text); + } else { + cons_show("Mood from %s %s", from, m); + } + } + } + } + } + } + return TRUE; +} + void session_login_success(gboolean secured) { @@ -330,6 +362,9 @@ session_login_success(gboolean secured) g_timer_destroy(reconnect_timer); reconnect_timer = NULL; } + + message_pubsub_event_handler_add("http://jabber.org/protocol/mood", _receive_mood, NULL, NULL); + caps_add_feature("http://jabber.org/protocol/mood+notify"); } void diff --git a/src/xmpp/xmpp.h b/src/xmpp/xmpp.h index 16293d73..8a2d2eb2 100644 --- a/src/xmpp/xmpp.h +++ b/src/xmpp/xmpp.h @@ -307,4 +307,6 @@ FormField* form_get_field_by_tag(DataForm* form, const char* const tag); Autocomplete form_get_value_ac(DataForm* form, const char* const tag); void form_reset_autocompleters(DataForm* form); +void publish_user_mood(const char* const mood, const char* const text); + #endif From e745b4af60bf9d504abec737babebe0a0f9c5ef8 Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Sun, 17 Oct 2021 00:08:36 +0200 Subject: [PATCH 2/5] tests: add publish_user_mood stub --- tests/unittests/xmpp/stub_xmpp.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/tests/unittests/xmpp/stub_xmpp.c b/tests/unittests/xmpp/stub_xmpp.c index 847ce82a..a01c9930 100644 --- a/tests/unittests/xmpp/stub_xmpp.c +++ b/tests/unittests/xmpp/stub_xmpp.c @@ -426,6 +426,11 @@ iq_muc_register_nick(const char* const roomjid) { } +void +publish_user_mood(const char* const mood, const char* const text) +{ +} + // caps functions void caps_add_feature(char* feature) From 2f3de0eb0da2792e6e4f0cade0acfea5af9ab370 Mon Sep 17 00:00:00 2001 From: DebXWoody Date: Sun, 17 Oct 2021 20:41:11 +0200 Subject: [PATCH 3/5] xep-0107: code review * Remarks in the Merge Request (ac_reset, help) * Defines in iq.c * Mood help and null check * Added additional information about tab key in CMD_DESC. * Added additional null check --- src/command/cmd_ac.c | 8 +------- src/command/cmd_defs.c | 9 ++++++--- src/command/cmd_funcs.c | 13 +++++++------ src/xmpp/iq.c | 16 ++++++++-------- src/xmpp/session.c | 16 +++++++--------- src/xmpp/stanza.h | 4 ++++ 6 files changed, 33 insertions(+), 33 deletions(-) diff --git a/src/command/cmd_ac.c b/src/command/cmd_ac.c index 475d02ff..d817b2ef 100644 --- a/src/command/cmd_ac.c +++ b/src/command/cmd_ac.c @@ -1460,6 +1460,7 @@ cmd_ac_reset(ProfWin* window) autocomplete_reset(executable_ac); autocomplete_reset(intype_ac); autocomplete_reset(mood_ac); + autocomplete_reset(mood_type_ac); autocomplete_reset(script_ac); if (script_show_ac) { @@ -4247,17 +4248,10 @@ _mood_autocomplete(ProfWin* window, const char* const input, gboolean previous) return result; } - //jabber_conn_status_t conn_status = connection_get_status(); - //if (conn_status == JABBER_CONNECTED) { result = autocomplete_param_with_ac(input, "/mood set", mood_type_ac, FALSE, previous); if (result) { return result; } - // result = autocomplete_param_with_func(input, "/mood get", roster_barejid_autocomplete, previous, NULL); - // if (result) { - // return result; - // } - //} return result; } diff --git a/src/command/cmd_defs.c b/src/command/cmd_defs.c index fc4c8dca..4ceb8193 100644 --- a/src/command/cmd_defs.c +++ b/src/command/cmd_defs.c @@ -2688,9 +2688,12 @@ static struct cmd_t command_defs[] = { CMD_SYN( "/mood set [\"Text\"]") CMD_DESC( - "Set your mood") - CMD_NOARGS - CMD_NOEXAMPLES + "Set your mood. Use the tab key to switch through the available moods") + CMD_ARGS( + { "set ", "Your mood" }, + { "", "Additional Text" }) + CMD_EXAMPLES( + "/mood set happy \"I'm happy\"") }, // NEXT-COMMAND (search helper) }; diff --git a/src/command/cmd_funcs.c b/src/command/cmd_funcs.c index 5e6b3cc2..fe5d5e45 100644 --- a/src/command/cmd_funcs.c +++ b/src/command/cmd_funcs.c @@ -9649,13 +9649,14 @@ cmd_register(ProfWin* window, const char* const command, gchar** args) gboolean cmd_mood(ProfWin* window, const char* const command, gchar** args) { - if (g_strcmp0(args[0], "set") == 0) { - cons_show("Your mood: %s", args[1]); - if (args[2]) { - publish_user_mood(args[1], args[2]); - } else { - publish_user_mood(args[1], args[1]); + if(args[1]) { + cons_show("Your mood: %s", args[1]); + if (args[2]) { + publish_user_mood(args[1], args[2]); + } else { + publish_user_mood(args[1], args[1]); + } } } return TRUE; diff --git a/src/xmpp/iq.c b/src/xmpp/iq.c index 4d140013..81eec81e 100644 --- a/src/xmpp/iq.c +++ b/src/xmpp/iq.c @@ -2808,23 +2808,23 @@ publish_user_mood(const char* const mood, const char* const text) xmpp_stanza_t* iq = xmpp_iq_new(ctx, STANZA_TYPE_SET, id); xmpp_stanza_t* pubsub = xmpp_stanza_new(ctx); - xmpp_stanza_set_name(pubsub, "pubsub"); - xmpp_stanza_set_ns(pubsub, "http://jabber.org/protocol/pubsub"); + xmpp_stanza_set_name(pubsub, STANZA_NAME_PUBSUB); + xmpp_stanza_set_ns(pubsub, STANZA_NS_PUBSUB); xmpp_stanza_add_child(iq, pubsub); xmpp_stanza_t* publish = xmpp_stanza_new(ctx); - xmpp_stanza_set_name(publish, "publish"); - xmpp_stanza_set_attribute(publish, "node", "http://jabber.org/protocol/mood"); + xmpp_stanza_set_name(publish, STANZA_NAME_PUBLISH); + xmpp_stanza_set_attribute(publish, STANZA_ATTR_NODE, STANZA_NS_MOOD); xmpp_stanza_add_child(pubsub, publish); xmpp_stanza_t* item = xmpp_stanza_new(ctx); - xmpp_stanza_set_name(item, "item"); + xmpp_stanza_set_name(item, STANZA_NAME_ITEM); xmpp_stanza_set_attribute(item, "id", "current"); xmpp_stanza_add_child(publish, item); xmpp_stanza_t* mood_t = xmpp_stanza_new(ctx); - xmpp_stanza_set_name(mood_t, "mood"); - xmpp_stanza_set_ns(mood_t, "http://jabber.org/protocol/mood"); + xmpp_stanza_set_name(mood_t, STANZA_NAME_MOOD); + xmpp_stanza_set_ns(mood_t, STANZA_NS_MOOD); xmpp_stanza_add_child(item, mood_t); xmpp_stanza_t* x = xmpp_stanza_new(ctx); @@ -2832,7 +2832,7 @@ publish_user_mood(const char* const mood, const char* const text) xmpp_stanza_add_child(mood_t, x); xmpp_stanza_t* text_t = xmpp_stanza_new(ctx); - xmpp_stanza_set_name(text_t, "text"); + xmpp_stanza_set_name(text_t, STANZA_NAME_TEXT); xmpp_stanza_add_child(mood_t, text_t); xmpp_stanza_t* t = xmpp_stanza_new(ctx); diff --git a/src/xmpp/session.c b/src/xmpp/session.c index a58ab1f7..4a19e211 100644 --- a/src/xmpp/session.c +++ b/src/xmpp/session.c @@ -286,24 +286,22 @@ session_get_account_name(void) return saved_account.name; } -static int _receive_mood(xmpp_stanza_t* const stanza, void* const userdata); - static int _receive_mood(xmpp_stanza_t* const stanza, void* const userdata) { const char* from = xmpp_stanza_get_from(stanza); - xmpp_stanza_t* event = xmpp_stanza_get_child_by_name_and_ns(stanza, "event", "http://jabber.org/protocol/pubsub#event"); + xmpp_stanza_t* event = xmpp_stanza_get_child_by_name_and_ns(stanza, STANZA_NAME_EVENT, STANZA_NS_PUBSUB_EVENT); if (event) { - xmpp_stanza_t* items = xmpp_stanza_get_child_by_name(event, "items"); + xmpp_stanza_t* items = xmpp_stanza_get_child_by_name(event, STANZA_NAME_ITEMS); if (items) { - xmpp_stanza_t* item = xmpp_stanza_get_child_by_name(items, "item"); + xmpp_stanza_t* item = xmpp_stanza_get_child_by_name(items, STANZA_NAME_ITEM); if (item) { - xmpp_stanza_t* mood = xmpp_stanza_get_child_by_name_and_ns(item, "mood", "http://jabber.org/protocol/mood"); + xmpp_stanza_t* mood = xmpp_stanza_get_child_by_name_and_ns(item, STANZA_NAME_MOOD, STANZA_NS_MOOD); if (mood) { xmpp_stanza_t* c = xmpp_stanza_get_children(mood); if (c) { const char* m = xmpp_stanza_get_name(c); - xmpp_stanza_t* t = xmpp_stanza_get_child_by_name(mood, "text"); + xmpp_stanza_t* t = xmpp_stanza_get_child_by_name(mood, STANZA_NAME_TEXT); if (t) { const char* text = xmpp_stanza_get_text(t); cons_show("Mood from %s %s (%s)", from, m, text); @@ -363,8 +361,8 @@ session_login_success(gboolean secured) reconnect_timer = NULL; } - message_pubsub_event_handler_add("http://jabber.org/protocol/mood", _receive_mood, NULL, NULL); - caps_add_feature("http://jabber.org/protocol/mood+notify"); + message_pubsub_event_handler_add(STANZA_NS_MOOD, _receive_mood, NULL, NULL); + caps_add_feature(STANZA_NS_MOOD_NOTIFY); } void diff --git a/src/xmpp/stanza.h b/src/xmpp/stanza.h index e2c22bd8..b4c65641 100644 --- a/src/xmpp/stanza.h +++ b/src/xmpp/stanza.h @@ -117,6 +117,8 @@ #define STANZA_NAME_USERNAME "username" #define STANZA_NAME_PROPOSE "propose" #define STANZA_NAME_REPORT "report" +#define STANZA_NAME_EVENT "event" +#define STANZA_NAME_MOOD "mood" // error conditions #define STANZA_NAME_BAD_REQUEST "bad-request" @@ -239,6 +241,8 @@ #define STANZA_NS_JINGLE_MESSAGE "urn:xmpp:jingle-message:0" #define STANZA_NS_JINGLE_RTP "urn:xmpp:jingle:apps:rtp:1" #define STANZA_NS_REPORTING "urn:xmpp:reporting:1" +#define STANZA_NS_MOOD "http://jabber.org/protocol/mood" +#define STANZA_NS_MOOD_NOTIFY "http://jabber.org/protocol/mood+notify" #define STANZA_DATAFORM_SOFTWARE "urn:xmpp:dataforms:softwareinfo" From 67fea6f3c452dd8c96feb7c2ad8de90eba632ce7 Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Mon, 6 Dec 2021 13:38:46 +0100 Subject: [PATCH 4/5] xep-0107: adjust help --- src/command/cmd_defs.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/command/cmd_defs.c b/src/command/cmd_defs.c index 4ceb8193..ab491f0c 100644 --- a/src/command/cmd_defs.c +++ b/src/command/cmd_defs.c @@ -2686,14 +2686,14 @@ static struct cmd_t command_defs[] = { CMD_TAGS( CMD_TAG_CHAT) CMD_SYN( - "/mood set [\"Text\"]") + "/mood set [text]") CMD_DESC( - "Set your mood. Use the tab key to switch through the available moods") + "Set your mood (XEP-0107). Use tab to switch through predefined moods.") CMD_ARGS( - { "set ", "Your mood" }, - { "", "Additional Text" }) + { "set ", "Setting your mood." }, + { "", "Additional Text." }) CMD_EXAMPLES( - "/mood set happy \"I'm happy\"") + "/mood set happy \"So happy to use Profanity!\"") }, // NEXT-COMMAND (search helper) }; From 6c3e6a5262c6009f43dddb6fd5a2fc8204520eef Mon Sep 17 00:00:00 2001 From: Michael Vetter Date: Mon, 6 Dec 2021 13:44:04 +0100 Subject: [PATCH 5/5] xep-0107: adapting the pubsub/headline code Like mentioned on the review at https://github.com/profanity-im/profanity/pull/1605 I don't ge why @DebXWoody changed the code like he did. I changed it to something that made more sense to me now. Instead of looking for headline in two places and checking for pubsub in a headline place (only). I didn't check this deeply. And still have a feeling that this is not the best way to go. But I didn't read the XEP yet. Added a TODO to the code regarding this too. A quick skimming through https://xmpp.org/extensions/xep-0107.html doesn't show me anything regarding headline. So I really don't see why this needs to go here. Hopefully @DebXWoody checks this in the future. But since he didn't react on the PR I decided to make some adjustments myself so we can merge it. --- src/xmpp/message.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/xmpp/message.c b/src/xmpp/message.c index 17ef979b..ab4d48c6 100644 --- a/src/xmpp/message.c +++ b/src/xmpp/message.c @@ -164,9 +164,12 @@ _message_handler(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* con } else if (type && g_strcmp0(type, STANZA_TYPE_HEADLINE) == 0) { xmpp_stanza_t* event = xmpp_stanza_get_child_by_ns(stanza, STANZA_NS_PUBSUB_EVENT); + // TODO: do we want to handle all pubsub here or should additionaly check for STANZA_NS_MOOD? if (event) { _handle_pubsub(stanza, event); return 1; + } else { + _handle_headline(stanza); } } else if (type == NULL || g_strcmp0(type, STANZA_TYPE_CHAT) == 0 || g_strcmp0(type, STANZA_TYPE_NORMAL) == 0) { // type: chat, normal (==NULL) @@ -252,8 +255,6 @@ _message_handler(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* con if (msg_stanza) { _handle_chat(msg_stanza, FALSE, is_carbon, NULL, NULL); } - } else if (type && g_strcmp0(type, STANZA_TYPE_HEADLINE) == 0) { - _handle_headline(stanza); } else { // none of the allowed types char* text;