package org.tvbrowser.tvbrowser;
import java.util.ArrayList;
import java.util.HashSet;
import org.tvbrowser.content.TvBrowserContentProvider;
import org.tvbrowser.utils.IOUtils;
import org.tvbrowser.utils.UiUtils;
import android.app.Service;
import android.content.ContentResolver;
import android.content.Intent;
import android.database.Cursor;
import android.os.IBinder;
import android.text.TextUtils;
import android.util.Log;
public class ServiceChannelCleaner extends Service {
public ServiceChannelCleaner() {
}
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
new Thread("CLEAN CHANNELS") {
@Override
public void run() {
if(IOUtils.isDatabaseAccessible(ServiceChannelCleaner.this)) {
final ContentResolver cr = getContentResolver();
final String[] projection = {
TvBrowserContentProvider.KEY_ID,
TvBrowserContentProvider.CHANNEL_KEY_CHANNEL_ID,
TvBrowserContentProvider.GROUP_KEY_GROUP_ID
};
final Cursor channels = cr.query(TvBrowserContentProvider.CONTENT_URI_CHANNELS, projection, null, null, TvBrowserContentProvider.KEY_ID);
final HashSet<String> knownChannels = new HashSet<String>();
final ArrayList<String> toDelete = new ArrayList<String>();
try {
if(IOUtils.prepareAccess(channels)) {
final int keyIndex = channels.getColumnIndex(TvBrowserContentProvider.KEY_ID);
final int channelKeyIndex = channels.getColumnIndex(TvBrowserContentProvider.CHANNEL_KEY_CHANNEL_ID);
final int groupKeyIndex = channels.getColumnIndex(TvBrowserContentProvider.GROUP_KEY_GROUP_ID);
while(channels.moveToNext()) {
final int key = channels.getInt(keyIndex);
final String channelGroupKey = getChannelGroupKey(channels.getString(channelKeyIndex),channels.getInt(groupKeyIndex));
if(knownChannels.contains(channelGroupKey)) {
toDelete.add(String.valueOf(key));
}
else {
knownChannels.add(channelGroupKey);
}
}
}
}finally{
IOUtils.close(channels);
}
if(!toDelete.isEmpty()) {
int rows = cr.delete(TvBrowserContentProvider.CONTENT_URI_DATA, TvBrowserContentProvider.CHANNEL_KEY_CHANNEL_ID + " IN ( " + TextUtils.join(", ", toDelete) + " ) ", null);
Log.d("info4", "DELETED DATA ROWS " + rows);
rows = cr.delete(TvBrowserContentProvider.CONTENT_URI_CHANNELS, TvBrowserContentProvider.KEY_ID + " IN ( " + TextUtils.join(", ", toDelete) + " ) ", null);
Log.d("info4", "DELETED CHANNEL ROWS " + rows);
}
UiUtils.updateRunningProgramsWidget(getApplicationContext());
UiUtils.updateImportantProgramsWidget(getApplicationContext());
stopSelf();
}
}
}.start();
return Service.START_NOT_STICKY;
}
private static final String getChannelGroupKey(String channelKey, int groupKey) {
return new StringBuilder(channelKey).append(";").append(groupKey).toString();
}
}