/* * Copyright (C) 2013 Simon Vig Therkildsen * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package net.simonvt.cathode.remote.sync.shows; import android.database.Cursor; import java.util.ArrayList; import java.util.List; import javax.inject.Inject; import net.simonvt.cathode.api.entity.Episode; import net.simonvt.cathode.api.entity.Show; import net.simonvt.cathode.api.entity.WatchlistItem; import net.simonvt.cathode.api.service.SyncService; import net.simonvt.cathode.provider.DatabaseContract.EpisodeColumns; import net.simonvt.cathode.provider.DatabaseSchematic; import net.simonvt.cathode.provider.EpisodeDatabaseHelper; import net.simonvt.cathode.provider.ProviderSchematic.Episodes; import net.simonvt.cathode.provider.SeasonDatabaseHelper; import net.simonvt.cathode.provider.ShowDatabaseHelper; import net.simonvt.cathode.remote.CallJob; import net.simonvt.cathode.remote.Flags; import net.simonvt.schematic.Cursors; import retrofit2.Call; public class SyncEpisodeWatchlist extends CallJob<List<WatchlistItem>> { @Inject transient SyncService syncService; @Inject transient ShowDatabaseHelper showHelper; @Inject transient SeasonDatabaseHelper seasonHelper; @Inject transient EpisodeDatabaseHelper episodeHelper; public SyncEpisodeWatchlist() { super(Flags.REQUIRES_AUTH); } @Override public String key() { return "SyncEpisodeWatchlist"; } @Override public int getPriority() { return PRIORITY_USER_DATA; } @Override public Call<List<WatchlistItem>> getCall() { return syncService.getEpisodeWatchlist(); } @Override public void handleResponse(List<WatchlistItem> watchlist) { Cursor c = getContentResolver().query(Episodes.EPISODES_IN_WATCHLIST, new String[] { DatabaseSchematic.Tables.EPISODES + "." + EpisodeColumns.ID, }, null, null, null); List<Long> episodeIds = new ArrayList<>(); while (c.moveToNext()) { episodeIds.add(Cursors.getLong(c, EpisodeColumns.ID)); } c.close(); for (WatchlistItem item : watchlist) { final Show show = item.getShow(); final Episode episode = item.getEpisode(); final long showTraktId = show.getIds().getTrakt(); final int seasonNumber = episode.getSeason(); final int episodeNumber = episode.getNumber(); final long listedAt = item.getListedAt().getTimeInMillis(); ShowDatabaseHelper.IdResult showResult = showHelper.getIdOrCreate(showTraktId); final long showId = showResult.showId; final boolean didShowExist = !showResult.didCreate; if (showResult.didCreate) { showHelper.partialUpdate(show); queue(new SyncShow(showTraktId)); } SeasonDatabaseHelper.IdResult seasonResult = seasonHelper.getIdOrCreate(showId, seasonNumber); final long seasonId = seasonResult.id; final boolean didSeasonExist = !seasonResult.didCreate; if (seasonResult.didCreate) { if (didShowExist) { queue(new SyncShow(showTraktId)); } } EpisodeDatabaseHelper.IdResult episodeResult = episodeHelper.getIdOrCreate(showId, seasonId, episodeNumber); final long episodeId = episodeResult.id; if (episodeResult.didCreate) { if (didShowExist && didSeasonExist) { queue(new SyncSeason(showTraktId, seasonNumber)); } } if (!episodeIds.remove(episodeId)) { episodeHelper.setIsInWatchlist(episodeId, true, listedAt); } } for (Long episodeId : episodeIds) { episodeHelper.setIsInWatchlist(episodeId, false, 0L); } } }