Skip to content

Commit

Permalink
add OER codec for string types
Browse files Browse the repository at this point in the history
  • Loading branch information
vlm committed Aug 2, 2017
1 parent ca84c46 commit 1d76f3c
Show file tree
Hide file tree
Showing 16 changed files with 214 additions and 26 deletions.
4 changes: 2 additions & 2 deletions skeletons/BMPString.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ asn_TYPE_descriptor_t asn_DEF_BMPString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/GeneralString.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ asn_TYPE_descriptor_t asn_DEF_GeneralString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/GraphicString.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ asn_TYPE_descriptor_t asn_DEF_GraphicString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/IA5String.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ asn_TYPE_descriptor_t asn_DEF_IA5String = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/ISO646String.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ asn_TYPE_descriptor_t asn_DEF_ISO646String = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/NumericString.c
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,8 @@ asn_TYPE_descriptor_t asn_DEF_NumericString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
2 changes: 2 additions & 0 deletions skeletons/OCTET_STRING.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ xer_type_decoder_f OCTET_STRING_decode_xer_binary; /* 01010111010 */
xer_type_decoder_f OCTET_STRING_decode_xer_utf8; /* ASCII/UTF-8 */
xer_type_encoder_f OCTET_STRING_encode_xer;
xer_type_encoder_f OCTET_STRING_encode_xer_utf8;
oer_type_decoder_f OCTET_STRING_decode_oer;
oer_type_encoder_f OCTET_STRING_encode_oer;
per_type_decoder_f OCTET_STRING_decode_uper;
per_type_encoder_f OCTET_STRING_encode_uper;

Expand Down
185 changes: 185 additions & 0 deletions skeletons/OCTET_STRING_oer.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,185 @@
/*
* Copyright (c) 2017 Lev Walkin <[email protected]>.
* All rights reserved.
* Redistribution and modifications are permitted subject to BSD license.
*/
#ifndef ASN_DISABLE_OER_SUPPORT

#include <asn_internal.h>
#include <OCTET_STRING.h>
#include <errno.h>

static asn_oer_constraints_t asn_DEF_OCTET_STRING_oer_constraints = {
{ 0, 0, 0 },
{ AOC_HAS_LOWER_BOUND, 0, 0 }
};

asn_dec_rval_t
OCTET_STRING_decode_oer(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_descriptor_t *td,
asn_oer_constraints_t *constraints, void **sptr,
const void *ptr, size_t size) {
asn_OCTET_STRING_specifics_t *specs =
td->specifics
? (asn_OCTET_STRING_specifics_t *)td->specifics
: (asn_OCTET_STRING_specifics_t *)&asn_DEF_OCTET_STRING.specifics;
OCTET_STRING_t *st = (OCTET_STRING_t *)*sptr;
asn_oer_constraints_t *cts =
constraints ? constraints : td->oer_constraints;
asn_oer_constraint_t *csiz =
cts ? &cts->size : &asn_DEF_OCTET_STRING_oer_constraints.size;
asn_dec_rval_t rval = {RC_OK, 0};
size_t expected_length = 0;

size_t unit_bytes;
switch(specs->subvariant) {
default:
case ASN_OSUBV_BIT:
ASN_DEBUG("Invalid use of OCTET STRING to decode BIT STRING");
ASN__DECODE_FAILED;
case ASN_OSUBV_ANY:
/* Fall through */
case ASN_OSUBV_STR:
unit_bytes = 1;
break;
case ASN_OSUBV_U16:
unit_bytes = 2;
break;
case ASN_OSUBV_U32:
unit_bytes = 4;
break;
}

(void)opt_codec_ctx;

if(!st) {
st = (OCTET_STRING_t *)(*sptr = CALLOC(1, specs->struct_size));
if(!st) ASN__DECODE_FAILED;
}

if((csiz->flags
& (AOC_HAS_LOWER_BOUND | AOC_HAS_UPPER_BOUND))
== (AOC_HAS_LOWER_BOUND | AOC_HAS_UPPER_BOUND)
&& csiz->lower_bound == csiz->upper_bound) {
expected_length = unit_bytes * csiz->lower_bound;
} else {
/*
* X.696 (08/2015) #27.2
* Encode length determinant as _number of octets_, but only
* if upper bound is not equal to lower bound.
*/
ssize_t len_len = oer_fetch_length(ptr, size, &expected_length);
if(len_len > 0) {
rval.consumed = len_len;
ptr = (const char *)ptr + len_len;
size -= len_len;
} else if(len_len == 0) {
ASN__DECODE_STARVED;
} else if(len_len < 0) {
ASN__DECODE_FAILED;
}

if(expected_length % unit_bytes != 0) {
ASN_DEBUG(
"Data size %zu bytes is not consistent with multiplier %zu",
expected_length, unit_bytes);
ASN__DECODE_FAILED;
}
}

if(size < expected_length) {
ASN__DECODE_STARVED;
} else {
uint8_t *buf = MALLOC(expected_length + 1);
if(buf == NULL) {
ASN__DECODE_FAILED;
} else {
memcpy(buf, ptr, expected_length);
buf[expected_length] = '\0';
}
FREEMEM(st->buf);
st->buf = buf;
st->size = expected_length;

rval.consumed += expected_length;
return rval;
}
}

/*
* Encode as Canonical OER.
*/
asn_enc_rval_t
OCTET_STRING_encode_oer(asn_TYPE_descriptor_t *td,
asn_oer_constraints_t *constraints, void *sptr,
asn_app_consume_bytes_f *cb, void *app_key) {
asn_OCTET_STRING_specifics_t *specs =
td->specifics
? (asn_OCTET_STRING_specifics_t *)td->specifics
: (asn_OCTET_STRING_specifics_t *)&asn_DEF_OCTET_STRING.specifics;
OCTET_STRING_t *st = (OCTET_STRING_t *)sptr;
asn_oer_constraints_t *cts =
constraints ? constraints : td->oer_constraints;
asn_oer_constraint_t *csiz =
cts ? &cts->size : &asn_DEF_OCTET_STRING_oer_constraints.size;
asn_enc_rval_t er = {0, 0, 0};

if(!st) ASN__ENCODE_FAILED;

ASN_DEBUG("Encoding %s %d as OCTET STRING", td ? td->name : "", st->size);

if((csiz->flags
& (AOC_HAS_LOWER_BOUND | AOC_HAS_UPPER_BOUND))
== (AOC_HAS_LOWER_BOUND | AOC_HAS_UPPER_BOUND)
&& csiz->lower_bound == csiz->upper_bound) {
/*
* Check that available data matches the constraint
*/
size_t unit_bytes;
switch(specs->subvariant) {
default:
case ASN_OSUBV_BIT:
ASN_DEBUG("Invalid use of OCTET STRING to encode BIT STRING");
ASN__ENCODE_FAILED;
case ASN_OSUBV_ANY:
/* Fall through */
case ASN_OSUBV_STR:
unit_bytes = 1;
break;
case ASN_OSUBV_U16:
unit_bytes = 2;
break;
case ASN_OSUBV_U32:
unit_bytes = 4;
break;
}

if(st->size != unit_bytes * csiz->lower_bound) {
ASN_DEBUG(
"Trying to encode %s (%zu bytes) which doesn't fit SIZE "
"constraint (%d)",
td->name, st->size, csiz->lower_bound);
ASN__ENCODE_FAILED;
}
} else {
/*
* X.696 (08/2015) #27.2
* Encode length determinant as _number of octets_, but only
* if upper bound is not equal to lower bound.
*/
ssize_t ret = oer_serialize_length(st->size, cb, app_key);
if(ret < 0) {
ASN__ENCODE_FAILED;
}
er.encoded += ret;
}

er.encoded += st->size;
if(cb(st->buf, st->size, app_key) < 0) {
ASN__ENCODE_FAILED;
} else {
ASN__ENCODED_OK(er);
}
}

#endif /* ASN_DISABLE_OER_SUPPORT */
4 changes: 2 additions & 2 deletions skeletons/PrintableString.c
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,8 @@ asn_TYPE_descriptor_t asn_DEF_PrintableString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/T61String.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ asn_TYPE_descriptor_t asn_DEF_T61String = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/TeletexString.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ asn_TYPE_descriptor_t asn_DEF_TeletexString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/UTF8String.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,8 @@ asn_TYPE_descriptor_t asn_DEF_UTF8String = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/UniversalString.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ asn_TYPE_descriptor_t asn_DEF_UniversalString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/VideotexString.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@ asn_TYPE_descriptor_t asn_DEF_VideotexString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
4 changes: 2 additions & 2 deletions skeletons/VisibleString.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ asn_TYPE_descriptor_t asn_DEF_VisibleString = {
0,
0,
#else
0,
0,
OCTET_STRING_decode_oer,
OCTET_STRING_encode_oer,
#endif /* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
0,
Expand Down
1 change: 1 addition & 0 deletions skeletons/file-dependencies
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ converter-sample.c # A default name for sample transcoder

CODEC-OER: # THIS IS A SPECIAL SECTION
INTEGER_oer.c
OCTET_STRING_oer.c
NativeInteger_oer.c
constr_SEQUENCE_oer.c

Expand Down

0 comments on commit 1d76f3c

Please sign in to comment.