1
0
Fork 0
mirror of https://github.com/vanitasvitae/Smack.git synced 2024-11-23 20:42:06 +01:00

Add first dirty send test

This commit is contained in:
vanitasvitae 2017-05-31 19:12:38 +02:00
parent 2cbbfd1048
commit 0b28e8b467
Signed by: vanitasvitae
GPG key ID: 62BEE9264BF17311
8 changed files with 142 additions and 20 deletions

View file

@ -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;
}
}

View file

@ -17,11 +17,35 @@
package org.jivesoftware.smackx.jingle_filetransfer; package org.jivesoftware.smackx.jingle_filetransfer;
import org.jivesoftware.smack.Manager; import org.jivesoftware.smack.Manager;
import org.jivesoftware.smack.SmackException;
import org.jivesoftware.smack.XMPPConnection; 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.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_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.WeakHashMap;
import java.util.logging.Level;
import java.util.logging.Logger;
/** /**
* Manager for Jingle File Transfers. * Manager for Jingle File Transfers.
@ -30,6 +54,8 @@ import java.util.WeakHashMap;
*/ */
public final class JingleFileTransferManager extends Manager { 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"; public static final String NAMESPACE_V5 = "urn:xmpp:jingle:apps:file-transfer:5";
private static final WeakHashMap<XMPPConnection, JingleFileTransferManager> INSTANCES = new WeakHashMap<>(); private static final WeakHashMap<XMPPConnection, JingleFileTransferManager> INSTANCES = new WeakHashMap<>();
@ -59,4 +85,69 @@ public final class JingleFileTransferManager extends Manager {
} }
return 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);
}
} }

View file

@ -25,7 +25,7 @@ import java.util.Date;
/** /**
* Content of type File. * Content of type File.
*/ */
public class FileTransferPayload extends JingleContentDescriptionPayloadType { public class JingleFileTransferPayload extends JingleContentDescriptionPayloadType {
public static final String ELEMENT = "file"; public static final String ELEMENT = "file";
public static final String ELEM_DATE = "date"; public static final String ELEM_DATE = "date";
public static final String ELEM_DESC = "desc"; public static final String ELEM_DESC = "desc";
@ -41,7 +41,7 @@ public class FileTransferPayload extends JingleContentDescriptionPayloadType {
private final int size; private final int size;
private final Range range; 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.date = date;
this.desc = desc; this.desc = desc;
this.hash = hash; this.hash = hash;

View file

@ -20,7 +20,7 @@ import org.jivesoftware.smackx.hash.element.HashElement;
import org.jivesoftware.smackx.hash.provider.HashElementProvider; import org.jivesoftware.smackx.hash.provider.HashElementProvider;
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType; import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
import org.jivesoftware.smackx.jingle.provider.JingleContentDescriptionProvider; 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.JingleContentDescriptionFileTransfer;
import org.jivesoftware.smackx.jingle_filetransfer.element.Range; import org.jivesoftware.smackx.jingle_filetransfer.element.Range;
import org.jxmpp.util.XmppDateTime; import org.jxmpp.util.XmppDateTime;
@ -64,7 +64,7 @@ public class JingleContentDescriptionFileTransferProvider
if (tag == START_TAG) { if (tag == START_TAG) {
switch (elem) { switch (elem) {
case FileTransferPayload.ELEMENT: case JingleFileTransferPayload.ELEMENT:
date = null; date = null;
desc = null; desc = null;
mediaType = null; mediaType = null;
@ -75,23 +75,23 @@ public class JingleContentDescriptionFileTransferProvider
hash = null; hash = null;
break; break;
case FileTransferPayload.ELEM_DATE: case JingleFileTransferPayload.ELEM_DATE:
date = XmppDateTime.parseXEP0082Date(parser.nextText()); date = XmppDateTime.parseXEP0082Date(parser.nextText());
break; break;
case FileTransferPayload.ELEM_DESC: case JingleFileTransferPayload.ELEM_DESC:
desc = parser.nextText(); desc = parser.nextText();
break; break;
case FileTransferPayload.ELEM_MEDIA_TYPE: case JingleFileTransferPayload.ELEM_MEDIA_TYPE:
mediaType = parser.nextText(); mediaType = parser.nextText();
break; break;
case FileTransferPayload.ELEM_NAME: case JingleFileTransferPayload.ELEM_NAME:
name = parser.nextText(); name = parser.nextText();
break; break;
case FileTransferPayload.ELEM_SIZE: case JingleFileTransferPayload.ELEM_SIZE:
size = Integer.parseInt(parser.nextText()); size = Integer.parseInt(parser.nextText());
break; break;
@ -125,8 +125,8 @@ public class JingleContentDescriptionFileTransferProvider
range = new Range(offset, length, inRangeHash); range = new Range(offset, length, inRangeHash);
break; break;
case FileTransferPayload.ELEMENT: case JingleFileTransferPayload.ELEMENT:
payloads.add(new FileTransferPayload(date, desc, hash, mediaType, name, size, range)); payloads.add(new JingleFileTransferPayload(date, desc, hash, mediaType, name, size, range));
break; break;
case JingleContentDescriptionFileTransfer.ELEMENT: case JingleContentDescriptionFileTransfer.ELEMENT:

View file

@ -22,7 +22,7 @@ import org.jivesoftware.smackx.hash.HashManager;
import org.jivesoftware.smackx.hash.element.HashElement; import org.jivesoftware.smackx.hash.element.HashElement;
import org.jivesoftware.smackx.jingle.element.JingleContentDescription; import org.jivesoftware.smackx.jingle.element.JingleContentDescription;
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType; 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.JingleContentDescriptionFileTransfer;
import org.jivesoftware.smackx.jingle_filetransfer.element.Range; import org.jivesoftware.smackx.jingle_filetransfer.element.Range;
import org.jivesoftware.smackx.jingle_filetransfer.provider.JingleContentDescriptionFileTransferProvider; import org.jivesoftware.smackx.jingle_filetransfer.provider.JingleContentDescriptionFileTransferProvider;
@ -65,9 +65,9 @@ public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
HashElement hashElement = new HashElement(algorithm, hashB64); HashElement hashElement = new HashElement(algorithm, hashB64);
Range range = new Range(); Range range = new Range();
Date date = XmppDateTime.parseDate(dateString); 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<>(); ArrayList<JingleContentDescriptionPayloadType> payloads = new ArrayList<>();
payloads.add(fileTransferPayload); payloads.add(jingleFileTransferPayload);
JingleContentDescriptionFileTransfer descriptionFileTransfer = JingleContentDescriptionFileTransfer descriptionFileTransfer =
new JingleContentDescriptionFileTransfer(payloads); new JingleContentDescriptionFileTransfer(payloads);
@ -78,7 +78,7 @@ public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
.parse(TestUtils.getParser(xml)); .parse(TestUtils.getParser(xml));
assertEquals(xml, parsed.toXML().toString()); assertEquals(xml, parsed.toXML().toString());
FileTransferPayload payload = (FileTransferPayload) parsed.getJinglePayloadTypes().get(0); JingleFileTransferPayload payload = (JingleFileTransferPayload) parsed.getJinglePayloadTypes().get(0);
assertEquals(date, payload.getDate()); assertEquals(date, payload.getDate());
assertEquals(descriptionString, payload.getDescription()); assertEquals(descriptionString, payload.getDescription());
assertEquals(mediaTypeString, payload.getMediaType()); assertEquals(mediaTypeString, payload.getMediaType());
@ -104,7 +104,7 @@ public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
"</range>" + "</range>" +
"</file>" + "</file>" +
"</description>"; "</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<>(); ArrayList<JingleContentDescriptionPayloadType> list = new ArrayList<>();
list.add(payload); list.add(payload);
JingleContentDescriptionFileTransfer fileTransfer = new JingleContentDescriptionFileTransfer(list); JingleContentDescriptionFileTransfer fileTransfer = new JingleContentDescriptionFileTransfer(list);

View file

@ -29,7 +29,7 @@ import static junit.framework.TestCase.assertNull;
/** /**
* Test the JingleContentFile class. * Test the JingleContentFile class.
*/ */
public class FileTransferPayloadTest extends SmackTestSuite { public class JingleFileTransferPayloadTest extends SmackTestSuite {
@Test @Test
public void rangeTest() throws Exception { public void rangeTest() throws Exception {

View file

@ -36,7 +36,7 @@ public enum JingleAction {
session_accept, session_accept,
session_info, session_info,
session_initiate, session_initiate,
sessio_terminate, session_terminate,
transport_accept, transport_accept,
transport_info, transport_info,
transport_reject, transport_reject,

View file

@ -18,10 +18,10 @@ package org.jivesoftware.smackx.jingle_ibb;
import org.jivesoftware.smack.Manager; import org.jivesoftware.smack.Manager;
import org.jivesoftware.smack.XMPPConnection; import org.jivesoftware.smack.XMPPConnection;
import org.jivesoftware.smack.util.StringUtils;
import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager; import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager;
import org.jivesoftware.smackx.jingle_ibb.provider.JingleInBandByteStreamTransportProvider; import org.jivesoftware.smackx.jingle_ibb.provider.JingleInBandByteStreamTransportProvider;
import java.util.Random;
import java.util.WeakHashMap; import java.util.WeakHashMap;
/** /**
@ -52,6 +52,6 @@ public final class JingleInBandByteStreamManager extends Manager {
* @return * @return
*/ */
public static String generateSessionId() { public static String generateSessionId() {
return Integer.toString(64,new Random().nextInt()); return StringUtils.randomString(24);
} }
} }