mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Merge remote-tracking branch 'tsenart/passwords-on-accounts-file'
Conflicts: src/config/accounts.c
This commit is contained in:
parent
9101f1ea26
commit
3d7087959d
@ -20,6 +20,7 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#include <assert.h>
|
||||
#include <errno.h>
|
||||
#include <limits.h>
|
||||
#include <stdlib.h>
|
||||
@ -67,6 +68,7 @@ typedef struct cmd_t {
|
||||
|
||||
typedef char*(*autocompleter)(char*, int*);
|
||||
|
||||
static char * _ask_password(void);
|
||||
static void _update_presence(const resource_presence_t presence,
|
||||
const char * const show, gchar **args);
|
||||
static gboolean _cmd_set_boolean_preference(gchar *arg, struct cmd_help_t help,
|
||||
@ -1311,13 +1313,6 @@ _cmd_connect(gchar **args, struct cmd_help_t help)
|
||||
char *lower = g_utf8_strdown(user, -1);
|
||||
char *jid;
|
||||
|
||||
status_bar_get_password();
|
||||
status_bar_refresh();
|
||||
char passwd[21];
|
||||
inp_block();
|
||||
inp_get_password(passwd);
|
||||
inp_non_block();
|
||||
|
||||
ProfAccount *account = accounts_get_account(lower);
|
||||
if (account != NULL) {
|
||||
if (account->resource != NULL) {
|
||||
@ -1325,12 +1320,18 @@ _cmd_connect(gchar **args, struct cmd_help_t help)
|
||||
} else {
|
||||
jid = strdup(account->jid);
|
||||
}
|
||||
|
||||
if (account->password == NULL) {
|
||||
account->password = _ask_password();
|
||||
}
|
||||
cons_show("Connecting with account %s as %s", account->name, jid);
|
||||
conn_status = jabber_connect_with_account(account, passwd);
|
||||
conn_status = jabber_connect_with_account(account);
|
||||
} else {
|
||||
char *passwd = _ask_password();
|
||||
jid = strdup(lower);
|
||||
cons_show("Connecting as %s", jid);
|
||||
conn_status = jabber_connect_with_details(jid, passwd, altdomain);
|
||||
free(passwd);
|
||||
}
|
||||
|
||||
if (conn_status == JABBER_DISCONNECTED) {
|
||||
@ -3443,6 +3444,20 @@ _cmd_xa(gchar **args, struct cmd_help_t help)
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// helper function that asks the user for a password and saves it in passwd
|
||||
|
||||
static char *
|
||||
_ask_password(void) {
|
||||
char *passwd = malloc(sizeof(char) * 21);
|
||||
status_bar_get_password();
|
||||
status_bar_refresh();
|
||||
inp_block();
|
||||
inp_get_password(passwd);
|
||||
inp_non_block();
|
||||
|
||||
return passwd;
|
||||
}
|
||||
|
||||
// helper function for status change commands
|
||||
|
||||
static void
|
||||
|
@ -39,10 +39,12 @@ static GKeyFile *accounts;
|
||||
static Autocomplete all_ac;
|
||||
static Autocomplete enabled_ac;
|
||||
|
||||
// used to rename account (copies properties to new account)
|
||||
static gchar *string_keys[] = {
|
||||
"jid",
|
||||
"server",
|
||||
"resource",
|
||||
"password",
|
||||
"presence.last",
|
||||
"presence.login",
|
||||
"muc.service",
|
||||
@ -193,6 +195,14 @@ accounts_get_account(const char * const name)
|
||||
_save_accounts();
|
||||
}
|
||||
|
||||
gchar *password = g_key_file_get_string(accounts, name, "password", NULL);
|
||||
if (password != NULL) {
|
||||
account->password = strdup(password);
|
||||
g_free(password);
|
||||
} else {
|
||||
account->password = NULL;
|
||||
}
|
||||
|
||||
account->enabled = g_key_file_get_boolean(accounts, name, "enabled", NULL);
|
||||
|
||||
gchar *server = g_key_file_get_string(accounts, name, "server", NULL);
|
||||
@ -281,6 +291,7 @@ accounts_free_account(ProfAccount *account)
|
||||
FREE_SET_NULL(account->name);
|
||||
FREE_SET_NULL(account->jid);
|
||||
FREE_SET_NULL(account->resource);
|
||||
FREE_SET_NULL(account->password);
|
||||
FREE_SET_NULL(account->server);
|
||||
FREE_SET_NULL(account->last_presence);
|
||||
FREE_SET_NULL(account->login_presence);
|
||||
@ -341,6 +352,7 @@ accounts_rename(const char * const account_name, const char * const new_name)
|
||||
g_key_file_set_integer(accounts, new_name, "priority.dnd",
|
||||
g_key_file_get_boolean(accounts, account_name, "priority.dnd", NULL));
|
||||
|
||||
// copy other string properties
|
||||
int i;
|
||||
for (i = 0; i < ARRAY_SIZE(string_keys); i++) {
|
||||
char *value = g_key_file_get_string(accounts, account_name, string_keys[i], NULL);
|
||||
|
@ -28,6 +28,7 @@
|
||||
typedef struct prof_account_t {
|
||||
gchar *name;
|
||||
gchar *jid;
|
||||
gchar *password;
|
||||
gchar *resource;
|
||||
gchar *server;
|
||||
gchar *last_presence;
|
||||
|
@ -801,6 +801,9 @@ cons_show_account(ProfAccount *account)
|
||||
cons_show ("enabled : FALSE");
|
||||
}
|
||||
cons_show ("jid : %s", account->jid);
|
||||
if (account->password != NULL) {
|
||||
cons_show ("password : [redacted]");
|
||||
}
|
||||
if (account->resource != NULL) {
|
||||
cons_show ("resource : %s", account->resource);
|
||||
}
|
||||
|
@ -108,21 +108,20 @@ jabber_init(const int disable_tls)
|
||||
}
|
||||
|
||||
jabber_conn_status_t
|
||||
jabber_connect_with_account(const ProfAccount * const account,
|
||||
const char * const passwd)
|
||||
jabber_connect_with_account(const ProfAccount * const account)
|
||||
{
|
||||
assert(account != NULL);
|
||||
assert(passwd != NULL);
|
||||
|
||||
log_info("Connecting using account: %s", account->name);
|
||||
|
||||
// save account name and password for reconnect
|
||||
saved_account.name = strdup(account->name);
|
||||
saved_account.passwd = strdup(passwd);
|
||||
saved_account.passwd = strdup(account->password);
|
||||
|
||||
// connect with fulljid
|
||||
Jid *jidp = jid_create_from_bare_and_resource(account->jid, account->resource);
|
||||
jabber_conn_status_t result = _jabber_connect(jidp->fulljid, passwd, account->server);
|
||||
jabber_conn_status_t result =
|
||||
_jabber_connect(jidp->fulljid, account->password, account->server);
|
||||
jid_destroy(jidp);
|
||||
|
||||
return result;
|
||||
|
@ -78,8 +78,7 @@ typedef struct disco_identity_t {
|
||||
void jabber_init(const int disable_tls);
|
||||
jabber_conn_status_t jabber_connect_with_details(const char * const jid,
|
||||
const char * const passwd, const char * const altdomain);
|
||||
jabber_conn_status_t jabber_connect_with_account(const ProfAccount * const account,
|
||||
const char * const passwd);
|
||||
jabber_conn_status_t jabber_connect_with_account(const ProfAccount * const account);
|
||||
void jabber_disconnect(void);
|
||||
void jabber_shutdown(void);
|
||||
void jabber_process_events(void);
|
||||
|
Loading…
Reference in New Issue
Block a user