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
|
/*
* Dibbler - a portable DHCPv6
*
* authors: Tomasz Mrugalski <thomson@klub.com.pl>
* Marek Senderski <msend@o2.pl>
* changes: Krzysztof Wnuk <keczi@poczta.onet.pl>
*
*
*/
#ifdef WIN32
#include <winsock2.h>
#endif
#ifdef LINUX
#include <netinet/in.h>
#endif
#include "DHCPConst.h"
#include "Opt.h"
#include "OptIAPrefix.h"
#include "SrvOptIAPrefix.h"
#include "SrvOptStatusCode.h"
#include "Msg.h"
#include "Logger.h"
TSrvOptIAPrefix::TSrvOptIAPrefix( char * buf, int bufsize, TMsg* parent)
:TOptIAPrefix(buf,bufsize, parent)
{
int pos=0;
while(pos<bufsize)
{
int code=buf[pos]*256+buf[pos+1]; // FIXME: use htons!
pos+=2;
int length=buf[pos]*256+buf[pos+1]; // FIXME: use htons!
pos+=2;
if ((code>0)&&(code<=24))
{
if(allowOptInOpt(parent->getType(),OPTION_IAPREFIX,code))
{
SmartPtr<TOpt> opt;
opt = SmartPtr<TOpt>();
switch (code)
{
case OPTION_STATUS_CODE:
opt =(Ptr*)SmartPtr<TSrvOptStatusCode> (
new TSrvOptStatusCode(buf+pos,length,this->Parent));
break;
default:
Log(Warning) << "Option " << code<< " not supported "
<<" in message (type="<< parent->getType() <<")." << LogEnd;
break;
}
if((opt)&&(opt->isValid()))
SubOptions.append(opt);
} else {
Log(Warning) << "Illegal option received, opttype=" << code
<< " in field options of IA_PD option" << LogEnd;
}
} else {
Log(Warning) <<"Unknown option in option IA_PD( optType="
<< code << "). Option ignored." << LogEnd;
};
pos+=length;
}
}
TSrvOptIAPrefix::TSrvOptIAPrefix(SmartPtr<TIPv6Addr> prefix, char length, unsigned long pref,
unsigned long valid, TMsg* parent)
:TOptIAPrefix(prefix,length,pref,valid, parent) {
}
bool TSrvOptIAPrefix::doDuties() {
return true;
}
|