Skip to content

Commit

Permalink
jer: OBJECT IDENTIFIER missing quotes
Browse files Browse the repository at this point in the history
  • Loading branch information
v0-e authored and mouse07410 committed Feb 15, 2024
1 parent e0c4a3e commit 9100393
Showing 1 changed file with 29 additions and 2 deletions.
31 changes: 29 additions & 2 deletions skeletons/OBJECT_IDENTIFIER_jer.c
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,14 @@
#include <asn_internal.h>
#include <OBJECT_IDENTIFIER.h>

#define CQUOTE 0x22

static enum jer_pbd_rval
OBJECT_IDENTIFIER__jer_body_decode(const asn_TYPE_descriptor_t *td, void *sptr,
const void *chunk_buf, size_t chunk_size) {
OBJECT_IDENTIFIER_t *st = (OBJECT_IDENTIFIER_t *)sptr;
const char *chunk_end = (const char *)chunk_buf + chunk_size;
const char *p = (const char *)chunk_buf;
const char *endptr;
asn_oid_arc_t s_arcs[10];
asn_oid_arc_t *arcs = s_arcs;
Expand All @@ -19,6 +22,23 @@ OBJECT_IDENTIFIER__jer_body_decode(const asn_TYPE_descriptor_t *td, void *sptr,

(void)td;

/* Strip quotes */
for (; p < chunk_end; ++p) {
if (*p == CQUOTE) {
++p;
break;
}
}
--chunk_end;
for (; chunk_end >= p; --chunk_end) {
if (*chunk_end == CQUOTE)
break;
}
if (chunk_end - p < 0)
return JPBD_BROKEN_ENCODING;
chunk_size = chunk_end - p;
chunk_buf = p;

num_arcs = OBJECT_IDENTIFIER_parse_arcs(
(const char *)chunk_buf, chunk_size, arcs,
sizeof(s_arcs) / sizeof(s_arcs[0]), &endptr);
Expand Down Expand Up @@ -65,6 +85,7 @@ OBJECT_IDENTIFIER_encode_jer(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_consume_bytes_f *cb, void *app_key) {
const OBJECT_IDENTIFIER_t *st = (const OBJECT_IDENTIFIER_t *)sptr;
asn_enc_rval_t er = {0,0,0};
ssize_t oid_encoded = 0;

(void)ilevel;
(void)flags;
Expand All @@ -73,8 +94,14 @@ OBJECT_IDENTIFIER_encode_jer(const asn_TYPE_descriptor_t *td, const void *sptr,
ASN__ENCODE_FAILED;
}

er.encoded = OBJECT_IDENTIFIER__dump_body(st, cb, app_key);
if(er.encoded < 0) ASN__ENCODE_FAILED;
ASN__CALLBACK("\"", 1);
oid_encoded = OBJECT_IDENTIFIER__dump_body(st, cb, app_key);
if(oid_encoded < 0) goto cb_failed;
er.encoded += oid_encoded;
ASN__CALLBACK("\"", 1);

ASN__ENCODED_OK(er);

cb_failed:
ASN__ENCODE_FAILED;
}

0 comments on commit 9100393

Please sign in to comment.