UNPKG

@wildboar/pkcs

Version:
52 lines (51 loc) 2.25 kB
/* eslint-disable */ import { ASN1TagClass as _TagClass } from "@wildboar/asn1"; import * as $ from "@wildboar/asn1/functional"; import { _decode_Identifier, _encode_Identifier, } from "../PKCS-15/Identifier.ta.mjs"; let _cached_decoder_for_SecurityCondition = null; /** * @summary Decodes an ASN.1 element into a(n) SecurityCondition * @function * @param {_Element} el The element being decoded. * @returns {SecurityCondition} The decoded data structure. */ export function _decode_SecurityCondition(el) { if (!_cached_decoder_for_SecurityCondition) { _cached_decoder_for_SecurityCondition = $._decode_extensible_choice({ "UNIVERSAL 4": ["authId", _decode_Identifier], "CONTEXT 0": [ "not", $._decode_explicit(() => _decode_SecurityCondition), ], "CONTEXT 1": [ "and", $._decode_implicit(() => $._decodeSequenceOf(() => _decode_SecurityCondition)), ], "CONTEXT 2": [ "or", $._decode_implicit(() => $._decodeSequenceOf(() => _decode_SecurityCondition)), ], }); } return _cached_decoder_for_SecurityCondition(el); } let _cached_encoder_for_SecurityCondition = null; /** * @summary Encodes a(n) SecurityCondition into an ASN.1 Element. * @function * @param value The element being encoded. * @param elGetter A function that can be used to get new ASN.1 elements. * @returns {_Element} The SecurityCondition, encoded as an ASN.1 Element. */ export function _encode_SecurityCondition(value, elGetter) { if (!_cached_encoder_for_SecurityCondition) { _cached_encoder_for_SecurityCondition = $._encode_choice({ authId: _encode_Identifier, not: $._encode_explicit(_TagClass.context, 0, () => _encode_SecurityCondition, $.BER), and: $._encode_implicit(_TagClass.context, 1, () => $._encodeSequenceOf(() => _encode_SecurityCondition, $.BER), $.BER), or: $._encode_implicit(_TagClass.context, 2, () => $._encodeSequenceOf(() => _encode_SecurityCondition, $.BER), $.BER), }, $.BER); } return _cached_encoder_for_SecurityCondition(value, elGetter); } /* eslint-enable */