File: OptUserClass.cpp

package info (click to toggle)
dibbler 1.0.1-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 13,352 kB
  • sloc: cpp: 60,323; ansic: 12,235; sh: 11,951; yacc: 3,418; lex: 969; makefile: 940; perl: 319; xml: 116; python: 74
file content (85 lines) | stat: -rw-r--r-- 1,987 bytes parent folder | download | duplicates (3)
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
/*
 * Dibbler - a portable DHCPv6
 *
 * authors: Tomasz Mrugalski <thomson@klub.com.pl>
 *          Marek Senderski <msend@o2.pl>
 *
 * released under GNU GPL v2 licence
 *
 */

#include "DHCPConst.h"
#include "OptUserClass.h"
#include "Portable.h"
#include <string.h>

TOptUserClass::TOptUserClass(uint16_t type, const char* buf, unsigned short buf_len, TMsg* parent)
    :TOpt(type, parent) {
    Valid = parseUserData(buf, buf_len);
}

TOptUserClass::TOptUserClass(uint16_t type, TMsg* parent)
    :TOpt(type, parent) {
    Valid = true;
}

size_t TOptUserClass::getSize() {
    size_t len = 4;
    for (std::vector<UserClassData>::const_iterator data = userClassData_.begin();
	 data != userClassData_.end(); ++data) {
	len += 2; // len field
	len += data->opaqueData_.size();
    }
    return len;
}

char * TOptUserClass::storeSelf(char* buf) {
    buf = writeUint16(buf, OptType);
    buf = writeUint16(buf, getSize() - 4);
    return storeUserData(buf);
}

char * TOptUserClass::storeUserData(char* buf) {
    for (std::vector<UserClassData>::const_iterator data = userClassData_.begin();
	 data != userClassData_.end(); ++data) {
	buf = writeUint16(buf, data->opaqueData_.size());
	memcpy(buf, &data->opaqueData_[0], data->opaqueData_.size());
	buf += data->opaqueData_.size();
    }

    return buf;
}

/// @brief parses UserData field
///
/// @return true if parsing was successful, false otherwise
bool TOptUserClass::parseUserData(const char* buf, unsigned short buf_len) {
    int pos = 0;
    while (buf_len > 2) {
	uint16_t len = readUint16(buf + pos);
	buf_len -= sizeof(uint16_t);
	pos += sizeof(uint16_t);
	
	if (len > buf_len) {
	    // truncated user-data
	    return false;
	}
	UserClassData data;
	data.opaqueData_.resize(len);
	memcpy(&data.opaqueData_[0], buf + pos, len);
	userClassData_.push_back(data);

	pos += len;
	buf_len -= len;
    }

    if (buf_len) {
	return false;
    }

    return true;
}

bool TOptUserClass::isValid() const {
    return true;
}