From 7897ac41444b7be10e9881ea30ed67fe14929cef Mon Sep 17 00:00:00 2001 From: xengineering Date: Sat, 30 Jan 2021 11:37:16 +0100 Subject: Implement successful Stream Setup --- src/xbot.c | 54 ++++++++++++++++++++++++++++++++++++------------------ 1 file changed, 36 insertions(+), 18 deletions(-) (limited to 'src') diff --git a/src/xbot.c b/src/xbot.c index ec16d6b..eaca1da 100644 --- a/src/xbot.c +++ b/src/xbot.c @@ -15,6 +15,7 @@ void parse_cli_args(int argc, char **argv, char **msg, char **jid, char **cfg); void read_xmpp_profile(char *path, char **jid, char **pwd); +void send_message(char *msg, char *recipient, char *sender, char *pwd); void conn_handler( xmpp_conn_t *const conn, const xmpp_conn_event_t status, @@ -34,24 +35,9 @@ int main(int argc, char **argv) char *my_jid = NULL; char *my_pwd = NULL; - parse_cli_args(argc, argv, &message, &target_jid, &profile_path); // get information from user + parse_cli_args(argc, argv, &message, &target_jid, &profile_path); read_xmpp_profile(profile_path, &my_jid, &my_pwd); - - // send message - /*xmpp_ctx_t *ctx; - xmpp_conn_t *conn; - xmpp_log_t *log; - xmpp_initialize(); - log = xmpp_get_default_logger(XMPP_LEVEL_DEBUG); - ctx = xmpp_ctx_new(NULL, log); - conn = xmpp_conn_new(ctx); - xmpp_conn_set_jid(conn, my_jid); - xmpp_conn_set_pass(conn, my_pwd); - xmpp_connect_client(conn, NULL, 0, conn_handler, ctx); - xmpp_run(ctx); - xmpp_conn_release(conn); - xmpp_ctx_free(ctx); - xmpp_shutdown();*/ + send_message(message, target_jid, my_jid, my_pwd); // free memory if(message != NULL)free(message); @@ -113,6 +99,36 @@ void read_xmpp_profile(char *path, char **jid, char **pwd) } +void send_message(char *msg, char *recipient, char *sender, char *pwd) +{ + // setup some pointers and variables + xmpp_ctx_t *ctx; + xmpp_conn_t *conn; + xmpp_log_t *log; + long flags = 0; + + flags |= XMPP_CONN_FLAG_MANDATORY_TLS; // force transport encryption + xmpp_initialize(); // init libstrophe (xmpp library) + log = xmpp_get_default_logger(XMPP_LEVEL_DEBUG); // create xmpp logger + ctx = xmpp_ctx_new(NULL, log); // create xmpp context + + // create xmpp connection, set own jabber id and password and connect + conn = xmpp_conn_new(ctx); + xmpp_conn_set_flags(conn, flags); + xmpp_conn_set_jid(conn, sender); + xmpp_conn_set_pass(conn, pwd); + xmpp_connect_client(conn, NULL, 0, conn_handler, ctx); + + xmpp_run(ctx); // event loop - conn_handler will trigger exit + + xmpp_conn_release(conn); + + // cleanup + xmpp_ctx_free(ctx); + xmpp_shutdown(); +} + + void conn_handler( xmpp_conn_t *const conn, const xmpp_conn_event_t status, @@ -121,7 +137,6 @@ void conn_handler( void *const userdata ) { - // TODO: Implement this stuff! xmpp_ctx_t *ctx = (xmpp_ctx_t *)userdata; int secured; @@ -133,6 +148,9 @@ void conn_handler( fprintf(stderr, "DEBUG: connected\n"); secured = xmpp_conn_is_secured(conn); fprintf(stderr, "DEBUG: connection is %s.\n", secured ? "secured" : "NOT secured"); + + // time to play some stanzas + xmpp_disconnect(conn); } else -- cgit v1.2.3-70-g09d2