dns-suite.js/dns.rdata.parse.js

46 lines
1.7 KiB
JavaScript
Raw Normal View History

2017-01-21 14:33:51 -07:00
(function (exports) {
'use strict';
exports.DNS_RDATA_PARSE = function (ab, packet, record) {
// ab is needed if the rdata makes use of compression pointers
// packet is given for convenience
var parser;
2017-01-21 14:33:51 -07:00
if (!record.className) {
2017-02-11 09:56:17 -07:00
throw new Error("Support for DNS Class 0x" + record.class.toString(16) + " (" + record.class + ")"
2017-01-21 14:33:51 -07:00
+ " is not implemented yet. Open an issue if you actually need support"
+ " (i.e. you're not working with a malformed packet)"
);
}
if (!record.typeName) {
2017-02-11 09:56:17 -07:00
throw new Error("Support for DNS Type 0x" + record.type.toString(16) + " (" + record.type + ")"
2017-01-21 14:33:51 -07:00
+ " is not implemented yet. Open an issue if you actually need support"
+ " (i.e. you're not working with a malformed packet)"
);
}
try {
parser = exports['DNS_TYPE_' + record.typeName]
2017-01-21 14:39:26 -07:00
|| require('./dns.type.' + record.typeName.toLowerCase())['DNS_TYPE_' + record.typeName];
2017-01-21 14:33:51 -07:00
}
catch (e) { /*console.error(e)*/ }
if (!parser) {
throw new Error("Parser for DNS Type " + record.typeName + " could not be loaded."
+ " Did you include <script src=\"dns.type." + record.typeName.toLowerCase() + ".js\"></script> ?"
+ " (or perhaps we plan to implement it and haven't yet - in which case please open an issue)"
);
}
// NOTE: record will be modified
// Things that get added include:
2017-02-02 19:44:18 -07:00
// address, data, priority exchange, weight,
// NOTE: this slicing is a shim so that we don't have to pass rdend to unpackLabel
// (because `undefined` and 0x00 are functionally equivalent)
return parser(ab.slice(0, record.rdstart + record.rdlength), packet, record);
2017-01-21 14:33:51 -07:00
};
}('undefined' !== typeof window ? window : exports));