diff options
author | Michael Vetter <jubalh@iodoru.org> | 2022-06-21 14:13:29 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-06-21 14:13:29 +0200 |
commit | f4d8728809640a812e02eb6974989f4e08f9a38b (patch) | |
tree | 0af2a3fbae51d3ac1c704aa290693f35f61853fd /src/config | |
parent | 476c73251c2787930f866c76484eb1417a834cea (diff) | |
parent | f1d1a80d07ed1fa06f04347ac975f8c2d705fb27 (diff) | |
download | profani-tty-f4d8728809640a812e02eb6974989f4e08f9a38b.tar.gz |
Merge pull request #1722 from MarcoPolo-PasTonMolo/fix/automatically-start-ox-or-pgp
Don't forget encryption status for OX and PGP.
Diffstat (limited to 'src/config')
-rw-r--r-- | src/config/account.c | 11 | ||||
-rw-r--r-- | src/config/account.h | 7 | ||||
-rw-r--r-- | src/config/accounts.c | 70 | ||||
-rw-r--r-- | src/config/accounts.h | 2 |
4 files changed, 76 insertions, 14 deletions
diff --git a/src/config/account.c b/src/config/account.c index d8029052..238c2ef1 100644 --- a/src/config/account.c +++ b/src/config/account.c @@ -57,8 +57,9 @@ account_new(const gchar* const name, const gchar* const jid, const gchar* const muc_service, const gchar* const muc_nick, const gchar* const otr_policy, GList* otr_manual, GList* otr_opportunistic, GList* otr_always, const gchar* const omemo_policy, GList* omemo_enabled, - GList* omemo_disabled, const gchar* const pgp_keyid, const char* const startscript, - const char* const theme, gchar* tls_policy, gchar* auth_policy) + GList* omemo_disabled, GList* ox_enabled, GList* pgp_enabled, + const gchar* const pgp_keyid, const char* const startscript, const char* const theme, + gchar* tls_policy, gchar* auth_policy) { ProfAccount* new_account = malloc(sizeof(ProfAccount)); memset(new_account, 0, sizeof(ProfAccount)); @@ -154,6 +155,10 @@ account_new(const gchar* const name, const gchar* const jid, new_account->omemo_enabled = omemo_enabled; new_account->omemo_disabled = omemo_disabled; + new_account->ox_enabled = ox_enabled; + + new_account->pgp_enabled = pgp_enabled; + if (pgp_keyid != NULL) { new_account->pgp_keyid = strdup(pgp_keyid); } else { @@ -281,6 +286,8 @@ account_free(ProfAccount* account) g_list_free_full(account->otr_always, g_free); g_list_free_full(account->omemo_enabled, g_free); g_list_free_full(account->omemo_disabled, g_free); + g_list_free_full(account->ox_enabled, g_free); + g_list_free_full(account->pgp_enabled, g_free); free(account); } diff --git a/src/config/account.h b/src/config/account.h index dfc7bc12..ce49883e 100644 --- a/src/config/account.h +++ b/src/config/account.h @@ -64,6 +64,8 @@ typedef struct prof_account_t gchar* omemo_policy; GList* omemo_enabled; GList* omemo_disabled; + GList* ox_enabled; + GList* pgp_enabled; gchar* pgp_keyid; gchar* startscript; gchar* theme; @@ -79,8 +81,9 @@ ProfAccount* account_new(const gchar* const name, const gchar* const jid, const gchar* const muc_service, const gchar* const muc_nick, const gchar* const otr_policy, GList* otr_manual, GList* otr_opportunistic, GList* otr_always, const gchar* const omemo_policy, GList* omemo_enabled, - GList* omemo_disabled, const gchar* const pgp_keyid, const char* const startscript, - const char* const theme, gchar* tls_policy, gchar* auth_policy); + GList* omemo_disabled, GList* ox_enabled, GList* pgp_enabled, const gchar* const pgp_keyid, + const char* const startscript, const char* const theme, gchar* tls_policy, + gchar* auth_policy); char* account_create_connect_jid(ProfAccount* account); gboolean account_eval_password(ProfAccount* account); void account_free(ProfAccount* account); diff --git a/src/config/accounts.c b/src/config/accounts.c index 83934012..d99dd10d 100644 --- a/src/config/accounts.c +++ b/src/config/accounts.c @@ -283,21 +283,39 @@ accounts_get_account(const char* const name) } GList* omemo_enabled = NULL; - gchar** enabled_list = g_key_file_get_string_list(accounts, name, "omemo.enabled", &length, NULL); - if (enabled_list) { + gchar** omemo_enabled_list = g_key_file_get_string_list(accounts, name, "omemo.enabled", &length, NULL); + if (omemo_enabled_list) { for (int i = 0; i < length; i++) { - omemo_enabled = g_list_append(omemo_enabled, strdup(enabled_list[i])); + omemo_enabled = g_list_append(omemo_enabled, strdup(omemo_enabled_list[i])); } - g_strfreev(enabled_list); + g_strfreev(omemo_enabled_list); } GList* omemo_disabled = NULL; - gchar** disabled_list = g_key_file_get_string_list(accounts, name, "omemo.disabled", &length, NULL); - if (disabled_list) { + gchar** omemo_disabled_list = g_key_file_get_string_list(accounts, name, "omemo.disabled", &length, NULL); + if (omemo_disabled_list) { for (int i = 0; i < length; i++) { - omemo_disabled = g_list_append(omemo_disabled, strdup(disabled_list[i])); + omemo_disabled = g_list_append(omemo_disabled, strdup(omemo_disabled_list[i])); } - g_strfreev(disabled_list); + g_strfreev(omemo_disabled_list); + } + + GList* ox_enabled = NULL; + gchar** ox_enabled_list = g_key_file_get_string_list(accounts, name, "ox.enabled", &length, NULL); + if (ox_enabled_list) { + for (int i = 0; i < length; i++) { + ox_enabled = g_list_append(ox_enabled, strdup(ox_enabled_list[i])); + } + g_strfreev(ox_enabled_list); + } + + GList* pgp_enabled = NULL; + gchar** pgp_enabled_list = g_key_file_get_string_list(accounts, name, "pgp.enabled", &length, NULL); + if (pgp_enabled_list) { + for (int i = 0; i < length; i++) { + pgp_enabled = g_list_append(pgp_enabled, strdup(pgp_enabled_list[i])); + } + g_strfreev(pgp_enabled_list); } gchar* pgp_keyid = NULL; @@ -328,8 +346,8 @@ accounts_get_account(const char* const name) priority_online, priority_chat, priority_away, priority_xa, priority_dnd, muc_service, muc_nick, otr_policy, otr_manual, otr_opportunistic, otr_always, omemo_policy, omemo_enabled, - omemo_disabled, pgp_keyid, startscript, theme, tls_policy, - auth_policy); + omemo_disabled, ox_enabled, pgp_enabled, pgp_keyid, + startscript, theme, tls_policy, auth_policy); g_free(jid); g_free(password); @@ -415,6 +433,8 @@ accounts_rename(const char* const account_name, const char* const new_name) "omemo.policy", "omemo.enabled", "omemo.disabled", + "ox.enabled", + "pgp.enabled", "pgp.keyid", "last.activity", "script.start", @@ -678,6 +698,36 @@ accounts_add_omemo_state(const char* const account_name, const char* const conta } void +accounts_add_ox_state(const char* const account_name, const char* const contact_jid, gboolean enabled) +{ + if (accounts_account_exists(account_name)) { + if (enabled) { + conf_string_list_add(accounts, account_name, "ox.enabled", contact_jid); + } else { + conf_string_list_remove(accounts, account_name, "ox.enabled", contact_jid); + } + + _save_accounts(); + } +} + +void +accounts_add_pgp_state(const char* const account_name, const char* const contact_jid, gboolean enabled) +{ + if (accounts_account_exists(account_name)) { + if (enabled) { + conf_string_list_add(accounts, account_name, "pgp.enabled", contact_jid); + conf_string_list_remove(accounts, account_name, "pgp.disabled", contact_jid); + } else { + conf_string_list_add(accounts, account_name, "pgp.disabled", contact_jid); + conf_string_list_remove(accounts, account_name, "pgp.enabled", contact_jid); + } + + _save_accounts(); + } +} + +void accounts_clear_omemo_state(const char* const account_name, const char* const contact_jid) { if (accounts_account_exists(account_name)) { diff --git a/src/config/accounts.h b/src/config/accounts.h index d279bbd0..2f594a2f 100644 --- a/src/config/accounts.h +++ b/src/config/accounts.h @@ -100,6 +100,8 @@ void accounts_clear_muc(const char* const account_name); void accounts_clear_resource(const char* const account_name); void accounts_add_otr_policy(const char* const account_name, const char* const contact_jid, const char* const policy); void accounts_add_omemo_state(const char* const account_name, const char* const contact_jid, gboolean enabled); +void accounts_add_ox_state(const char* const account_name, const char* const contact_jid, gboolean enabled); +void accounts_add_pgp_state(const char* const account_name, const char* const contact_jid, gboolean enabled); void accounts_clear_omemo_state(const char* const account_name, const char* const contact_jid); #endif |