2014-09-13 11:03:40 +02:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Copyright © 2014 Florian Schmaus
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
package org.jivesoftware.smack.util;
|
|
|
|
|
|
|
|
import java.util.Collection;
|
|
|
|
|
2015-02-26 18:41:17 +01:00
|
|
|
import org.jivesoftware.smack.packet.ExtensionElement;
|
2014-09-13 11:03:40 +02:00
|
|
|
|
|
|
|
public class PacketUtil {
|
|
|
|
|
2017-12-19 15:06:40 +01:00
|
|
|
/**
|
|
|
|
* Get a extension element from a collection.
|
2019-08-30 12:08:30 +02:00
|
|
|
* @param collection TODO javadoc me please
|
|
|
|
* @param element TODO javadoc me please
|
|
|
|
* @param namespace TODO javadoc me please
|
|
|
|
* @param <PE> the type of the extension element.
|
2017-12-19 15:06:40 +01:00
|
|
|
* @return the extension element
|
|
|
|
* @deprecated use {@link #extensionElementFrom(Collection, String, String)} instead.
|
|
|
|
*/
|
|
|
|
@Deprecated
|
|
|
|
public static <PE extends ExtensionElement> PE packetExtensionfromCollection(
|
|
|
|
Collection<ExtensionElement> collection, String element,
|
|
|
|
String namespace) {
|
|
|
|
return extensionElementFrom(collection, element, namespace);
|
|
|
|
}
|
|
|
|
|
2015-01-19 08:38:41 +01:00
|
|
|
/**
|
2015-03-29 12:15:32 +02:00
|
|
|
* Get a extension element from a collection.
|
2015-01-19 08:38:41 +01:00
|
|
|
*
|
2017-12-23 20:21:19 +01:00
|
|
|
* @param collection Collection of ExtensionElements.
|
|
|
|
* @param element name of the targeted ExtensionElement.
|
|
|
|
* @param namespace namespace of the targeted ExtensionElement.
|
|
|
|
* @param <PE> Type of the ExtensionElement
|
|
|
|
*
|
2015-01-19 08:38:41 +01:00
|
|
|
* @return the extension element
|
|
|
|
* @deprecated use {@link #extensionElementFrom(Collection, String, String)} instead
|
|
|
|
*/
|
|
|
|
@Deprecated
|
2017-12-13 23:10:11 +01:00
|
|
|
public static <PE extends ExtensionElement> PE packetExtensionFromCollection(
|
2015-02-26 18:41:17 +01:00
|
|
|
Collection<ExtensionElement> collection, String element,
|
2014-09-13 11:03:40 +02:00
|
|
|
String namespace) {
|
2015-01-19 08:38:41 +01:00
|
|
|
return extensionElementFrom(collection, element, namespace);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-03-29 12:15:32 +02:00
|
|
|
* Get a extension element from a collection.
|
2015-01-19 08:38:41 +01:00
|
|
|
*
|
2017-12-23 20:21:19 +01:00
|
|
|
* @param collection Collection of ExtensionElements.
|
|
|
|
* @param element name of the targeted ExtensionElement.
|
|
|
|
* @param namespace namespace of the targeted ExtensionElement.
|
|
|
|
* @param <PE> Type of the ExtensionElement
|
|
|
|
*
|
2015-01-19 08:38:41 +01:00
|
|
|
* @return the extension element
|
|
|
|
*/
|
|
|
|
@SuppressWarnings("unchecked")
|
2015-02-26 18:41:17 +01:00
|
|
|
public static <PE extends ExtensionElement> PE extensionElementFrom(Collection<ExtensionElement> collection,
|
2015-01-19 08:38:41 +01:00
|
|
|
String element, String namespace) {
|
2015-02-26 18:41:17 +01:00
|
|
|
for (ExtensionElement packetExtension : collection) {
|
2014-09-13 11:03:40 +02:00
|
|
|
if ((element == null || packetExtension.getElementName().equals(
|
|
|
|
element))
|
|
|
|
&& packetExtension.getNamespace().equals(namespace)) {
|
|
|
|
return (PE) packetExtension;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|