use java 8 in push management service

This commit is contained in:
Daniel Gultsch 2018-02-25 14:39:55 +01:00
parent d4ac8b3122
commit 7557de5479
1 changed files with 35 additions and 48 deletions

View File

@ -13,7 +13,6 @@ import eu.siacs.conversations.R;
import eu.siacs.conversations.entities.Account; import eu.siacs.conversations.entities.Account;
import eu.siacs.conversations.xml.Element; import eu.siacs.conversations.xml.Element;
import eu.siacs.conversations.xml.Namespace; import eu.siacs.conversations.xml.Namespace;
import eu.siacs.conversations.xmpp.OnIqPacketReceived;
import eu.siacs.conversations.xmpp.XmppConnection; import eu.siacs.conversations.xmpp.XmppConnection;
import eu.siacs.conversations.xmpp.forms.Data; import eu.siacs.conversations.xmpp.forms.Data;
import eu.siacs.conversations.xmpp.jid.InvalidJidException; import eu.siacs.conversations.xmpp.jid.InvalidJidException;
@ -32,17 +31,13 @@ public class PushManagementService {
public void registerPushTokenOnServer(final Account account) { public void registerPushTokenOnServer(final Account account) {
Log.d(Config.LOGTAG, account.getJid().toBareJid() + ": has push support"); Log.d(Config.LOGTAG, account.getJid().toBareJid() + ": has push support");
retrieveGcmInstanceToken(new OnGcmInstanceTokenRetrieved() { retrieveGcmInstanceToken(token -> {
@Override
public void onGcmInstanceTokenRetrieved(String token) {
try { try {
final String deviceId = Settings.Secure.getString(mXmppConnectionService.getContentResolver(), Settings.Secure.ANDROID_ID); final String deviceId = Settings.Secure.getString(mXmppConnectionService.getContentResolver(), Settings.Secure.ANDROID_ID);
IqPacket packet = mXmppConnectionService.getIqGenerator().pushTokenToAppServer(Jid.fromString(APP_SERVER), token, deviceId); IqPacket packet = mXmppConnectionService.getIqGenerator().pushTokenToAppServer(Jid.fromString(APP_SERVER), token, deviceId);
mXmppConnectionService.sendIqPacket(account, packet, new OnIqPacketReceived() { mXmppConnectionService.sendIqPacket(account, packet, (a, p) -> {
@Override Element command = p.findChild("command","http://jabber.org/protocol/commands");
public void onIqPacketReceived(Account account, IqPacket packet) { if (p.getType() == IqPacket.TYPE.RESULT && command != null) {
Element command = packet.findChild("command","http://jabber.org/protocol/commands");
if (packet.getType() == IqPacket.TYPE.RESULT && command != null) {
Element x = command.findChild("x", Namespace.DATA); Element x = command.findChild("x", Namespace.DATA);
if (x != null) { if (x != null) {
Data data = Data.parse(x); Data data = Data.parse(x);
@ -51,42 +46,35 @@ public class PushManagementService {
String secret = data.getValue("secret"); String secret = data.getValue("secret");
Jid jid = Jid.fromString(data.getValue("jid")); Jid jid = Jid.fromString(data.getValue("jid"));
if (node != null && secret != null) { if (node != null && secret != null) {
enablePushOnServer(account, jid, node, secret); enablePushOnServer(a, jid, node, secret);
} }
} catch (InvalidJidException e) { } catch (InvalidJidException e) {
e.printStackTrace(); e.printStackTrace();
} }
} }
} else { } else {
Log.d(Config.LOGTAG,account.getJid().toBareJid()+": invalid response from app server"); Log.d(Config.LOGTAG, a.getJid().toBareJid()+": invalid response from app server");
}
} }
}); });
} catch (InvalidJidException ignored) { } catch (InvalidJidException ignored) {
} }
}
}); });
} }
private void enablePushOnServer(final Account account, final Jid jid, final String node, final String secret) { private void enablePushOnServer(final Account account, final Jid jid, final String node, final String secret) {
IqPacket enable = mXmppConnectionService.getIqGenerator().enablePush(jid, node, secret); IqPacket enable = mXmppConnectionService.getIqGenerator().enablePush(jid, node, secret);
mXmppConnectionService.sendIqPacket(account, enable, new OnIqPacketReceived() { mXmppConnectionService.sendIqPacket(account, enable, (a, p) -> {
@Override if (p.getType() == IqPacket.TYPE.RESULT) {
public void onIqPacketReceived(Account account, IqPacket packet) { Log.d(Config.LOGTAG, a.getJid().toBareJid() + ": successfully enabled push on server");
if (packet.getType() == IqPacket.TYPE.RESULT) { } else if (p.getType() == IqPacket.TYPE.ERROR) {
Log.d(Config.LOGTAG, account.getJid().toBareJid() + ": successfully enabled push on server"); Log.d(Config.LOGTAG, a.getJid().toBareJid() + ": enabling push on server failed");
} else if (packet.getType() == IqPacket.TYPE.ERROR) {
Log.d(Config.LOGTAG, account.getJid().toBareJid() + ": enabling push on server failed");
}
} }
}); });
} }
private void retrieveGcmInstanceToken(final OnGcmInstanceTokenRetrieved instanceTokenRetrieved) { private void retrieveGcmInstanceToken(final OnGcmInstanceTokenRetrieved instanceTokenRetrieved) {
new Thread(new Runnable() { new Thread(() -> {
@Override
public void run() {
InstanceID instanceID = InstanceID.getInstance(mXmppConnectionService); InstanceID instanceID = InstanceID.getInstance(mXmppConnectionService);
try { try {
String token = instanceID.getToken(mXmppConnectionService.getString(R.string.gcm_defaultSenderId), GoogleCloudMessaging.INSTANCE_ID_SCOPE, null); String token = instanceID.getToken(mXmppConnectionService.getString(R.string.gcm_defaultSenderId), GoogleCloudMessaging.INSTANCE_ID_SCOPE, null);
@ -94,7 +82,6 @@ public class PushManagementService {
} catch (Exception e) { } catch (Exception e) {
Log.d(Config.LOGTAG,"unable to get push token"); Log.d(Config.LOGTAG,"unable to get push token");
} }
}
}).start(); }).start();
} }