Parent: [b323f7] (diff)

Download this file

CDAPSplitter.cc    104 lines (85 with data), 3.9 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
// The MIT License (MIT)
//
// Copyright (c) 2014-2016 Brno University of Technology, PRISTINE project
//
// 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.
#include "CDAPSplitter.h"
Define_Module(CDAPSplitter);
void CDAPSplitter::initialize()
{
MsgLog = dynamic_cast<CDAPMsgLog*>(this->getParentModule()->getSubmodule(MOD_CDAPMSGLOG));
if (!MsgLog)
error("Pointer to CDAPMsgLog is not initialized!");
}
CDAPSplitter::CDAPSplitter() {
MsgLog = NULL;
}
CDAPSplitter::~CDAPSplitter() {
MsgLog = NULL;
}
void CDAPSplitter::handleMessage(cMessage *msg)
{
//Process message
if (!dynamic_cast<CDAPMessage*>(msg)) {
EV << this->getFullPath() << " received unknown message" << endl;
delete msg;
return;
}
CDAPMessage* cdapmsg = check_and_cast<CDAPMessage*>(msg);
//Check for unsolicited response
if (cdapmsg->getOpCode() % 2 == 0 //is *_R message
&& !MsgLog->findRequestByInvId(cdapmsg)) //does not have request with appropriate invokeId
{
EV << "Cannot send/received unsolicited CDAP response thus discarding message" << endl;
delete msg;
return;
}
//Output gate pointer
cGate* out;
//Received from south gates
if ( strstr(msg->getArrivalGate()->getName(), GATE_SOUTHIO) != NULL ) {
MsgLog->insert(cdapmsg, false);
//Pass it to the CACE module
if (dynamic_cast<CDAP_M_Connect*>(msg) || dynamic_cast<CDAP_M_Connect_R*>(msg) ||
dynamic_cast<CDAP_M_Release*>(msg) || dynamic_cast<CDAP_M_Release_R*>(msg) )
{
out = gateHalf(GATE_CACEIO, cGate::OUTPUT);
}
//Pass it to the Auth module
//Pass it to the CDAP module
else if (dynamic_cast<CDAP_M_Create*>(msg) || dynamic_cast<CDAP_M_Create_R*>(msg) ||
dynamic_cast<CDAP_M_Delete*>(msg) || dynamic_cast<CDAP_M_Delete_R*>(msg) ||
dynamic_cast<CDAP_M_Start*>(msg) || dynamic_cast<CDAP_M_Start_R*>(msg) ||
dynamic_cast<CDAP_M_Stop*>(msg) || dynamic_cast<CDAP_M_Stop_R*>(msg) ||
dynamic_cast<CDAP_M_Write*>(msg) || dynamic_cast<CDAP_M_Write_R*>(msg) ||
dynamic_cast<CDAP_M_Read*>(msg) || dynamic_cast<CDAP_M_Read_R*>(msg) ||
dynamic_cast<CDAP_M_CancelRead*>(msg) || dynamic_cast<CDAP_M_CancelRead_R*>(msg) )
{
//EV <<"XXXXXXXX "<< msg->getArrivalGate()->getFullName() << "-" << msg->getArrivalGate()->getIndex() << endl;
out = gateHalf(GATE_CDAPIO, cGate::OUTPUT);
}
}
//Received from north gates
else if (strstr(msg->getArrivalGate()->getName(), GATE_SOUTHIO) == NULL) {
MsgLog->insert(check_and_cast<CDAPMessage*>(msg), true);
out = gateHalf(GATE_SOUTHIO, cGate::OUTPUT);
}
//Forward message
send(msg, out);
}