mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2024-11-29 09:42:06 +01:00
[softwareinfo] Remove SoftwareInfoManager.isSupported(Jid)
SoftwareInfoManager.fromJid(Jid) will return 'null' if the jid in question does not announce or support this.
This commit is contained in:
parent
027358fc63
commit
54d6bc8658
1 changed files with 4 additions and 24 deletions
|
@ -20,7 +20,6 @@ import java.util.Map;
|
||||||
import java.util.WeakHashMap;
|
import java.util.WeakHashMap;
|
||||||
|
|
||||||
import org.jivesoftware.smack.Manager;
|
import org.jivesoftware.smack.Manager;
|
||||||
import org.jivesoftware.smack.SmackException.FeatureNotSupportedException;
|
|
||||||
import org.jivesoftware.smack.SmackException.NoResponseException;
|
import org.jivesoftware.smack.SmackException.NoResponseException;
|
||||||
import org.jivesoftware.smack.SmackException.NotConnectedException;
|
import org.jivesoftware.smack.SmackException.NotConnectedException;
|
||||||
import org.jivesoftware.smack.XMPPConnection;
|
import org.jivesoftware.smack.XMPPConnection;
|
||||||
|
@ -41,7 +40,6 @@ import org.jxmpp.jid.Jid;
|
||||||
*/
|
*/
|
||||||
public final class SoftwareInfoManager extends Manager {
|
public final class SoftwareInfoManager extends Manager {
|
||||||
|
|
||||||
private static final String FEATURE = "http://jabber.org/protocol/disco";
|
|
||||||
private static final Map<XMPPConnection, SoftwareInfoManager> INSTANCES = new WeakHashMap<>();
|
private static final Map<XMPPConnection, SoftwareInfoManager> INSTANCES = new WeakHashMap<>();
|
||||||
private final ServiceDiscoveryManager serviceDiscoveryManager;
|
private final ServiceDiscoveryManager serviceDiscoveryManager;
|
||||||
|
|
||||||
|
@ -59,20 +57,6 @@ public final class SoftwareInfoManager extends Manager {
|
||||||
serviceDiscoveryManager = ServiceDiscoveryManager.getInstanceFor(connection);
|
serviceDiscoveryManager = ServiceDiscoveryManager.getInstanceFor(connection);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if the feature is supported by the Jid.
|
|
||||||
* <br>
|
|
||||||
* @param jid Jid to be checked for support
|
|
||||||
* @return boolean
|
|
||||||
* @throws NoResponseException if there was no response from the remote entity
|
|
||||||
* @throws XMPPErrorException if there was an XMPP error returned
|
|
||||||
* @throws NotConnectedException if the XMPP connection is not connected
|
|
||||||
* @throws InterruptedException if the calling thread was interrupted
|
|
||||||
*/
|
|
||||||
public boolean isSupported(Jid jid) throws NoResponseException, XMPPErrorException, NotConnectedException, InterruptedException {
|
|
||||||
return serviceDiscoveryManager.supportsFeatures(jid, FEATURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Publishes the provided {@link SoftwareInfoForm} as an extended info.
|
* Publishes the provided {@link SoftwareInfoForm} as an extended info.
|
||||||
* <br>
|
* <br>
|
||||||
|
@ -83,20 +67,16 @@ public final class SoftwareInfoManager extends Manager {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get SoftwareInfoForm from Jid provided.
|
* Get Software Information from the provided XMPP address. Returns <code>null</code> in case the queried entity does not announce that information.
|
||||||
* <br>
|
*
|
||||||
* @param jid jid to get software information from
|
* @param jid jid to get software information from
|
||||||
* @return {@link SoftwareInfoForm} Form containing software information
|
* @return {@link SoftwareInfoForm} Form containing software information or <code>null</code>.
|
||||||
* @throws NoResponseException if there was no response from the remote entity
|
* @throws NoResponseException if there was no response from the remote entity
|
||||||
* @throws XMPPErrorException if there was an XMPP error returned
|
* @throws XMPPErrorException if there was an XMPP error returned
|
||||||
* @throws NotConnectedException if the XMPP connection is not connected
|
* @throws NotConnectedException if the XMPP connection is not connected
|
||||||
* @throws InterruptedException if the calling thread was interrupted
|
* @throws InterruptedException if the calling thread was interrupted
|
||||||
* @throws FeatureNotSupportedException if the feature is not supported
|
|
||||||
*/
|
*/
|
||||||
public SoftwareInfoForm fromJid(Jid jid) throws NoResponseException, XMPPErrorException, NotConnectedException, InterruptedException, FeatureNotSupportedException {
|
public SoftwareInfoForm fromJid(Jid jid) throws NoResponseException, XMPPErrorException, NotConnectedException, InterruptedException {
|
||||||
if (!isSupported(jid)) {
|
|
||||||
throw new FeatureNotSupportedException(SoftwareInfoForm.FORM_TYPE, jid);
|
|
||||||
}
|
|
||||||
DiscoverInfo discoverInfo = serviceDiscoveryManager.discoverInfo(jid);
|
DiscoverInfo discoverInfo = serviceDiscoveryManager.discoverInfo(jid);
|
||||||
DataForm dataForm = DataForm.from(discoverInfo, SoftwareInfoForm.FORM_TYPE);
|
DataForm dataForm = DataForm.from(discoverInfo, SoftwareInfoForm.FORM_TYPE);
|
||||||
if (dataForm == null) {
|
if (dataForm == null) {
|
||||||
|
|
Loading…
Reference in a new issue