2
0
mirror of https://github.com/KDE/kdeconnect-android synced 2025-08-22 18:07:55 +00:00

199 lines
6.3 KiB
Java
Raw Normal View History

2013-06-06 05:57:06 +02:00
package org.kde.connect;
import android.app.Service;
import android.content.Context;
2013-06-06 05:57:06 +02:00
import android.content.Intent;
import android.content.IntentFilter;
2013-06-06 05:57:06 +02:00
import android.content.SharedPreferences;
import android.os.Binder;
import android.os.Handler;
2013-06-06 05:57:06 +02:00
import android.os.IBinder;
import android.os.Looper;
import android.preference.PreferenceManager;
2013-06-06 05:57:06 +02:00
import android.util.Log;
2013-06-18 03:05:32 +02:00
import org.kde.connect.ComputerLinks.BaseComputerLink;
2013-07-02 15:22:05 +02:00
import org.kde.connect.LinkProviders.BaseLinkProvider;
2013-08-07 10:44:52 +02:00
import org.kde.connect.LinkProviders.BroadcastTcpLinkProvider;
2013-06-06 05:57:06 +02:00
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Set;
2013-06-06 05:57:06 +02:00
2013-06-19 16:15:25 +02:00
public class BackgroundService extends Service {
2013-06-06 05:57:06 +02:00
2013-08-08 04:26:06 +02:00
private ArrayList<BaseLinkProvider> linkProviders = new ArrayList<BaseLinkProvider>();
2013-08-08 04:26:06 +02:00
private HashMap<String, Device> devices = new HashMap<String, Device>();
2013-06-06 05:57:06 +02:00
private void loadRememberedDevicesFromSettings() {
SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());
Set<String> trustedDevices = preferences.getStringSet("trusted", new HashSet<String>());
for(String deviceId : trustedDevices) {
Log.e("loadRememberedDevicesFromSettings",deviceId);
devices.put(deviceId,new Device(getApplicationContext(), deviceId));
}
}
public void registerLinkProviders() {
SharedPreferences settings = PreferenceManager.getDefaultSharedPreferences(this);
if (settings.getBoolean("avahitcp_link", true)) {
2013-08-07 10:44:52 +02:00
//linkProviders.add(new AvahiTcpLinkProvider(this));
}
2013-08-07 10:44:52 +02:00
if (settings.getBoolean("broadcasttcp_link", true)) {
linkProviders.add(new BroadcastTcpLinkProvider(this));
}
}
public Device getDevice(String id) {
return devices.get(id);
}
private BaseLinkProvider.ConnectionReceiver deviceListener = new BaseLinkProvider.ConnectionReceiver() {
@Override
public void onConnectionReceived(final NetworkPackage identityPackage, final BaseComputerLink link) {
Log.i("BackgroundService", "Connection accepted!");
runOnMainThread(new Runnable() { //Some plugins that create Handlers will crash if started from a different thread!
@Override
public void run() {
String deviceId = identityPackage.getString("deviceId");
String name = identityPackage.getString("deviceName");
if (devices.containsKey(deviceId)) {
Log.i("BackgroundService", "known device");
Device device = devices.get(deviceId);
if (!device.hasName()) device.setName(identityPackage.getString("deviceName"));
device.addLink(link);
} else {
Log.i("BackgroundService", "unknown device");
Device device = new Device(getApplicationContext(), deviceId, name, link);
devices.put(deviceId, device);
}
}
});
}
@Override
public void onConnectionLost(BaseComputerLink link) {
Device d = devices.get(link.getDeviceId());
if (d != null) {
d.removeLink(link);
if (!d.isReachable() && !d.isTrusted()) {
devices.remove(link.getDeviceId());
}
}
}
};
public HashMap<String, Device> getDevices() {
return devices;
2013-06-18 03:05:32 +02:00
}
//This will be called for each intent launch, even if the service is already started and is reused
2013-06-17 12:23:08 +02:00
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.i("BackgroundService","onStartCommand");
for (InstanceCallback c : callbacks) {
c.onServiceStart(this);
}
callbacks.clear();
return Service.START_STICKY;
}
public void startDiscovery() {
Log.i("BackgroundService","StartDiscovery");
for (BaseLinkProvider a : linkProviders) {
a.onStart();
}
}
public void stopDiscovery() {
Log.i("BackgroundService","StopDiscovery");
for (BaseLinkProvider a : linkProviders) {
a.onStop();
}
}
2013-08-07 10:44:52 +02:00
public void onNetworkChange() {
Log.i("BackgroundService","OnNetworkChange");
for (BaseLinkProvider a : linkProviders) {
a.onNetworkChange();
}
}
public void addConnectionListener(BaseLinkProvider.ConnectionReceiver cr) {
Log.i("BackgroundService","Registering connection listener");
for (BaseLinkProvider a : linkProviders) {
a.addConnectionReceiver(cr);
2013-06-17 12:23:08 +02:00
}
2013-06-06 05:57:06 +02:00
}
//This will called only once, even if we launch the service intent several times
2013-06-06 05:57:06 +02:00
@Override
public void onCreate() {
2013-07-02 15:22:05 +02:00
super.onCreate();
// Register screen on listener
IntentFilter filter = new IntentFilter(Intent.ACTION_SCREEN_ON);
registerReceiver(new KdeConnectBroadcastReceiver(), filter);
Log.i("BackgroundService","Service not started yet, initializing...");
2013-06-17 12:23:08 +02:00
loadRememberedDevicesFromSettings();
registerLinkProviders();
//Link Providers need to be already registered
addConnectionListener(deviceListener);
startDiscovery();
}
2013-06-17 12:23:08 +02:00
2013-06-06 05:57:06 +02:00
@Override
public void onDestroy() {
Log.i("BackgroundService", "Destroying");
stopDiscovery();
2013-06-06 05:57:06 +02:00
super.onDestroy();
}
@Override
public IBinder onBind (Intent intent) {
return new Binder();
}
//To use the service from the gui
2013-07-02 15:22:05 +02:00
public interface InstanceCallback {
void onServiceStart(BackgroundService service);
}
2013-07-02 15:22:05 +02:00
private static ArrayList<InstanceCallback> callbacks = new ArrayList<InstanceCallback>();
public static void Start(Context c) {
2013-07-02 15:22:05 +02:00
RunCommand(c, null);
}
2013-07-02 15:22:05 +02:00
public static void RunCommand(Context c, final InstanceCallback callback) {
if (callback != null) callbacks.add(callback);
Intent serviceIntent = new Intent(c, BackgroundService.class);
c.startService(serviceIntent);
2013-07-02 15:22:05 +02:00
}
Handler mainHandler = new Handler(Looper.getMainLooper());
private void runOnMainThread(Runnable runnable) {
mainHandler.post(runnable);
}
2013-06-06 05:57:06 +02:00
}