mirror of
https://github.com/vanitasvitae/Smack.git
synced 2025-01-07 02:17:57 +01:00
Add first dirty send test
This commit is contained in:
parent
2cbbfd1048
commit
0b28e8b467
8 changed files with 142 additions and 20 deletions
|
@ -0,0 +1,31 @@
|
|||
package org.jivesoftware.smackx.jingle_filetransfer;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
import java.io.IOException;
|
||||
|
||||
/**
|
||||
* Dirty.
|
||||
*/
|
||||
public final class DirtyHelper {
|
||||
|
||||
public static byte[] readFile(File file) throws IOException {
|
||||
byte[] bytes = null;
|
||||
int read;
|
||||
FileInputStream fin = null;
|
||||
try {
|
||||
fin = new FileInputStream(file);
|
||||
bytes = new byte[(int) file.length()];
|
||||
read = fin.read(bytes);
|
||||
} finally {
|
||||
if (fin != null) {
|
||||
fin.close();
|
||||
}
|
||||
}
|
||||
if (read == -1) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return bytes;
|
||||
}
|
||||
}
|
|
@ -17,11 +17,35 @@
|
|||
package org.jivesoftware.smackx.jingle_filetransfer;
|
||||
|
||||
import org.jivesoftware.smack.Manager;
|
||||
import org.jivesoftware.smack.SmackException;
|
||||
import org.jivesoftware.smack.XMPPConnection;
|
||||
import org.jivesoftware.smack.XMPPException;
|
||||
import org.jivesoftware.smack.packet.IQ;
|
||||
import org.jivesoftware.smackx.bytestreams.ibb.InBandBytestreamManager;
|
||||
import org.jivesoftware.smackx.bytestreams.ibb.InBandBytestreamSession;
|
||||
import org.jivesoftware.smackx.hash.HashManager;
|
||||
import org.jivesoftware.smackx.hash.element.HashElement;
|
||||
import org.jivesoftware.smackx.jingle.JingleManager;
|
||||
import org.jivesoftware.smackx.jingle.JingleSessionHandler;
|
||||
import org.jivesoftware.smackx.jingle.element.Jingle;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleAction;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContent;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
|
||||
import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleContentDescriptionFileTransfer;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleFileTransferPayload;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.provider.JingleContentDescriptionFileTransferProvider;
|
||||
import org.jivesoftware.smackx.jingle_ibb.JingleInBandByteStreamManager;
|
||||
import org.jivesoftware.smackx.jingle_ibb.element.JingleInBandByteStreamTransport;
|
||||
import org.jxmpp.jid.FullJid;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Date;
|
||||
import java.util.WeakHashMap;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
|
||||
/**
|
||||
* Manager for Jingle File Transfers.
|
||||
|
@ -30,6 +54,8 @@ import java.util.WeakHashMap;
|
|||
*/
|
||||
public final class JingleFileTransferManager extends Manager {
|
||||
|
||||
private static final Logger LOGGER = Logger.getLogger(JingleFileTransferManager.class.getName());
|
||||
|
||||
public static final String NAMESPACE_V5 = "urn:xmpp:jingle:apps:file-transfer:5";
|
||||
|
||||
private static final WeakHashMap<XMPPConnection, JingleFileTransferManager> INSTANCES = new WeakHashMap<>();
|
||||
|
@ -59,4 +85,69 @@ public final class JingleFileTransferManager extends Manager {
|
|||
}
|
||||
return manager;
|
||||
}
|
||||
|
||||
/**
|
||||
* QnD method.
|
||||
* @param file
|
||||
*/
|
||||
public void sendFile(File file, final FullJid recipient) throws IOException, SmackException.NotConnectedException, InterruptedException {
|
||||
final byte[] bytes = DirtyHelper.readFile(file);
|
||||
if (bytes == null) {
|
||||
LOGGER.log(Level.SEVERE, "bytes are null.");
|
||||
return;
|
||||
}
|
||||
Date lastModified = new Date(file.lastModified());
|
||||
JingleFileTransferPayload payload = new JingleFileTransferPayload(
|
||||
lastModified, "A file", HashElement.fromData(HashManager.ALGORITHM.SHA_256, bytes),
|
||||
"application/octet-stream", file.getName(), (int) file.length(), null);
|
||||
ArrayList<JingleContentDescriptionPayloadType> payloadTypes = new ArrayList<>();
|
||||
payloadTypes.add(payload);
|
||||
|
||||
JingleContentDescriptionFileTransfer descriptionFileTransfer = new JingleContentDescriptionFileTransfer(payloadTypes);
|
||||
final JingleInBandByteStreamTransport transport = new JingleInBandByteStreamTransport();
|
||||
JingleContent.Builder cb = JingleContent.getBuilder();
|
||||
cb.setDescription(descriptionFileTransfer)
|
||||
.addTransport(transport)
|
||||
.setCreator(JingleContent.Creator.initiator)
|
||||
.setSenders(JingleContent.Senders.initiator);
|
||||
JingleContent content = cb.build();
|
||||
|
||||
final String sid = JingleInBandByteStreamManager.generateSessionId();
|
||||
|
||||
Jingle.Builder jb = Jingle.getBuilder();
|
||||
jb.setInitiator(connection().getUser())
|
||||
.setResponder(recipient)
|
||||
.setAction(JingleAction.session_initiate)
|
||||
.addJingleContent(content)
|
||||
.setSessionId(sid);
|
||||
Jingle jingle = jb.build();
|
||||
|
||||
JingleManager.getInstanceFor(connection()).registerJingleSessionHandler(recipient, sid, new JingleSessionHandler() {
|
||||
@Override
|
||||
public IQ handleRequest(Jingle jingle, String sessionId) {
|
||||
if (sessionId.equals(sid)) {
|
||||
if (jingle.getAction() == JingleAction.session_accept) {
|
||||
|
||||
InBandBytestreamSession session;
|
||||
try {
|
||||
session = InBandBytestreamManager.getByteStreamManager(connection())
|
||||
.establishSession(recipient, sid);
|
||||
} catch (SmackException.NoResponseException | InterruptedException | SmackException.NotConnectedException | XMPPException.XMPPErrorException e) {
|
||||
LOGGER.log(Level.SEVERE, "Fail in handle request: " + e, e);
|
||||
return null;
|
||||
}
|
||||
|
||||
try {
|
||||
session.getOutputStream().write(bytes);
|
||||
} catch (IOException e) {
|
||||
LOGGER.log(Level.SEVERE, "Fail while writing: " + e, e);
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
});
|
||||
|
||||
connection().sendStanza(jingle);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -25,7 +25,7 @@ import java.util.Date;
|
|||
/**
|
||||
* Content of type File.
|
||||
*/
|
||||
public class FileTransferPayload extends JingleContentDescriptionPayloadType {
|
||||
public class JingleFileTransferPayload extends JingleContentDescriptionPayloadType {
|
||||
public static final String ELEMENT = "file";
|
||||
public static final String ELEM_DATE = "date";
|
||||
public static final String ELEM_DESC = "desc";
|
||||
|
@ -41,7 +41,7 @@ public class FileTransferPayload extends JingleContentDescriptionPayloadType {
|
|||
private final int size;
|
||||
private final Range range;
|
||||
|
||||
public FileTransferPayload(Date date, String desc, HashElement hash, String mediaType, String name, int size, Range range) {
|
||||
public JingleFileTransferPayload(Date date, String desc, HashElement hash, String mediaType, String name, int size, Range range) {
|
||||
this.date = date;
|
||||
this.desc = desc;
|
||||
this.hash = hash;
|
|
@ -20,7 +20,7 @@ import org.jivesoftware.smackx.hash.element.HashElement;
|
|||
import org.jivesoftware.smackx.hash.provider.HashElementProvider;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
|
||||
import org.jivesoftware.smackx.jingle.provider.JingleContentDescriptionProvider;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.FileTransferPayload;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleFileTransferPayload;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleContentDescriptionFileTransfer;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.Range;
|
||||
import org.jxmpp.util.XmppDateTime;
|
||||
|
@ -64,7 +64,7 @@ public class JingleContentDescriptionFileTransferProvider
|
|||
if (tag == START_TAG) {
|
||||
switch (elem) {
|
||||
|
||||
case FileTransferPayload.ELEMENT:
|
||||
case JingleFileTransferPayload.ELEMENT:
|
||||
date = null;
|
||||
desc = null;
|
||||
mediaType = null;
|
||||
|
@ -75,23 +75,23 @@ public class JingleContentDescriptionFileTransferProvider
|
|||
hash = null;
|
||||
break;
|
||||
|
||||
case FileTransferPayload.ELEM_DATE:
|
||||
case JingleFileTransferPayload.ELEM_DATE:
|
||||
date = XmppDateTime.parseXEP0082Date(parser.nextText());
|
||||
break;
|
||||
|
||||
case FileTransferPayload.ELEM_DESC:
|
||||
case JingleFileTransferPayload.ELEM_DESC:
|
||||
desc = parser.nextText();
|
||||
break;
|
||||
|
||||
case FileTransferPayload.ELEM_MEDIA_TYPE:
|
||||
case JingleFileTransferPayload.ELEM_MEDIA_TYPE:
|
||||
mediaType = parser.nextText();
|
||||
break;
|
||||
|
||||
case FileTransferPayload.ELEM_NAME:
|
||||
case JingleFileTransferPayload.ELEM_NAME:
|
||||
name = parser.nextText();
|
||||
break;
|
||||
|
||||
case FileTransferPayload.ELEM_SIZE:
|
||||
case JingleFileTransferPayload.ELEM_SIZE:
|
||||
size = Integer.parseInt(parser.nextText());
|
||||
break;
|
||||
|
||||
|
@ -125,8 +125,8 @@ public class JingleContentDescriptionFileTransferProvider
|
|||
range = new Range(offset, length, inRangeHash);
|
||||
break;
|
||||
|
||||
case FileTransferPayload.ELEMENT:
|
||||
payloads.add(new FileTransferPayload(date, desc, hash, mediaType, name, size, range));
|
||||
case JingleFileTransferPayload.ELEMENT:
|
||||
payloads.add(new JingleFileTransferPayload(date, desc, hash, mediaType, name, size, range));
|
||||
break;
|
||||
|
||||
case JingleContentDescriptionFileTransfer.ELEMENT:
|
||||
|
|
|
@ -22,7 +22,7 @@ import org.jivesoftware.smackx.hash.HashManager;
|
|||
import org.jivesoftware.smackx.hash.element.HashElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentDescription;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.FileTransferPayload;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleFileTransferPayload;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleContentDescriptionFileTransfer;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.element.Range;
|
||||
import org.jivesoftware.smackx.jingle_filetransfer.provider.JingleContentDescriptionFileTransferProvider;
|
||||
|
@ -65,9 +65,9 @@ public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
|
|||
HashElement hashElement = new HashElement(algorithm, hashB64);
|
||||
Range range = new Range();
|
||||
Date date = XmppDateTime.parseDate(dateString);
|
||||
FileTransferPayload fileTransferPayload = new FileTransferPayload(date, descriptionString, hashElement, mediaTypeString, nameString, sizeInt, range);
|
||||
JingleFileTransferPayload jingleFileTransferPayload = new JingleFileTransferPayload(date, descriptionString, hashElement, mediaTypeString, nameString, sizeInt, range);
|
||||
ArrayList<JingleContentDescriptionPayloadType> payloads = new ArrayList<>();
|
||||
payloads.add(fileTransferPayload);
|
||||
payloads.add(jingleFileTransferPayload);
|
||||
|
||||
JingleContentDescriptionFileTransfer descriptionFileTransfer =
|
||||
new JingleContentDescriptionFileTransfer(payloads);
|
||||
|
@ -78,7 +78,7 @@ public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
|
|||
.parse(TestUtils.getParser(xml));
|
||||
assertEquals(xml, parsed.toXML().toString());
|
||||
|
||||
FileTransferPayload payload = (FileTransferPayload) parsed.getJinglePayloadTypes().get(0);
|
||||
JingleFileTransferPayload payload = (JingleFileTransferPayload) parsed.getJinglePayloadTypes().get(0);
|
||||
assertEquals(date, payload.getDate());
|
||||
assertEquals(descriptionString, payload.getDescription());
|
||||
assertEquals(mediaTypeString, payload.getMediaType());
|
||||
|
@ -104,7 +104,7 @@ public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
|
|||
"</range>" +
|
||||
"</file>" +
|
||||
"</description>";
|
||||
FileTransferPayload payload = new FileTransferPayload(null, null, null, null, null, -1, range);
|
||||
JingleFileTransferPayload payload = new JingleFileTransferPayload(null, null, null, null, null, -1, range);
|
||||
ArrayList<JingleContentDescriptionPayloadType> list = new ArrayList<>();
|
||||
list.add(payload);
|
||||
JingleContentDescriptionFileTransfer fileTransfer = new JingleContentDescriptionFileTransfer(list);
|
||||
|
|
|
@ -29,7 +29,7 @@ import static junit.framework.TestCase.assertNull;
|
|||
/**
|
||||
* Test the JingleContentFile class.
|
||||
*/
|
||||
public class FileTransferPayloadTest extends SmackTestSuite {
|
||||
public class JingleFileTransferPayloadTest extends SmackTestSuite {
|
||||
|
||||
@Test
|
||||
public void rangeTest() throws Exception {
|
|
@ -36,7 +36,7 @@ public enum JingleAction {
|
|||
session_accept,
|
||||
session_info,
|
||||
session_initiate,
|
||||
sessio_terminate,
|
||||
session_terminate,
|
||||
transport_accept,
|
||||
transport_info,
|
||||
transport_reject,
|
||||
|
|
|
@ -18,10 +18,10 @@ package org.jivesoftware.smackx.jingle_ibb;
|
|||
|
||||
import org.jivesoftware.smack.Manager;
|
||||
import org.jivesoftware.smack.XMPPConnection;
|
||||
import org.jivesoftware.smack.util.StringUtils;
|
||||
import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager;
|
||||
import org.jivesoftware.smackx.jingle_ibb.provider.JingleInBandByteStreamTransportProvider;
|
||||
|
||||
import java.util.Random;
|
||||
import java.util.WeakHashMap;
|
||||
|
||||
/**
|
||||
|
@ -52,6 +52,6 @@ public final class JingleInBandByteStreamManager extends Manager {
|
|||
* @return
|
||||
*/
|
||||
public static String generateSessionId() {
|
||||
return Integer.toString(64,new Random().nextInt());
|
||||
return StringUtils.randomString(24);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue