aboutsummaryrefslogtreecommitdiff
path: root/src/github/daneren2005/dsub/service/sync/StarredSyncAdapter.java
blob: ff153e33c7f1477cd48ce0553f61ecda22e4bef4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*
 This file is part of Subsonic.

 Subsonic 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.

 Subsonic 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 Subsonic.  If not, see <http://www.gnu.org/licenses/>.

 Copyright 2009 (C) Sindre Mehus
 */

package github.daneren2005.dsub.service.sync;

import android.annotation.TargetApi;
import android.content.Context;
import android.util.Log;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

import github.daneren2005.dsub.R;
import github.daneren2005.dsub.domain.MusicDirectory;
import github.daneren2005.dsub.util.FileUtil;
import github.daneren2005.dsub.util.SyncUtil;
import github.daneren2005.dsub.util.Util;

/**
 * Created by Scott on 8/28/13.
 */

public class StarredSyncAdapter extends SubsonicSyncAdapter {
	private static String TAG = StarredSyncAdapter.class.getSimpleName();

	public StarredSyncAdapter(Context context, boolean autoInitialize) {
		super(context, autoInitialize);
	}
	@TargetApi(14)
	public StarredSyncAdapter(Context context, boolean autoInitialize, boolean allowParallelSyncs) {
		super(context, autoInitialize, allowParallelSyncs);
	}

	@Override
	public void onExecuteSync(Context context, int instance) {
		try {
			ArrayList<String> syncedList = new ArrayList<String>();
			MusicDirectory starredList = musicService.getStarredList(context, null);

			// Pin all the starred stuff
			boolean updated = downloadRecursively(syncedList, starredList, context, true);

			// Get old starred list
			ArrayList<String> oldSyncedList = SyncUtil.getSyncedStarred(context, instance);

			// Check to make sure there aren't any old starred songs that now need to be removed
			oldSyncedList.removeAll(syncedList);

			for(String path: oldSyncedList) {
				File saveFile = new File(path);

				// Unpin file, rename to .complete
				File completeFile = new File(saveFile.getParent(), FileUtil.getBaseName(saveFile.getName()) +
					".complete." + FileUtil.getExtension(saveFile.getName()));

				if(!saveFile.renameTo(completeFile)) {
					Log.w(TAG, "Failed to rename " + path + " to " + completeFile.getPath());
				}
			}

			FileUtil.serialize(context, syncedList, SyncUtil.getStarredSyncFile(context, instance));
			if(updated) {
				SyncUtil.showSyncNotification(context, R.string.sync_new_starred, null);
			}
		} catch(Exception e) {
			Log.e(TAG, "Failed to get starred list for " + Util.getServerName(context, instance));
		}
	}
}