Support RFC5904 and short type

This commit is contained in:
moznion
2020-12-06 16:25:44 +09:00
parent 2b6b80a83e
commit a251f4b2af
6 changed files with 225 additions and 1 deletions
+20
View File
@@ -48,6 +48,13 @@ impl AVP {
}
}
pub fn from_u16(typ: AVPType, value: u16) -> Self {
AVP {
typ,
value: u16::to_be_bytes(value).to_vec(),
}
}
pub fn from_tagged_u32(typ: AVPType, tag: Option<&Tag>, value: u32) -> Self {
let tag = match tag {
None => &Tag {
@@ -287,6 +294,19 @@ impl AVP {
}
}
pub fn encode_u16(&self) -> Result<u16, AVPError> {
const U16_SIZE: usize = std::mem::size_of::<u16>();
if self.value.len() != U16_SIZE {
return Err(AVPError::InvalidAttributeLengthError(self.value.len()));
}
let (int_bytes, _) = self.value.split_at(U16_SIZE);
match int_bytes.try_into() {
Ok(boxed_array) => Ok(u16::from_be_bytes(boxed_array)),
Err(e) => Err(AVPError::UnexpectedDecodingError(e.to_string())),
}
}
pub fn encode_tagged_u32(&self) -> Result<(u32, Tag), AVPError> {
if self.value.is_empty() {
return Err(AVPError::InvalidAttributeLengthError(self.value.len()));
+1
View File
@@ -20,6 +20,7 @@ pub mod rfc4849;
pub mod rfc5090;
pub mod rfc5176;
pub mod rfc5607;
pub mod rfc5904;
pub mod rfc6519;
pub mod rfc6677;
pub mod rfc6911;
+146
View File
@@ -0,0 +1,146 @@
// Code generated by machine generator; DO NOT EDIT.
use crate::avp::{AVPError, AVPType, AVP};
use crate::packet::Packet;
pub const PKM_SS_CERT_TYPE: AVPType = 137;
pub fn delete_pkm_ss_cert(packet: &mut Packet) {
packet.delete(PKM_SS_CERT_TYPE);
}
pub fn add_pkm_ss_cert(packet: &mut Packet, value: &[u8]) {
packet.extend(
value
.chunks(253)
.map(|chunk| AVP::from_bytes(PKM_SS_CERT_TYPE, chunk))
.collect(),
);
}
pub fn lookup_pkm_ss_cert(packet: &Packet) -> Option<Vec<u8>> {
let avps = packet.lookup_all(PKM_SS_CERT_TYPE);
match avps.is_empty() {
true => None,
false => Some(avps.into_iter().fold(Vec::new(), |mut acc, v| {
acc.extend(v.encode_bytes());
acc
})),
}
}
pub const PKM_CA_CERT_TYPE: AVPType = 138;
pub fn delete_pkm_ca_cert(packet: &mut Packet) {
packet.delete(PKM_CA_CERT_TYPE);
}
pub fn add_pkm_ca_cert(packet: &mut Packet, value: &[u8]) {
packet.extend(
value
.chunks(253)
.map(|chunk| AVP::from_bytes(PKM_CA_CERT_TYPE, chunk))
.collect(),
);
}
pub fn lookup_pkm_ca_cert(packet: &Packet) -> Option<Vec<u8>> {
let avps = packet.lookup_all(PKM_CA_CERT_TYPE);
match avps.is_empty() {
true => None,
false => Some(avps.into_iter().fold(Vec::new(), |mut acc, v| {
acc.extend(v.encode_bytes());
acc
})),
}
}
pub const PKM_CONFIG_SETTINGS_TYPE: AVPType = 139;
pub fn delete_pkm_config_settings(packet: &mut Packet) {
packet.delete(PKM_CONFIG_SETTINGS_TYPE);
}
pub fn add_pkm_config_settings(packet: &mut Packet, value: &[u8]) {
packet.add(AVP::from_bytes(PKM_CONFIG_SETTINGS_TYPE, value));
}
pub fn lookup_pkm_config_settings(packet: &Packet) -> Option<Vec<u8>> {
packet
.lookup(PKM_CONFIG_SETTINGS_TYPE)
.map(|v| v.encode_bytes())
}
pub fn lookup_all_pkm_config_settings(packet: &Packet) -> Vec<Vec<u8>> {
let mut vec = Vec::new();
for avp in packet.lookup_all(PKM_CONFIG_SETTINGS_TYPE) {
vec.push(avp.encode_bytes())
}
vec
}
pub const PKM_CRYPTOSUITE_LIST_TYPE: AVPType = 140;
pub fn delete_pkm_cryptosuite_list(packet: &mut Packet) {
packet.delete(PKM_CRYPTOSUITE_LIST_TYPE);
}
pub fn add_pkm_cryptosuite_list(packet: &mut Packet, value: &[u8]) {
packet.add(AVP::from_bytes(PKM_CRYPTOSUITE_LIST_TYPE, value));
}
pub fn lookup_pkm_cryptosuite_list(packet: &Packet) -> Option<Vec<u8>> {
packet
.lookup(PKM_CRYPTOSUITE_LIST_TYPE)
.map(|v| v.encode_bytes())
}
pub fn lookup_all_pkm_cryptosuite_list(packet: &Packet) -> Vec<Vec<u8>> {
let mut vec = Vec::new();
for avp in packet.lookup_all(PKM_CRYPTOSUITE_LIST_TYPE) {
vec.push(avp.encode_bytes())
}
vec
}
pub const PKM_SAID_TYPE: AVPType = 141;
pub fn delete_pkm_said(packet: &mut Packet) {
packet.delete(PKM_SAID_TYPE);
}
pub fn add_pkm_said(packet: &mut Packet, value: u16) {
packet.add(AVP::from_u16(PKM_SAID_TYPE, value));
}
pub fn lookup_pkm_said(packet: &Packet) -> Option<Result<u16, AVPError>> {
packet.lookup(PKM_SAID_TYPE).map(|v| v.encode_u16())
}
pub fn lookup_all_pkm_said(packet: &Packet) -> Result<Vec<u16>, AVPError> {
let mut vec = Vec::new();
for avp in packet.lookup_all(PKM_SAID_TYPE) {
vec.push(avp.encode_u16()?)
}
Ok(vec)
}
pub const PKM_SA_DESCRIPTOR_TYPE: AVPType = 142;
pub fn delete_pkm_sa_descriptor(packet: &mut Packet) {
packet.delete(PKM_SA_DESCRIPTOR_TYPE);
}
pub fn add_pkm_sa_descriptor(packet: &mut Packet, value: &[u8]) {
packet.add(AVP::from_bytes(PKM_SA_DESCRIPTOR_TYPE, value));
}
pub fn lookup_pkm_sa_descriptor(packet: &Packet) -> Option<Vec<u8>> {
packet
.lookup(PKM_SA_DESCRIPTOR_TYPE)
.map(|v| v.encode_bytes())
}
pub fn lookup_all_pkm_sa_descriptor(packet: &Packet) -> Vec<Vec<u8>> {
let mut vec = Vec::new();
for avp in packet.lookup_all(PKM_SA_DESCRIPTOR_TYPE) {
vec.push(avp.encode_bytes())
}
vec
}
pub const PKM_AUTH_KEY_TYPE: AVPType = 143;
pub fn delete_pkm_auth_key(packet: &mut Packet) {
packet.delete(PKM_AUTH_KEY_TYPE);
}
pub fn add_pkm_auth_key(packet: &mut Packet, value: &[u8]) {
packet.add(AVP::from_bytes(PKM_AUTH_KEY_TYPE, value));
}
pub fn lookup_pkm_auth_key(packet: &Packet) -> Option<Vec<u8>> {
packet.lookup(PKM_AUTH_KEY_TYPE).map(|v| v.encode_bytes())
}
pub fn lookup_all_pkm_auth_key(packet: &Packet) -> Vec<Vec<u8>> {
let mut vec = Vec::new();
for avp in packet.lookup_all(PKM_AUTH_KEY_TYPE) {
vec.push(avp.encode_bytes())
}
vec
}