All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.codeminders.socketio.protocol.BinaryEventPacket Maven / Gradle / Ivy

There is a newer version: 1.0.10
Show newest version
/**
 * The MIT License
 * Copyright (c) 2015 Alexander Sova ([email protected])
 * 

* Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: *

* The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. *

* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package com.codeminders.socketio.protocol; import java.io.InputStream; import java.util.ArrayList; import java.util.Collection; import java.util.LinkedList; import java.util.List; /** * Binary event packet class * * @author Alexander Sova ([email protected]) */ public class BinaryEventPacket extends EventPacket implements BinaryPacket { private List attachments; private int number_attachments_expected; /** * This constructor suppose to be called by parser when new packet arrived * * @param id packet id. Used for ACK * @param name event name * @param args event arguments as array of POJOs to be converted to JSON. * @param number_attachments_expected number of binary attachment expected to be attached to this packed */ BinaryEventPacket(int id, String ns, String name, Object[] args, int number_attachments_expected) { super(Type.BINARY_EVENT, id, ns, name, args); this.number_attachments_expected = number_attachments_expected; this.attachments = new ArrayList<>(number_attachments_expected); } /** * This constructor suppose to be called by user by emit() call * * @param id packet id * @param ns packet namespace * @param name event name * @param args event arguments as array of POJOs to be converted to JSON. * {@link java.io.InputStream} to be used for binary objects */ public BinaryEventPacket(int id, String ns, String name, Object[] args) { super(Type.BINARY_EVENT, id, ns, name, null); attachments = new LinkedList<>(); // We know that extractBinaryObjects does not change the structure of the object, // so we can safely case it to Object[] setArgs((Object[]) SocketIOProtocol.extractBinaryObjects(args, attachments)); } public Collection getAttachments() { return attachments; } @Override protected String encodeAttachments() { return SocketIOProtocol.encodeAttachments(attachments.size()); } /** * @return true when all expected attachment arrived, false otherwise */ public boolean isComplete() { return number_attachments_expected == 0; } /** * This method to be called when new attachement arrives to the socket * * @param attachment new attachment */ public void addAttachment(InputStream attachment) { attachments.add(attachment); number_attachments_expected -= 1; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy