/* */ #include "BtRejectMessage.h" #include "PeerMessageUtil.h" #include "Util.h" #include "DlAbortEx.h" BtRejectMessageHandle BtRejectMessage::create(const unsigned char* data, uint32_t dataLength) { if(dataLength != 13) { throw new DlAbortEx("invalid payload size for %s, size = %d. It should be %d", "reject", dataLength, 13); } int32_t id = PeerMessageUtil::getId(data); if(id != ID) { throw new DlAbortEx("invalid ID=%d for %s. It should be %d.", id, "reject", ID); } BtRejectMessageHandle message = new BtRejectMessage(); message->setIndex(PeerMessageUtil::getIntParam(data, 1)); message->setBegin(PeerMessageUtil::getIntParam(data, 5)); message->setLength(PeerMessageUtil::getIntParam(data, 9)); return message; } void BtRejectMessage::doReceivedAction() { if(!peer->isFastExtensionEnabled()) { throw new DlAbortEx("%s received while fast extension is disabled.", toString().c_str()); } // TODO Current implementation does not close a connection even if // a request for this reject message has never sent. RequestSlot slot = BT_MESSAGE_DISPATCHER(btContext, peer)->getOutstandingRequest(index, begin, length); if(RequestSlot::isNull(slot)) { //throw new DlAbortEx("reject recieved, but it is not in the request slots."); } else { BT_MESSAGE_DISPATCHER(btContext, peer)->removeOutstandingRequest(slot); } } uint32_t BtRejectMessage::MESSAGE_LENGTH = 17; const char* BtRejectMessage::getMessage() { if(!msg) { /** * len --- 13, 4bytes * id --- 16, 1byte * index --- index, 4bytes * begin --- begin, 4bytes * length -- length, 4bytes * total: 17bytes */ msg = new char[MESSAGE_LENGTH]; PeerMessageUtil::createPeerMessageString(msg, MESSAGE_LENGTH, 13, ID); PeerMessageUtil::setIntParam(&msg[5], index); PeerMessageUtil::setIntParam(&msg[9], begin); PeerMessageUtil::setIntParam(&msg[13], length); } return msg; } uint32_t BtRejectMessage::getMessageLength() { return MESSAGE_LENGTH; } string BtRejectMessage::toString() const { return "reject index="+Util::uitos(index)+", begin="+Util::uitos(begin)+ ", length="+Util::uitos(length); }