mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-04 06:20:26 +00:00
External enable/disable by toggling on demand
This commit is contained in:
parent
c4c3192a6a
commit
6d0cc9d322
3 changed files with 7 additions and 4 deletions
1
FAQ.md
1
FAQ.md
|
@ -2275,6 +2275,7 @@ To enable/disable a specific account:
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that disabling an account will hide the account and all associated folders and messages.
|
Note that disabling an account will hide the account and all associated folders and messages.
|
||||||
|
From version 1.1600 an account will be disabled/enabled by setting the account to manual/automatic sync, so the folders and messages keep being accessible.
|
||||||
|
|
||||||
To set the poll interval:
|
To set the poll interval:
|
||||||
|
|
||||||
|
|
|
@ -130,6 +130,9 @@ public interface DaoAccount {
|
||||||
@Query("UPDATE account SET synchronize = :synchronize WHERE id = :id AND NOT (synchronize IS :synchronize)")
|
@Query("UPDATE account SET synchronize = :synchronize WHERE id = :id AND NOT (synchronize IS :synchronize)")
|
||||||
int setAccountSynchronize(long id, boolean synchronize);
|
int setAccountSynchronize(long id, boolean synchronize);
|
||||||
|
|
||||||
|
@Query("UPDATE account SET ondemand = :ondemand WHERE id = :id AND NOT (ondemand IS :ondemand)")
|
||||||
|
int setAccountOnDemand(long id, boolean ondemand);
|
||||||
|
|
||||||
@Query("UPDATE account SET `primary` = :primary WHERE id = :id AND NOT (`primary` IS :primary)")
|
@Query("UPDATE account SET `primary` = :primary WHERE id = :id AND NOT (`primary` IS :primary)")
|
||||||
int setAccountPrimary(long id, boolean primary);
|
int setAccountPrimary(long id, boolean primary);
|
||||||
|
|
||||||
|
|
|
@ -44,8 +44,6 @@ public class ServiceExternal extends Service {
|
||||||
private static final String ACTION_INTERVAL = BuildConfig.APPLICATION_ID + ".INTERVAL";
|
private static final String ACTION_INTERVAL = BuildConfig.APPLICATION_ID + ".INTERVAL";
|
||||||
private static final String ACTION_DISCONNECT_ME = BuildConfig.APPLICATION_ID + ".DISCONNECT.ME";
|
private static final String ACTION_DISCONNECT_ME = BuildConfig.APPLICATION_ID + ".DISCONNECT.ME";
|
||||||
|
|
||||||
static final int PI_WIDGET_ENABLE = 1;
|
|
||||||
|
|
||||||
// adb shell am start-foreground-service -a eu.faircode.email.POLL --es account Gmail
|
// adb shell am start-foreground-service -a eu.faircode.email.POLL --es account Gmail
|
||||||
// adb shell am start-foreground-service -a eu.faircode.email.ENABLE --es account Gmail
|
// adb shell am start-foreground-service -a eu.faircode.email.ENABLE --es account Gmail
|
||||||
// adb shell am start-foreground-service -a eu.faircode.email.DISABLE --es account Gmail
|
// adb shell am start-foreground-service -a eu.faircode.email.DISABLE --es account Gmail
|
||||||
|
@ -192,9 +190,10 @@ public class ServiceExternal extends Service {
|
||||||
if (account == null)
|
if (account == null)
|
||||||
throw new IllegalArgumentException("Account not found name=" + accountName);
|
throw new IllegalArgumentException("Account not found name=" + accountName);
|
||||||
|
|
||||||
db.account().setAccountSynchronize(account.id, enabled);
|
db.account().setAccountOnDemand(account.id, !enabled);
|
||||||
ServiceSynchronize.eval(context, "external account=" + accountName + " enabled=" + enabled);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ServiceSynchronize.eval(context, "external account=" + accountName + " enabled=" + enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void disconnect(Context context, Intent intent) throws IOException, JSONException {
|
private static void disconnect(Context context, Intent intent) throws IOException, JSONException {
|
||||||
|
|
Loading…
Reference in a new issue