mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2024-11-23 06:42:05 +01:00
Added support for SHIM headers
git-svn-id: http://svn.igniterealtime.org/svn/repos/smack/trunk@11347 b35dd754-fafc-0310-a699-88a17e54d16e
This commit is contained in:
parent
f7a1c750ad
commit
46cebe5e9e
5 changed files with 306 additions and 34 deletions
59
source/org/jivesoftware/smackx/packet/Header.java
Normal file
59
source/org/jivesoftware/smackx/packet/Header.java
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
/*
|
||||||
|
* All rights reserved. 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.smackx.packet;
|
||||||
|
|
||||||
|
import org.jivesoftware.smack.packet.PacketExtension;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a <b>Header</b> entry as specified by the <a href="http://xmpp.org/extensions/xep-031.html">Stanza Headers and Internet Metadata (SHIM)</a>
|
||||||
|
|
||||||
|
* @author Robin Collier
|
||||||
|
*/
|
||||||
|
public class Header implements PacketExtension
|
||||||
|
{
|
||||||
|
private String name;
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
public Header(String name, String value)
|
||||||
|
{
|
||||||
|
this.name = name;
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName()
|
||||||
|
{
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getValue()
|
||||||
|
{
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getElementName()
|
||||||
|
{
|
||||||
|
return "header";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNamespace()
|
||||||
|
{
|
||||||
|
return HeadersExtension.NAMESPACE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toXML()
|
||||||
|
{
|
||||||
|
return "<header name='" + name + "'>" + value + "</header>";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
69
source/org/jivesoftware/smackx/packet/HeadersExtension.java
Normal file
69
source/org/jivesoftware/smackx/packet/HeadersExtension.java
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
/**
|
||||||
|
* All rights reserved. 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.smackx.packet;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
|
||||||
|
import org.jivesoftware.smack.packet.PacketExtension;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extension representing a list of headers as specified in <a href="http://xmpp.org/extensions/xep-0131">Stanza Headers and Internet Metadata (SHIM)</a>
|
||||||
|
*
|
||||||
|
* @see Header
|
||||||
|
*
|
||||||
|
* @author Robin Collier
|
||||||
|
*/
|
||||||
|
public class HeadersExtension implements PacketExtension
|
||||||
|
{
|
||||||
|
public static final String NAMESPACE = "http://jabber.org/protocol/shim";
|
||||||
|
|
||||||
|
private Collection<Header> headers = Collections.EMPTY_LIST;
|
||||||
|
|
||||||
|
public HeadersExtension(Collection<Header> headerList)
|
||||||
|
{
|
||||||
|
if (headerList != null)
|
||||||
|
headers = headerList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Collection<Header> getHeaders()
|
||||||
|
{
|
||||||
|
return headers;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getElementName()
|
||||||
|
{
|
||||||
|
return "headers";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNamespace()
|
||||||
|
{
|
||||||
|
return NAMESPACE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toXML()
|
||||||
|
{
|
||||||
|
StringBuilder builder = new StringBuilder("<" + getElementName() + " xmlns='" + getNamespace() + "'>");
|
||||||
|
|
||||||
|
for (Header header : headers)
|
||||||
|
{
|
||||||
|
builder.append(header.toXML());
|
||||||
|
}
|
||||||
|
builder.append("</" + getElementName() + '>');
|
||||||
|
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
44
source/org/jivesoftware/smackx/provider/HeaderProvider.java
Normal file
44
source/org/jivesoftware/smackx/provider/HeaderProvider.java
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
/**
|
||||||
|
* All rights reserved. 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.smackx.provider;
|
||||||
|
|
||||||
|
import org.jivesoftware.smack.packet.PacketExtension;
|
||||||
|
import org.jivesoftware.smack.provider.PacketExtensionProvider;
|
||||||
|
import org.jivesoftware.smackx.packet.Header;
|
||||||
|
import org.xmlpull.v1.XmlPullParser;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses the header element as defined in <a href="http://xmpp.org/extensions/xep-0131">Stanza Headers and Internet Metadata (SHIM)</a>.
|
||||||
|
*
|
||||||
|
* @author Robin Collier
|
||||||
|
*/
|
||||||
|
public class HeaderProvider implements PacketExtensionProvider
|
||||||
|
{
|
||||||
|
public PacketExtension parseExtension(XmlPullParser parser) throws Exception
|
||||||
|
{
|
||||||
|
String name = parser.getAttributeValue(null, "name");
|
||||||
|
String value = null;
|
||||||
|
|
||||||
|
parser.next();
|
||||||
|
|
||||||
|
if (parser.getEventType() == XmlPullParser.TEXT)
|
||||||
|
value = parser.getText();
|
||||||
|
|
||||||
|
while(parser.getEventType() != XmlPullParser.END_TAG)
|
||||||
|
parser.next();
|
||||||
|
|
||||||
|
return new Header(name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
37
source/org/jivesoftware/smackx/provider/HeadersProvider.java
Normal file
37
source/org/jivesoftware/smackx/provider/HeadersProvider.java
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
/**
|
||||||
|
* All rights reserved. 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.smackx.provider;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.jivesoftware.smack.packet.PacketExtension;
|
||||||
|
import org.jivesoftware.smackx.packet.Header;
|
||||||
|
import org.jivesoftware.smackx.packet.HeadersExtension;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parses the headers element as defined in <a href="http://xmpp.org/extensions/xep-0131">Stanza Headers and Internet Metadata (SHIM)</a>.
|
||||||
|
*
|
||||||
|
* @author Robin Collier
|
||||||
|
*/
|
||||||
|
public class HeadersProvider extends EmbeddedExtensionProvider
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
protected PacketExtension createReturnExtension(String currentElement, String currentNamespace, Map<String, String> attributeMap, List<? extends PacketExtension> content)
|
||||||
|
{
|
||||||
|
return new HeadersExtension((Collection<Header>)content);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -23,13 +23,17 @@ import junit.framework.TestCase;
|
||||||
import org.jivesoftware.smack.ConnectionConfiguration;
|
import org.jivesoftware.smack.ConnectionConfiguration;
|
||||||
import org.jivesoftware.smack.XMPPConnection;
|
import org.jivesoftware.smack.XMPPConnection;
|
||||||
import org.jivesoftware.smack.XMPPException;
|
import org.jivesoftware.smack.XMPPException;
|
||||||
|
import org.jivesoftware.smack.packet.XMPPError;
|
||||||
|
import org.jivesoftware.smack.packet.XMPPError.Type;
|
||||||
import org.xmlpull.mxp1.MXParser;
|
import org.xmlpull.mxp1.MXParser;
|
||||||
import org.xmlpull.v1.XmlPullParser;
|
import org.xmlpull.v1.XmlPullParser;
|
||||||
|
|
||||||
import javax.net.SocketFactory;
|
import javax.net.SocketFactory;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class for all the test cases which provides a pre-configured execution context. This
|
* Base class for all the test cases which provides a pre-configured execution context. This
|
||||||
|
@ -52,7 +56,10 @@ public abstract class SmackTestCase extends TestCase {
|
||||||
private String host = "localhost";
|
private String host = "localhost";
|
||||||
private String serviceName = "localhost";
|
private String serviceName = "localhost";
|
||||||
private int port = 5222;
|
private int port = 5222;
|
||||||
private String usernamnePrefix = "user";
|
private String usernamePrefix = "user";
|
||||||
|
private String passwordPrefix;
|
||||||
|
private boolean samePassword;
|
||||||
|
private List<Integer> createdUserIdx = new ArrayList<Integer>();
|
||||||
|
|
||||||
private String chatDomain = "chat";
|
private String chatDomain = "chat";
|
||||||
private String mucDomain = "conference";
|
private String mucDomain = "conference";
|
||||||
|
@ -136,7 +143,7 @@ public abstract class SmackTestCase extends TestCase {
|
||||||
if (index > getMaxConnections()) {
|
if (index > getMaxConnections()) {
|
||||||
throw new IllegalArgumentException("Index out of bounds");
|
throw new IllegalArgumentException("Index out of bounds");
|
||||||
}
|
}
|
||||||
return usernamnePrefix + index;
|
return usernamePrefix + (index + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -209,22 +216,39 @@ public abstract class SmackTestCase extends TestCase {
|
||||||
// that will not resolve as a network connection.
|
// that will not resolve as a network connection.
|
||||||
host = connections[0].getHost();
|
host = connections[0].getHost();
|
||||||
serviceName = connections[0].getServiceName();
|
serviceName = connections[0].getServiceName();
|
||||||
// Create the test accounts
|
|
||||||
if (!getConnection(0).getAccountManager().supportsAccountCreation())
|
|
||||||
fail("Server does not support account creation");
|
|
||||||
|
|
||||||
for (int i = 0; i < getMaxConnections(); i++) {
|
for (int i = 0; i < getMaxConnections(); i++) {
|
||||||
// Create the test account
|
String password = usernamePrefix + (i+1);
|
||||||
try {
|
String currentUser = password;
|
||||||
getConnection(i).getAccountManager().createAccount(usernamnePrefix + i, usernamnePrefix + i);
|
|
||||||
} catch (XMPPException e) {
|
if (passwordPrefix != null)
|
||||||
// Do nothing if the accout already exists
|
password = (samePassword ? passwordPrefix : passwordPrefix + (i+1));
|
||||||
if (e.getXMPPError() == null || e.getXMPPError().getCode() != 409) {
|
|
||||||
throw e;
|
try
|
||||||
}
|
{
|
||||||
}
|
getConnection(i).login(currentUser, password, "Smack");
|
||||||
// Login with the new test account
|
}
|
||||||
getConnection(i).login(usernamnePrefix + i, usernamnePrefix + i, "Smack");
|
catch (XMPPException e)
|
||||||
|
{
|
||||||
|
e.printStackTrace();
|
||||||
|
|
||||||
|
// Create the test accounts
|
||||||
|
if (!getConnection(0).getAccountManager().supportsAccountCreation())
|
||||||
|
fail("Server does not support account creation");
|
||||||
|
|
||||||
|
// Create the account and try logging in again as the
|
||||||
|
// same user.
|
||||||
|
try
|
||||||
|
{
|
||||||
|
createAccount(i, currentUser, password);
|
||||||
|
}
|
||||||
|
catch (Exception e1)
|
||||||
|
{
|
||||||
|
e1.printStackTrace();
|
||||||
|
fail("Could not create user: " + currentUser);
|
||||||
|
}
|
||||||
|
i--;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// Let the server process the available presences
|
// Let the server process the available presences
|
||||||
Thread.sleep(150);
|
Thread.sleep(150);
|
||||||
|
@ -235,26 +259,61 @@ public abstract class SmackTestCase extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void tearDown() throws Exception {
|
protected void connectAndLogin(int connectionIndex) throws XMPPException
|
||||||
|
{
|
||||||
|
String password = usernamePrefix + connectionIndex;
|
||||||
|
|
||||||
|
if (passwordPrefix != null)
|
||||||
|
password = (samePassword ? passwordPrefix : passwordPrefix + connectionIndex);
|
||||||
|
|
||||||
|
XMPPConnection con = getConnection(connectionIndex);
|
||||||
|
|
||||||
|
if (!con.isConnected())
|
||||||
|
con.connect();
|
||||||
|
con.login(usernamePrefix + connectionIndex, password, "Smack");
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void disconnect(int connectionIndex) throws XMPPException
|
||||||
|
{
|
||||||
|
getConnection(connectionIndex).disconnect();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createAccount(int connectionIdx, String username, String password)
|
||||||
|
{
|
||||||
|
// Create the test account
|
||||||
|
try {
|
||||||
|
getConnection(connectionIdx).getAccountManager().createAccount(username, password);
|
||||||
|
createdUserIdx.add(connectionIdx);
|
||||||
|
} catch (XMPPException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
fail(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void tearDown() throws Exception {
|
||||||
super.tearDown();
|
super.tearDown();
|
||||||
|
|
||||||
for (int i = 0; i < getMaxConnections(); i++) {
|
for (int i = 0; i < getMaxConnections(); i++)
|
||||||
try {
|
{
|
||||||
// If not connected, connect so that we can delete the account.
|
if (createdUserIdx.contains(i))
|
||||||
if (!getConnection(i).isConnected()) {
|
{
|
||||||
XMPPConnection con = getConnection(i);
|
try {
|
||||||
con.connect();
|
// If not connected, connect so that we can delete the account.
|
||||||
con.login(getUsername(i), getUsername(i));
|
if (!getConnection(i).isConnected()) {
|
||||||
|
XMPPConnection con = getConnection(i);
|
||||||
|
con.connect();
|
||||||
|
con.login(getUsername(i), getUsername(i));
|
||||||
|
}
|
||||||
|
else if (!getConnection(i).isAuthenticated()) {
|
||||||
|
getConnection(i).login(getUsername(i), getUsername(i));
|
||||||
|
}
|
||||||
|
// Delete the created account for the test
|
||||||
|
getConnection(i).getAccountManager().deleteAccount();
|
||||||
}
|
}
|
||||||
else if (!getConnection(i).isAuthenticated()) {
|
catch (Exception e) {
|
||||||
getConnection(i).login(getUsername(i), getUsername(i));
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
// Delete the created account for the test
|
}
|
||||||
getConnection(i).getAccountManager().deleteAccount();
|
|
||||||
}
|
|
||||||
catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
if (getConnection(i).isConnected()) {
|
if (getConnection(i).isConnected()) {
|
||||||
// Close the connection
|
// Close the connection
|
||||||
getConnection(i).disconnect();
|
getConnection(i).disconnect();
|
||||||
|
@ -334,7 +393,11 @@ public abstract class SmackTestCase extends TestCase {
|
||||||
mucDomain = parser.nextText();
|
mucDomain = parser.nextText();
|
||||||
}
|
}
|
||||||
else if (parser.getName().equals("username")) {
|
else if (parser.getName().equals("username")) {
|
||||||
usernamnePrefix = parser.nextText();
|
usernamePrefix = parser.nextText();
|
||||||
|
}
|
||||||
|
else if (parser.getName().equals("password")) {
|
||||||
|
samePassword = "true".equals(parser.getAttributeValue(0));
|
||||||
|
passwordPrefix = parser.nextText();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
eventType = parser.next();
|
eventType = parser.next();
|
||||||
|
|
Loading…
Reference in a new issue