1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Merge branch 'master' into pgp

This commit is contained in:
James Booth 2015-04-22 00:30:00 +01:00
commit 5f2c6cbd28
3 changed files with 143 additions and 120 deletions

View File

@ -140,31 +140,29 @@ cmd_execute_alias(const char * const inp, gboolean *ran)
if (inp[0] != '/') { if (inp[0] != '/') {
ran = FALSE; ran = FALSE;
return TRUE; return TRUE;
} else { }
char *alias = strdup(inp+1); char *alias = strdup(inp+1);
char *value = prefs_get_alias(alias); char *value = prefs_get_alias(alias);
free(alias); free(alias);
if (value != NULL) { if (value) {
*ran = TRUE; *ran = TRUE;
return cmd_process_input(value); return cmd_process_input(value);
} else { }
*ran = FALSE; *ran = FALSE;
return TRUE; return TRUE;
}
}
} }
gboolean gboolean
cmd_connect(gchar **args, struct cmd_help_t help) cmd_connect(gchar **args, struct cmd_help_t help)
{ {
gboolean result = FALSE;
jabber_conn_status_t conn_status = jabber_get_connection_status(); jabber_conn_status_t conn_status = jabber_get_connection_status();
if ((conn_status != JABBER_DISCONNECTED) && (conn_status != JABBER_STARTED)) { if ((conn_status != JABBER_DISCONNECTED) && (conn_status != JABBER_STARTED)) {
cons_show("You are either connected already, or a login is in process."); cons_show("You are either connected already, or a login is in process.");
result = TRUE; return TRUE;
} else { }
gchar *opt_keys[] = { "server", "port", NULL }; gchar *opt_keys[] = { "server", "port", NULL };
gboolean parsed; gboolean parsed;
@ -193,8 +191,8 @@ cmd_connect(gchar **args, struct cmd_help_t help)
char *user = args[0]; char *user = args[0];
char *def = prefs_get_string(PREF_DEFAULT_ACCOUNT); char *def = prefs_get_string(PREF_DEFAULT_ACCOUNT);
if(!user){ if (!user) {
if(def){ if (def) {
user = def; user = def;
cons_show("Using default account %s.", user); cons_show("Using default account %s.", user);
} else { } else {
@ -207,56 +205,19 @@ cmd_connect(gchar **args, struct cmd_help_t help)
char *lower = g_utf8_strdown(user, -1); char *lower = g_utf8_strdown(user, -1);
char *jid; char *jid;
g_free(def); g_free(def);
def = NULL;
ProfAccount *account = accounts_get_account(lower); ProfAccount *account = accounts_get_account(lower);
if (account != NULL) { if (account) {
jid = account_create_full_jid(account); jid = account_create_full_jid(account);
if(account->eval_password){ gboolean res = client_connect_account(account, &conn_status);
// Evaluate as shell command to retrieve password if (!res) {
GString *cmd = g_string_append(g_string_new(account->eval_password), " 2>/dev/null");
FILE *stream = popen(cmd->str, "r");
g_string_free(cmd, TRUE);
if(stream){
// Limit to READ_BUF_SIZE bytes to prevent overflows in the case of a poorly chosen command
account->password = g_malloc(READ_BUF_SIZE);
if(!account->password){
log_error("Failed to allocate enough memory to read eval_password output");
cons_show("Error evaluating password, see logs for details.");
return TRUE;
}
account->password = fgets(account->password, READ_BUF_SIZE, stream);
pclose(stream);
if(!account->password){
log_error("No result from eval_password.");
cons_show("Error evaluating password, see logs for details.");
return TRUE;
}
// strip trailing newline
if (g_str_has_suffix(account->password, "\n")) {
account->password[strlen(account->password)-1] = '\0';
}
} else {
log_error("popen failed when running eval_password.");
cons_show("Error evaluating password, see logs for details.");
return TRUE;
}
} else if (!account->password) {
account->password = ui_ask_password();
}
cons_show("Connecting with account %s as %s", account->name, jid);
if(g_hash_table_contains(options, "port") || g_hash_table_contains(options, "server"))
cons_show("Ignoring extra connect options. Please set them with /account set");
conn_status = jabber_connect_with_account(account);
account_free(account);
} else {
char *passwd = ui_ask_password();
jid = strdup(lower);
cons_show("Connecting as %s", jid);
conn_status = jabber_connect_with_details(jid, passwd, altdomain, port);
free(passwd);
}
g_free(lower); g_free(lower);
return TRUE;
}
} else {
jid = strdup(lower);
conn_status = client_connect_jid(jid, altdomain, port);
}
if (conn_status == JABBER_DISCONNECTED) { if (conn_status == JABBER_DISCONNECTED) {
cons_show_error("Connection attempt for %s failed.", jid); cons_show_error("Connection attempt for %s failed.", jid);
@ -264,13 +225,10 @@ cmd_connect(gchar **args, struct cmd_help_t help)
} }
options_destroy(options); options_destroy(options);
g_free(lower);
free(jid); free(jid);
result = TRUE; return TRUE;
}
return result;
} }
gboolean gboolean

View File

@ -42,6 +42,68 @@
#include "otr/otr.h" #include "otr/otr.h"
#endif #endif
jabber_conn_status_t
client_connect_jid(const char * const jid, const char * const altdomain, const int port)
{
cons_show("Connecting as %s", jid);
char *passwd = ui_ask_password();
jabber_conn_status_t conn_status = jabber_connect_with_details(jid, passwd, altdomain, port);
free(passwd);
return conn_status;
}
gboolean
client_connect_account(ProfAccount *account, jabber_conn_status_t *conn_status)
{
if (account->eval_password) {
// Evaluate as shell command to retrieve password
GString *cmd = g_string_new("");
g_string_append_printf(cmd, "%s 2>/dev/null", account->eval_password);
FILE *stream = popen(cmd->str, "r");
g_string_free(cmd, TRUE);
if (stream) {
// Limit to READ_BUF_SIZE bytes to prevent overflows in the case of a poorly chosen command
account->password = g_malloc(READ_BUF_SIZE);
if (!account->password) {
log_error("Failed to allocate enough memory to read eval_password output");
cons_show("Error evaluating password, see logs for details.");
return FALSE;
}
account->password = fgets(account->password, READ_BUF_SIZE, stream);
pclose(stream);
if (!account->password) {
log_error("No result from eval_password.");
cons_show("Error evaluating password, see logs for details.");
return FALSE;
}
// strip trailing newline
if (g_str_has_suffix(account->password, "\n")) {
account->password[strlen(account->password)-1] = '\0';
}
} else {
log_error("popen failed when running eval_password.");
cons_show("Error evaluating password, see logs for details.");
return FALSE;
}
} else if (!account->password) {
account->password = ui_ask_password();
}
char *jid = account_create_full_jid(account);
cons_show("Connecting with account %s as %s", account->name, jid);
free(jid);
*conn_status = jabber_connect_with_account(account);
account_free(account);
return TRUE;
}
void void
client_send_msg(const char * const barejid, const char * const msg) client_send_msg(const char * const barejid, const char * const msg)
{ {

View File

@ -35,6 +35,9 @@
#ifndef CLIENT_EVENTS_H #ifndef CLIENT_EVENTS_H
#define CLIENT_EVENTS_H #define CLIENT_EVENTS_H
jabber_conn_status_t client_connect_jid(const char * const jid, const char * const altdomain, const int port);
gboolean client_connect_account(ProfAccount *account, jabber_conn_status_t *conn_status);
void client_send_msg(const char * const barejid, const char * const msg); void client_send_msg(const char * const barejid, const char * const msg);
void client_send_muc_msg(const char * const roomjid, const char * const msg); void client_send_muc_msg(const char * const roomjid, const char * const msg);
void client_send_priv_msg(const char * const fulljid, const char * const msg); void client_send_priv_msg(const char * const fulljid, const char * const msg);