Mercury-IM/core-old/src/main/java/org/mercury_im/messenger/core/connection/MercuryConnection.java

140 lines
5.0 KiB
Java
Raw Normal View History

2019-08-25 17:54:03 +02:00
package org.mercury_im.messenger.core.connection;
2019-05-27 21:34:11 +02:00
2019-07-02 00:46:40 +02:00
import org.jivesoftware.smack.AbstractXMPPConnection;
2019-06-21 03:45:33 +02:00
import org.jivesoftware.smack.ConnectionListener;
2019-07-02 00:46:40 +02:00
import org.jivesoftware.smack.ReconnectionManager;
2019-08-12 17:05:30 +02:00
import org.jivesoftware.smack.SmackException;
2019-05-27 21:34:11 +02:00
import org.jivesoftware.smack.XMPPConnection;
2019-08-12 17:05:30 +02:00
import org.jivesoftware.smack.XMPPException;
2019-06-21 03:45:33 +02:00
import org.jivesoftware.smack.chat2.ChatManager;
2019-08-12 17:05:30 +02:00
import org.jivesoftware.smack.packet.Presence;
2019-05-27 21:34:11 +02:00
import org.jivesoftware.smack.roster.Roster;
2019-06-21 03:45:33 +02:00
import org.jivesoftware.smackx.carbons.CarbonManager;
2019-07-02 00:46:40 +02:00
import org.jivesoftware.smackx.disco.ServiceDiscoveryManager;
import org.jivesoftware.smackx.disco.packet.DiscoverInfo;
2019-08-10 21:50:03 +02:00
import org.jivesoftware.smackx.iqversion.VersionManager;
2019-09-08 04:47:59 +02:00
import org.jivesoftware.smackx.mam.MamManager;
2019-06-30 13:37:36 +02:00
import org.jivesoftware.smackx.sid.StableUniqueStanzaIdManager;
2019-06-24 01:41:17 +02:00
2019-08-12 17:05:30 +02:00
import java.io.IOException;
import java.util.logging.Level;
2019-06-24 01:41:17 +02:00
import java.util.logging.Logger;
2019-05-27 21:34:11 +02:00
2019-08-12 17:05:30 +02:00
import io.reactivex.subjects.BehaviorSubject;
public class MercuryConnection {
2019-06-21 03:45:33 +02:00
public static final String TAG = "Mercury";
2019-05-27 21:34:11 +02:00
2019-06-24 01:41:17 +02:00
private static final Logger LOGGER = Logger.getLogger(MercuryConnection.class.getName());
private final AbstractXMPPConnection mConnection;
private final long mAccountId;
2019-06-21 03:45:33 +02:00
// Managers
private final ReconnectionManager mReconnectionManager;
private final Roster mRoster;
private final ChatManager mChatManager;
private final CarbonManager mCarbonManager;
private final StableUniqueStanzaIdManager mStanzaIdManager;
private final ServiceDiscoveryManager mServiceDiscoveryManager;
private final MamManager mMamManager;
private final VersionManager mVersionManager;
2019-06-30 13:37:36 +02:00
private BehaviorSubject<ConnectionState> mState = BehaviorSubject.createDefault(ConnectionState.DISCONNECTED);
2019-08-12 17:05:30 +02:00
2019-08-04 04:22:08 +02:00
public MercuryConnection(AbstractXMPPConnection connection, long accountId) {
mConnection = connection;
mConnection.addConnectionListener(mConnectionListener);
mAccountId = accountId;
2019-05-27 21:34:11 +02:00
mReconnectionManager = ReconnectionManager.getInstanceFor(connection);
mReconnectionManager.enableAutomaticReconnection();
mReconnectionManager.abortPossiblyRunningReconnection();
2019-07-02 00:46:40 +02:00
mRoster = Roster.getInstanceFor(connection);
mRoster.setRosterLoadedAtLogin(true);
2019-06-30 13:37:36 +02:00
mChatManager = ChatManager.getInstanceFor(connection);
mCarbonManager = CarbonManager.getInstanceFor(connection);
mStanzaIdManager = StableUniqueStanzaIdManager.getInstanceFor(connection);
mStanzaIdManager.enable();
mServiceDiscoveryManager = ServiceDiscoveryManager.getInstanceFor(connection);
mServiceDiscoveryManager.setIdentity(new DiscoverInfo.Identity("client", "Mercury", "phone"));
mVersionManager = VersionManager.getInstanceFor(connection);
mVersionManager.setVersion("Mercury", "0.0.1-stealth", "Android");
2019-08-26 09:11:45 +02:00
VersionManager.setAutoAppendSmackVersion(false);
2019-09-08 04:47:59 +02:00
mMamManager = MamManager.getInstanceFor(connection);
2019-05-27 21:34:11 +02:00
}
public void connect() throws InterruptedException, XMPPException, SmackException, IOException {
2019-08-12 17:05:30 +02:00
LOGGER.log(Level.INFO, "Connecting...");
mState.onNext(ConnectionState.CONNECTING);
2019-08-12 17:05:30 +02:00
AbstractXMPPConnection con = (AbstractXMPPConnection) getConnection();
con.connect().login();
2019-08-12 17:05:30 +02:00
}
public void disconnect() throws SmackException.NotConnectedException {
2019-08-12 17:05:30 +02:00
AbstractXMPPConnection con = (AbstractXMPPConnection) getConnection();
mState.onNext(ConnectionState.DISCONNECTING);
con.disconnect(new Presence(Presence.Type.unavailable));
mState.onNext(ConnectionState.DISCONNECTED);
2019-08-12 17:05:30 +02:00
}
2019-05-27 21:34:11 +02:00
public XMPPConnection getConnection() {
return mConnection;
2019-05-27 21:34:11 +02:00
}
public long getAccountId() {
return mAccountId;
2019-05-27 21:34:11 +02:00
}
public Roster getRoster() {
return mRoster;
2019-05-27 21:34:11 +02:00
}
2019-06-21 03:45:33 +02:00
private final ConnectionListener mConnectionListener = new ConnectionListener() {
2019-08-12 17:05:30 +02:00
@Override
public void connected(XMPPConnection connection) {
mState.onNext(ConnectionState.CONNECTED);
2019-06-21 03:45:33 +02:00
}
2019-08-12 17:05:30 +02:00
@Override
public void authenticated(XMPPConnection connection, boolean resumed) {
mState.onNext(ConnectionState.AUTHENTICATED);
2019-08-12 17:05:30 +02:00
LOGGER.info("Connection " + getAccountId() + " authenticated (" + (resumed ? "resumed" : "initially") + ")");
if (!resumed) {
LOGGER.info("Enabling carbons!");
mCarbonManager.enableCarbonsAsync(exception -> {
LOGGER.severe("Could not enable carbons for connection " + mAccountId + ".");
2019-08-12 17:05:30 +02:00
exception.printStackTrace();
});
}
}
2019-06-21 03:45:33 +02:00
2019-08-12 17:05:30 +02:00
@Override
public void connectionClosed() {
mState.onNext(ConnectionState.DISCONNECTED);
2019-08-12 17:05:30 +02:00
}
2019-07-03 00:56:55 +02:00
2019-08-12 17:05:30 +02:00
@Override
public void connectionClosedOnError(Exception e) {
mState.onNext(ConnectionState.DISCONNECTED);
2019-08-12 17:05:30 +02:00
}
};
public BehaviorSubject<ConnectionState> getState() {
return mState;
}
2019-05-27 21:34:11 +02:00
}