package app.fedilab.android.jobs; /* Copyright 2017 Thomas Schneider * * This file is a part of Fedilab * * This program is free software; you can redistribute it and/or modify it under the terms of the * GNU General Public License as published by the Free Software Foundation; either version 3 of the * License, or (at your option) any later version. * * Fedilab is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even * the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General * Public License for more details. * * You should have received a copy of the GNU General Public License along with Fedilab; if not, * see . */ import android.content.Context; import android.database.sqlite.SQLiteDatabase; import androidx.annotation.NonNull; import com.evernote.android.job.Job; import com.evernote.android.job.JobRequest; import java.util.Date; import java.util.concurrent.TimeUnit; import app.fedilab.android.client.API; import app.fedilab.android.client.Entities.Account; import app.fedilab.android.client.Entities.Status; import app.fedilab.android.client.Entities.StoredStatus; import app.fedilab.android.sqlite.AccountDAO; import app.fedilab.android.sqlite.Sqlite; import app.fedilab.android.sqlite.StatusStoredDAO; /** * Created by Thomas on 16/07/2017. * Scheduled a toot a datetime */ public class BaseScheduledTootsSyncJob extends Job { public static final String SCHEDULED_TOOT = "job_scheduled_toot"; public static int schedule(Context context, long id, long timestampScheduling) { long startMs = (timestampScheduling - new Date().getTime()); long endMs = startMs + TimeUnit.MINUTES.toMillis(5); SQLiteDatabase db = Sqlite.getInstance(context.getApplicationContext(), Sqlite.DB_NAME, null, Sqlite.DB_VERSION).open(); int jobId = new JobRequest.Builder(BaseScheduledTootsSyncJob.SCHEDULED_TOOT) .setExecutionWindow(startMs, endMs) .setUpdateCurrent(false) .setRequiredNetworkType(JobRequest.NetworkType.METERED) .setRequirementsEnforced(false) .build() .schedule(); new StatusStoredDAO(context, db).scheduleStatus(id, jobId, new Date(timestampScheduling)); return jobId; } @NonNull @Override protected Result onRunJob(@NonNull Params params) { //Code refresh here int jobId = params.getId(); SQLiteDatabase db = Sqlite.getInstance(getContext().getApplicationContext(), Sqlite.DB_NAME, null, Sqlite.DB_VERSION).open(); //Retrieves the stored status StoredStatus storedStatus = new StatusStoredDAO(getContext(), db).getStatusScheduled(jobId); if (storedStatus != null) { String userId = storedStatus.getUserId(); String instance = storedStatus.getInstance(); if (instance != null && userId != null) { Account account = new AccountDAO(getContext(), db).getUniqAccount(userId, instance); if (account != null) { //Retrieves the linked status to toot Status status = storedStatus.getStatus(); if (status != null) { int statusCode = new API(getContext(), account.getInstance(), account.getToken()).statusAction(status); //Toot was sent if (statusCode == 200) { new StatusStoredDAO(getContext(), db).updateScheduledDone(jobId, new Date()); } } } } } return Result.SUCCESS; } }