1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2024-07-17 02:44:04 +02:00
Gadgetbridge/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/database/PeriodicExporter.java

76 lines
2.8 KiB
Java
Raw Normal View History

2018-01-04 15:13:06 +01:00
package nodomain.freeyourgadget.gadgetbridge.database;
import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.os.SystemClock;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.OutputStream;
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
2018-01-07 12:50:59 +01:00
import nodomain.freeyourgadget.gadgetbridge.R;
import nodomain.freeyourgadget.gadgetbridge.util.GB;
2018-01-08 11:27:28 +01:00
import nodomain.freeyourgadget.gadgetbridge.util.GBPrefs;
2018-01-08 12:07:39 +01:00
import nodomain.freeyourgadget.gadgetbridge.util.Prefs;
2018-01-04 15:13:06 +01:00
/**
* Created by maufl on 1/4/18.
*/
public class PeriodicExporter extends BroadcastReceiver {
private static final Logger LOG = LoggerFactory.getLogger(PeriodicExporter.class);
2018-01-08 12:07:39 +01:00
public static void enablePeriodicExport(Context context) {
Prefs prefs = GBApplication.getPrefs();
boolean autoExportEnabled = prefs.getBoolean(GBPrefs.AUTO_EXPORT_ENABLED, false);
Integer autoExportInterval = prefs.getInt(GBPrefs.AUTO_EXPORT_INTERVAL, 0);
sheduleAlarm(context, autoExportInterval, autoExportEnabled);
}
2018-01-04 15:13:06 +01:00
2018-01-08 12:07:39 +01:00
public static void sheduleAlarm(Context context, Integer autoExportInterval, boolean autoExportEnabled) {
2018-01-04 15:13:06 +01:00
Intent i = new Intent(context, PeriodicExporter.class);
PendingIntent pi = PendingIntent.getBroadcast(context, 0 , i, 0);
AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
am.cancel(pi);
if (!autoExportEnabled) {
return;
}
2018-01-08 12:07:39 +01:00
int exportPeriod = autoExportInterval * 60 * 60 * 1000;
2018-01-04 15:13:06 +01:00
if (exportPeriod == 0) {
return;
}
LOG.info("Enabling periodic export");
am.setInexactRepeating(
AlarmManager.ELAPSED_REALTIME,
SystemClock.elapsedRealtime() + exportPeriod,
exportPeriod,
pi
);
}
@Override
public void onReceive(Context context, Intent intent) {
LOG.info("Exporting DB");
try (DBHandler dbHandler = GBApplication.acquireDB()) {
DBHelper helper = new DBHelper(context);
2018-01-08 11:27:28 +01:00
String dst = GBApplication.getPrefs().getString(GBPrefs.AUTO_EXPORT_LOCATION, null);
2018-01-04 15:13:06 +01:00
if (dst == null) {
2018-01-07 12:50:59 +01:00
LOG.info("Unable to export DB, export location not set");
2018-01-04 15:13:06 +01:00
return;
}
Uri dstUri = Uri.parse(dst);
OutputStream out = context.getContentResolver().openOutputStream(dstUri);
helper.exportDB(dbHandler, out);
} catch (Exception ex) {
2018-01-07 12:50:59 +01:00
GB.updateExportFailedNotification(context.getString(R.string.notif_export_failed_title), context);
2018-01-04 15:13:06 +01:00
LOG.info("Exception while exporting DB: ", ex);
}
}
}