File: //usr/lib/erlang/lib/public_key-1.13/src/PKCS-FRAME.erl
%% Generated by the Erlang ASN.1 BER compiler. Version: 5.0.19
%% Purpose: Encoding and decoding of the types in PKCS-FRAME.
-module('PKCS-FRAME').
-compile(nowarn_unused_vars).
-dialyzer(no_improper_lists).
-dialyzer(no_match).
-include("PKCS-FRAME.hrl").
-asn1_info([{vsn,'5.0.19'},
{module,'PKCS-FRAME'},
{options,[{i,"/root/rpm/otp/lib/public_key/asn1/../src"},
warnings,ber,errors,
{cwd,"/root/rpm/otp/lib/public_key/asn1"},
{outdir,"/root/rpm/otp/lib/public_key/asn1/../src"},
asn1config,noobj,der,
{i,"."},
{i,"/root/rpm/otp/lib/public_key/asn1"}]}]).
-export([encoding_rule/0,maps/0,bit_string_format/0,
legacy_erlang_types/0]).
-export(['dialyzer-suppressions'/1]).
-export([
'enc_RC5-CBC-Parameters'/2,
'enc_RC2-CBC-Parameter'/2,
'enc_PBMAC1-params'/2,
'enc_PBES2-params'/2,
enc_PBEParameter/2,
'enc_PBKDF2-params'/2,
enc_AttributeUsage/2,
enc_Context/2,
enc_EncryptedData/2,
enc_EncryptedPrivateKeyInfo/2,
enc_Attributes/2,
enc_PrivateKey/2,
enc_Version/2,
enc_PublicKey/2,
enc_OneAsymmetricKey/2,
enc_PrivateKeyInfo/2
]).
-export([
'dec_RC5-CBC-Parameters'/2,
'dec_RC2-CBC-Parameter'/2,
'dec_PBMAC1-params'/2,
'dec_PBES2-params'/2,
dec_PBEParameter/2,
'dec_PBKDF2-params'/2,
dec_AttributeUsage/2,
dec_Context/2,
dec_EncryptedData/2,
dec_EncryptedPrivateKeyInfo/2,
dec_Attributes/2,
dec_PrivateKey/2,
dec_Version/2,
dec_PublicKey/2,
dec_OneAsymmetricKey/2,
dec_PrivateKeyInfo/2
]).
-export([
getenc_SupportingAlgorithms/1,
'getenc_PBMAC1-MACs'/1,
'getenc_PBMAC1-KDFs'/1,
getenc_PBMAC1Algorithms/1,
'getenc_PBES2-Encs'/1,
'getenc_PBES2-KDFs'/1,
getenc_PBES2Algorithms/1,
getenc_PBES1Algorithms/1,
'getenc_PBKDF2-PRFs'/1,
'getenc_PBKDF2-SaltSources'/1,
getenc_SupportedContexts/1,
getenc_KeyEncryptionAlgorithms/1,
getenc_PrivateKeyAlgorithms/1,
getenc_internal_object_set_argument_9/1,
getenc_internal_object_set_argument_8/1,
getenc_internal_object_set_argument_7/1,
getenc_internal_object_set_argument_6/1,
getenc_internal_object_set_argument_5/1,
getenc_internal_object_set_argument_4/1,
getenc_internal_object_set_argument_3/1,
getenc_internal_object_set_argument_2/1,
getenc_internal_object_set_argument_1/1,
getenc_internal_object_set_argument_10/1
]).
-export([
getdec_SupportingAlgorithms/1,
'getdec_PBMAC1-MACs'/1,
'getdec_PBMAC1-KDFs'/1,
getdec_PBMAC1Algorithms/1,
'getdec_PBES2-Encs'/1,
'getdec_PBES2-KDFs'/1,
getdec_PBES2Algorithms/1,
getdec_PBES1Algorithms/1,
'getdec_PBKDF2-PRFs'/1,
'getdec_PBKDF2-SaltSources'/1,
getdec_SupportedContexts/1,
getdec_KeyEncryptionAlgorithms/1,
getdec_PrivateKeyAlgorithms/1,
getdec_internal_object_set_argument_9/1,
getdec_internal_object_set_argument_8/1,
getdec_internal_object_set_argument_7/1,
getdec_internal_object_set_argument_6/1,
getdec_internal_object_set_argument_5/1,
getdec_internal_object_set_argument_4/1,
getdec_internal_object_set_argument_3/1,
getdec_internal_object_set_argument_2/1,
getdec_internal_object_set_argument_1/1,
getdec_internal_object_set_argument_10/1
]).
-export([
'rc5-CBC-PAD'/0,
rc2CBC/0,
'des-EDE3-CBC'/0,
desCBC/0,
'id-hmacWithSHA1'/0,
encryptionAlgorithm/0,
digestAlgorithm/0,
'id-PBMAC1'/0,
'id-PBES2'/0,
'pbeWithSHA1AndRC2-CBC'/0,
'pbeWithSHA1AndDES-CBC'/0,
'pbeWithMD5AndRC2-CBC'/0,
'pbeWithMD5AndDES-CBC'/0,
'pbeWithMD2AndRC2-CBC'/0,
'pbeWithMD2AndDES-CBC'/0,
'id-PBKDF2'/0,
'pkcs-5'/0,
pkcs/0,
rsadsi/0
]).
-export([info/0]).
-export([encode/2,decode/2]).
encoding_rule() -> ber.
maps() -> false.
bit_string_format() -> bitstring.
legacy_erlang_types() -> false.
encode(Type, Data) ->
try iolist_to_binary(element(1, encode_disp(Type, Data))) of
Bytes ->
{ok,Bytes}
catch
Class:Exception:Stk when Class =:= error; Class =:= exit ->
case Exception of
{error,{asn1,Reason}} ->
{error,{asn1,{Reason,Stk}}};
Reason ->
{error,{asn1,{Reason,Stk}}}
end
end.
decode(Type, Data) ->
try
Result = decode_disp(Type, element(1, ber_decode_nif(Data))),
{ok,Result}
catch
Class:Exception:Stk when Class =:= error; Class =:= exit ->
case Exception of
{error,{asn1,Reason}} ->
{error,{asn1,{Reason,Stk}}};
Reason ->
{error,{asn1,{Reason,Stk}}}
end
end.
encode_disp('RC5-CBC-Parameters', Data) -> 'enc_RC5-CBC-Parameters'(Data);
encode_disp('RC2-CBC-Parameter', Data) -> 'enc_RC2-CBC-Parameter'(Data);
encode_disp('PBMAC1-params', Data) -> 'enc_PBMAC1-params'(Data);
encode_disp('PBES2-params', Data) -> 'enc_PBES2-params'(Data);
encode_disp('PBEParameter', Data) -> enc_PBEParameter(Data);
encode_disp('PBKDF2-params', Data) -> 'enc_PBKDF2-params'(Data);
encode_disp('AttributeUsage', Data) -> enc_AttributeUsage(Data);
encode_disp('Context', Data) -> enc_Context(Data);
encode_disp('EncryptedData', Data) -> enc_EncryptedData(Data);
encode_disp('EncryptedPrivateKeyInfo', Data) -> enc_EncryptedPrivateKeyInfo(Data);
encode_disp('Attributes', Data) -> enc_Attributes(Data);
encode_disp('PrivateKey', Data) -> enc_PrivateKey(Data);
encode_disp('Version', Data) -> enc_Version(Data);
encode_disp('PublicKey', Data) -> enc_PublicKey(Data);
encode_disp('OneAsymmetricKey', Data) -> enc_OneAsymmetricKey(Data);
encode_disp('PrivateKeyInfo', Data) -> enc_PrivateKeyInfo(Data);
encode_disp(Type, _Data) -> exit({error,{asn1,{undefined_type,Type}}}).
decode_disp('RC5-CBC-Parameters', Data) -> 'dec_RC5-CBC-Parameters'(Data);
decode_disp('RC2-CBC-Parameter', Data) -> 'dec_RC2-CBC-Parameter'(Data);
decode_disp('PBMAC1-params', Data) -> 'dec_PBMAC1-params'(Data);
decode_disp('PBES2-params', Data) -> 'dec_PBES2-params'(Data);
decode_disp('PBEParameter', Data) -> dec_PBEParameter(Data);
decode_disp('PBKDF2-params', Data) -> 'dec_PBKDF2-params'(Data);
decode_disp('AttributeUsage', Data) -> dec_AttributeUsage(Data);
decode_disp('Context', Data) -> dec_Context(Data);
decode_disp('EncryptedData', Data) -> dec_EncryptedData(Data);
decode_disp('EncryptedPrivateKeyInfo', Data) -> dec_EncryptedPrivateKeyInfo(Data);
decode_disp('Attributes', Data) -> dec_Attributes(Data);
decode_disp('PrivateKey', Data) -> dec_PrivateKey(Data);
decode_disp('Version', Data) -> dec_Version(Data);
decode_disp('PublicKey', Data) -> dec_PublicKey(Data);
decode_disp('OneAsymmetricKey', Data) -> dec_OneAsymmetricKey(Data);
decode_disp('PrivateKeyInfo', Data) -> dec_PrivateKeyInfo(Data);
decode_disp(Type, _Data) -> exit({error,{asn1,{undefined_type,Type}}}).
info() ->
case ?MODULE:module_info(attributes) of
Attributes when is_list(Attributes) ->
case lists:keyfind(asn1_info, 1, Attributes) of
{_,Info} when is_list(Info) ->
Info;
_ ->
[]
end;
_ ->
[]
end.
%%================================
%% RC5-CBC-Parameters
%%================================
'enc_RC5-CBC-Parameters'(Val) ->
'enc_RC5-CBC-Parameters'(Val, [<<48>>]).
'enc_RC5-CBC-Parameters'(Val, TagIn) ->
{_,Cindex1,Cindex2,Cindex3,Cindex4} = Val,
%%-------------------------------------------------
%% attribute version(1) with type INTEGER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_integer(Cindex1, [{'v1-0',16}], [<<2>>]),
%%-------------------------------------------------
%% attribute rounds(2) with type INTEGER
%%-------------------------------------------------
{EncBytes2,EncLen2} = encode_integer(Cindex2, [<<2>>]),
%%-------------------------------------------------
%% attribute blockSizeInBits(3) with type INTEGER
%%-------------------------------------------------
{EncBytes3,EncLen3} = encode_integer(Cindex3, [<<2>>]),
%%-------------------------------------------------
%% attribute iv(4) with type OCTET STRING OPTIONAL
%%-------------------------------------------------
{EncBytes4,EncLen4} = case Cindex4 of
asn1_NOVALUE -> {<<>>,0};
_ ->
encode_restricted_string(Cindex4, [<<4>>])
end,
BytesSoFar = [EncBytes1, EncBytes2, EncBytes3, EncBytes4],
LenSoFar = EncLen1 + EncLen2 + EncLen3 + EncLen4,
encode_tags(TagIn, BytesSoFar, LenSoFar).
'dec_RC5-CBC-Parameters'(Tlv) ->
'dec_RC5-CBC-Parameters'(Tlv, [16]).
'dec_RC5-CBC-Parameters'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute version(1) with type INTEGER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = begin
Val1 = decode_integer(V1, [2]),
number2name(Val1, [{'v1-0',16}])
end
,
%%-------------------------------------------------
%% attribute rounds(2) with type INTEGER
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = begin
Val2 = decode_integer(V2, [2]),
if 8 =< Val2, Val2 =< 127 ->
Val2;
true ->
exit({error,{asn1,bad_range}})
end
end,
%%-------------------------------------------------
%% attribute blockSizeInBits(3) with type INTEGER
%%-------------------------------------------------
[V3|Tlv4] = Tlv3,
Term3 = begin
Val3 = decode_integer(V3, [2]),
if 64 =< Val3, Val3 =< 128 ->
Val3;
true ->
exit({error,{asn1,bad_range}})
end
end,
%%-------------------------------------------------
%% attribute iv(4) with type OCTET STRING OPTIONAL
%%-------------------------------------------------
{Term4,Tlv5} = case Tlv4 of
[{4,V4}|TempTlv5] ->
{decode_octet_string(V4, []), TempTlv5};
_ ->
{ asn1_NOVALUE, Tlv4}
end,
case Tlv5 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv5}}}) % extra fields not allowed
end,
Res1 = {'RC5-CBC-Parameters',Term1,Term2,Term3,Term4},
Res1.
%%================================
%% RC2-CBC-Parameter
%%================================
'enc_RC2-CBC-Parameter'(Val) ->
'enc_RC2-CBC-Parameter'(Val, [<<48>>]).
'enc_RC2-CBC-Parameter'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
%%-------------------------------------------------
%% attribute rc2ParameterVersion(1) with type INTEGER OPTIONAL
%%-------------------------------------------------
{EncBytes1,EncLen1} = case Cindex1 of
asn1_NOVALUE -> {<<>>,0};
_ ->
encode_integer(Cindex1, [<<2>>])
end,
%%-------------------------------------------------
%% attribute iv(2) with type OCTET STRING
%%-------------------------------------------------
{EncBytes2,EncLen2} = encode_restricted_string(Cindex2, [<<4>>]),
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
'dec_RC2-CBC-Parameter'(Tlv) ->
'dec_RC2-CBC-Parameter'(Tlv, [16]).
'dec_RC2-CBC-Parameter'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute rc2ParameterVersion(1) with type INTEGER OPTIONAL
%%-------------------------------------------------
{Term1,Tlv2} = case Tlv1 of
[{2,V1}|TempTlv2] ->
{decode_integer(V1, []), TempTlv2};
_ ->
{ asn1_NOVALUE, Tlv1}
end,
%%-------------------------------------------------
%% attribute iv(2) with type OCTET STRING
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = begin
Val1 = decode_octet_string(V2, [4]),
C1 = byte_size(Val1),
if C1 =:= 8 ->
Val1;
true ->
exit({error,{asn1,bad_range}})
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'RC2-CBC-Parameter',Term1,Term2},
Res1.
%%================================
%% PBMAC1-params
%%================================
'enc_PBMAC1-params'(Val) ->
'enc_PBMAC1-params'(Val, [<<48>>]).
'enc_PBMAC1-params'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
%%-------------------------------------------------
%% attribute keyDerivationFunc(1) with type SEQUENCE
%%-------------------------------------------------
{EncBytes1,EncLen1} = 'enc_PBMAC1-params_keyDerivationFunc'(Cindex1, [<<48>>]),
%%-------------------------------------------------
%% attribute messageAuthScheme(2) with type SEQUENCE
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_PBMAC1-params_messageAuthScheme'(Cindex2, [<<48>>]),
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PBMAC1-params_keyDerivationFunc
%%================================
'enc_PBMAC1-params_keyDerivationFunc'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_1'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PBMAC1-params_messageAuthScheme
%%================================
'enc_PBMAC1-params_messageAuthScheme'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_2'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
'dec_PBMAC1-params'(Tlv) ->
'dec_PBMAC1-params'(Tlv, [16]).
'dec_PBMAC1-params'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute keyDerivationFunc(1) with type SEQUENCE
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = 'dec_PBMAC1-params_keyDerivationFunc'(V1, [16]),
%%-------------------------------------------------
%% attribute messageAuthScheme(2) with type SEQUENCE
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_PBMAC1-params_messageAuthScheme'(V2, [16]),
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBMAC1-params',Term1,Term2},
Res1.
'dec_PBMAC1-params_keyDerivationFunc'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_1'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBMAC1-params_keyDerivationFunc',Term1,Term2},
Res1.
'dec_PBMAC1-params_messageAuthScheme'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_2'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBMAC1-params_messageAuthScheme',Term1,Term2},
Res1.
%%================================
%% PBES2-params
%%================================
'enc_PBES2-params'(Val) ->
'enc_PBES2-params'(Val, [<<48>>]).
'enc_PBES2-params'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
%%-------------------------------------------------
%% attribute keyDerivationFunc(1) with type SEQUENCE
%%-------------------------------------------------
{EncBytes1,EncLen1} = 'enc_PBES2-params_keyDerivationFunc'(Cindex1, [<<48>>]),
%%-------------------------------------------------
%% attribute encryptionScheme(2) with type SEQUENCE
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_PBES2-params_encryptionScheme'(Cindex2, [<<48>>]),
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PBES2-params_keyDerivationFunc
%%================================
'enc_PBES2-params_keyDerivationFunc'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_3'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PBES2-params_encryptionScheme
%%================================
'enc_PBES2-params_encryptionScheme'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_4'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
'dec_PBES2-params'(Tlv) ->
'dec_PBES2-params'(Tlv, [16]).
'dec_PBES2-params'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute keyDerivationFunc(1) with type SEQUENCE
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = 'dec_PBES2-params_keyDerivationFunc'(V1, [16]),
%%-------------------------------------------------
%% attribute encryptionScheme(2) with type SEQUENCE
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_PBES2-params_encryptionScheme'(V2, [16]),
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBES2-params',Term1,Term2},
Res1.
'dec_PBES2-params_keyDerivationFunc'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_3'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBES2-params_keyDerivationFunc',Term1,Term2},
Res1.
'dec_PBES2-params_encryptionScheme'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_4'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBES2-params_encryptionScheme',Term1,Term2},
Res1.
%%================================
%% PBEParameter
%%================================
enc_PBEParameter(Val) ->
enc_PBEParameter(Val, [<<48>>]).
enc_PBEParameter(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
%%-------------------------------------------------
%% attribute salt(1) with type OCTET STRING
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_restricted_string(Cindex1, [<<4>>]),
%%-------------------------------------------------
%% attribute iterationCount(2) with type INTEGER
%%-------------------------------------------------
{EncBytes2,EncLen2} = encode_integer(Cindex2, [<<2>>]),
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
dec_PBEParameter(Tlv) ->
dec_PBEParameter(Tlv, [16]).
dec_PBEParameter(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute salt(1) with type OCTET STRING
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = begin
Val1 = decode_octet_string(V1, [4]),
C1 = byte_size(Val1),
if C1 =:= 8 ->
Val1;
true ->
exit({error,{asn1,bad_range}})
end
end,
%%-------------------------------------------------
%% attribute iterationCount(2) with type INTEGER
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = decode_integer(V2, [2]),
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBEParameter',Term1,Term2},
Res1.
%%================================
%% PBKDF2-params
%%================================
'enc_PBKDF2-params'(Val) ->
'enc_PBKDF2-params'(Val, [<<48>>]).
'enc_PBKDF2-params'(Val, TagIn) ->
{_,Cindex1,Cindex2,Cindex3,Cindex4} = Val,
%%-------------------------------------------------
%% attribute salt(1) with type CHOICE
%%-------------------------------------------------
{EncBytes1,EncLen1} = 'enc_PBKDF2-params_salt'(Cindex1, []),
%%-------------------------------------------------
%% attribute iterationCount(2) with type INTEGER
%%-------------------------------------------------
{EncBytes2,EncLen2} = encode_integer(Cindex2, [<<2>>]),
%%-------------------------------------------------
%% attribute keyLength(3) with type INTEGER OPTIONAL
%%-------------------------------------------------
{EncBytes3,EncLen3} = case Cindex3 of
asn1_NOVALUE -> {<<>>,0};
_ ->
encode_integer(Cindex3, [<<2>>])
end,
%%-------------------------------------------------
%% attribute prf(4) with type SEQUENCE DEFAULT = {'PBKDF2-params_prf',{1,2,840,113549,2,7},'NULL'}
%%-------------------------------------------------
{EncBytes4,EncLen4} = case is_default_1(Cindex4) of
true -> {[],0};
false ->
'enc_PBKDF2-params_prf'(Cindex4, [<<48>>])
end,
BytesSoFar = [EncBytes1, EncBytes2, EncBytes3, EncBytes4],
LenSoFar = EncLen1 + EncLen2 + EncLen3 + EncLen4,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PBKDF2-params_salt
%%================================
'enc_PBKDF2-params_salt'(Val, TagIn) ->
{EncBytes,EncLen} = case element(1,Val) of
specified ->
encode_restricted_string(element(2,Val), [<<4>>]);
otherSource ->
'enc_PBKDF2-params_salt_otherSource'(element(2,Val), [<<48>>]);
Else ->
exit({error,{asn1,{invalid_choice_type,Else}}})
end,
encode_tags(TagIn, EncBytes, EncLen).
%%================================
%% PBKDF2-params_salt_otherSource
%%================================
'enc_PBKDF2-params_salt_otherSource'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_5'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PBKDF2-params_prf
%%================================
'enc_PBKDF2-params_prf'(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_6'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
'dec_PBKDF2-params'(Tlv) ->
'dec_PBKDF2-params'(Tlv, [16]).
'dec_PBKDF2-params'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute salt(1) with type CHOICE
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = 'dec_PBKDF2-params_salt'(V1, []),
%%-------------------------------------------------
%% attribute iterationCount(2) with type INTEGER
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = begin
Val1 = decode_integer(V2, [2]),
if 1 =< Val1, Val1 =< 'MAX' ->
Val1;
true ->
exit({error,{asn1,bad_range}})
end
end,
%%-------------------------------------------------
%% attribute keyLength(3) with type INTEGER OPTIONAL
%%-------------------------------------------------
{Term3,Tlv4} = case Tlv3 of
[{2,V3}|TempTlv4] ->
{begin
Val2 = decode_integer(V3, []),
if 1 =< Val2, Val2 =< 'MAX' ->
Val2;
true ->
exit({error,{asn1,bad_range}})
end
end, TempTlv4};
_ ->
{ asn1_NOVALUE, Tlv3}
end,
%%-------------------------------------------------
%% attribute prf(4) with type SEQUENCE DEFAULT = {'PBKDF2-params_prf',{1,2,840,113549,2,7},'NULL'}
%%-------------------------------------------------
{Term4,Tlv5} = case Tlv4 of
[{16,V4}|TempTlv5] ->
{'dec_PBKDF2-params_prf'(V4, []), TempTlv5};
_ ->
{{'PBKDF2-params_prf',{1,2,840,113549,2,7},'NULL'},Tlv4}
end,
case Tlv5 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv5}}}) % extra fields not allowed
end,
Res1 = {'PBKDF2-params',Term1,Term2,Term3,Term4},
Res1.
'dec_PBKDF2-params_salt'(Tlv, TagIn) ->
Tlv1 = match_tags(Tlv, TagIn),
case (case Tlv1 of [CtempTlv1] -> CtempTlv1; _ -> Tlv1 end) of
%% 'specified'
{4, V1} ->
{specified, decode_octet_string(V1, [])};
%% 'otherSource'
{16, V1} ->
{otherSource, 'dec_PBKDF2-params_salt_otherSource'(V1, [])};
Else ->
exit({error,{asn1,{invalid_choice_tag,Else}}})
end
.
'dec_PBKDF2-params_salt_otherSource'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_5'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBKDF2-params_salt_otherSource',Term1,Term2},
Res1.
'dec_PBKDF2-params_prf'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_6'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PBKDF2-params_prf',Term1,Term2},
Res1.
%%================================
%% AttributeUsage
%%================================
enc_AttributeUsage(Val) ->
enc_AttributeUsage(Val, [<<10>>]).
enc_AttributeUsage(Val, TagIn) ->
case Val of
userApplications -> encode_tags(TagIn, [0], 1);
directoryOperation -> encode_tags(TagIn, [1], 1);
distributedOperation -> encode_tags(TagIn, [2], 1);
dSAOperation -> encode_tags(TagIn, [3], 1);
Enumval1 -> exit({error,{asn1, {enumerated_not_in_range,Enumval1}}})
end.
dec_AttributeUsage(Tlv) ->
dec_AttributeUsage(Tlv, [10]).
dec_AttributeUsage(Tlv, TagIn) ->
case decode_integer(Tlv, TagIn) of
0 -> userApplications;
1 -> directoryOperation;
2 -> distributedOperation;
3 -> dSAOperation;
Default1 -> exit({error,{asn1,{illegal_enumerated,Default1}}})
end.
%%================================
%% Context
%%================================
enc_Context(Val) ->
enc_Context(Val, [<<48>>]).
enc_Context(Val, TagIn) ->
{_,Cindex1,Cindex2,Cindex3} = Val,
ObjcontextType =
'PKCS-FRAME':'getenc_SupportedContexts'( Cindex1),
%%-------------------------------------------------
%% attribute contextType(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute contextValues(2) with type SET OF
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_Context_contextValues'(Cindex2, [<<49>>], ObjcontextType),
%%-------------------------------------------------
%% attribute fallback(3) with type BOOLEAN DEFAULT = false
%%-------------------------------------------------
{EncBytes3,EncLen3} = case is_default_2(Cindex3) of
true -> {[],0};
false ->
encode_boolean(Cindex3, [<<1>>])
end,
BytesSoFar = [EncBytes1, EncBytes2, EncBytes3],
LenSoFar = EncLen1 + EncLen2 + EncLen3,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% Context_contextValues
%%================================
enc_Context_contextValues(Val, TagIn, ObjFun) ->
{EncBytes,EncLen} = 'enc_Context_contextValues_components'(Val, ObjFun,[],0),
encode_tags(TagIn, EncBytes, EncLen).
'enc_Context_contextValues_components'([], _, AccBytes, AccLen) ->
{dynamicsort_SETOF(AccBytes),AccLen};
'enc_Context_contextValues_components'([H|T], ObjFun,AccBytes, AccLen) ->
{TmpBytes,_} = ObjFun('Type', H, []),
{EncBytes,EncLen} = encode_open_type(TmpBytes, [])
,
'enc_Context_contextValues_components'(T, ObjFun,[EncBytes|AccBytes], AccLen + EncLen).
dec_Context(Tlv) ->
dec_Context(Tlv, [16]).
dec_Context(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute contextType(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
ObjFun = 'PKCS-FRAME':'getdec_SupportedContexts'(Term1),
%%-------------------------------------------------
%% attribute contextValues(2) with type SET OF
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_Context_contextValues'(V2, [17], ObjFun),
%%-------------------------------------------------
%% attribute fallback(3) with type BOOLEAN DEFAULT = false
%%-------------------------------------------------
{Term3,Tlv4} = case Tlv3 of
[{1,V3}|TempTlv4] ->
{decode_boolean(V3, []), TempTlv4};
_ ->
{false,Tlv3}
end,
case Tlv4 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv4}}}) % extra fields not allowed
end,
Res1 = {'Context',Term1,Term2,Term3},
Res1.
'dec_Context_contextValues'(Tlv, TagIn, ObjFun) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
[
begin
Tmptlv1 = decode_open_type(V1, []),
case (catch ObjFun('Type', Tmptlv1, [])) of
{'EXIT',Reason1} ->
exit({'Type not compatible with table constraint', Reason1});
Tmpterm1 ->
Tmpterm1
end
end
|| V1 <- Tlv1].
%%================================
%% EncryptedData
%%================================
enc_EncryptedData(Val) ->
enc_EncryptedData(Val, [<<4>>]).
enc_EncryptedData(Val, TagIn) ->
encode_restricted_string(Val, TagIn).
dec_EncryptedData(Tlv) ->
dec_EncryptedData(Tlv, [4]).
dec_EncryptedData(Tlv, TagIn) ->
decode_octet_string(Tlv, TagIn).
%%================================
%% EncryptedPrivateKeyInfo
%%================================
enc_EncryptedPrivateKeyInfo(Val) ->
enc_EncryptedPrivateKeyInfo(Val, [<<48>>]).
enc_EncryptedPrivateKeyInfo(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
%%-------------------------------------------------
%% attribute encryptionAlgorithm(1) with type SEQUENCE
%%-------------------------------------------------
{EncBytes1,EncLen1} = 'enc_EncryptedPrivateKeyInfo_encryptionAlgorithm'(Cindex1, [<<48>>]),
%%-------------------------------------------------
%% attribute encryptedData(2) with type OCTET STRING
%%-------------------------------------------------
{EncBytes2,EncLen2} = encode_restricted_string(Cindex2, [<<4>>]),
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% EncryptedPrivateKeyInfo_encryptionAlgorithm
%%================================
enc_EncryptedPrivateKeyInfo_encryptionAlgorithm(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_7'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
dec_EncryptedPrivateKeyInfo(Tlv) ->
dec_EncryptedPrivateKeyInfo(Tlv, [16]).
dec_EncryptedPrivateKeyInfo(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute encryptionAlgorithm(1) with type SEQUENCE
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = 'dec_EncryptedPrivateKeyInfo_encryptionAlgorithm'(V1, [16]),
%%-------------------------------------------------
%% attribute encryptedData(2) with type OCTET STRING
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = decode_octet_string(V2, [4]),
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'EncryptedPrivateKeyInfo',Term1,Term2},
Res1.
'dec_EncryptedPrivateKeyInfo_encryptionAlgorithm'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_7'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'EncryptedPrivateKeyInfo_encryptionAlgorithm',Term1,Term2},
Res1.
%%================================
%% Attributes
%%================================
enc_Attributes(Val) ->
enc_Attributes(Val, [<<49>>]).
enc_Attributes(Val, TagIn) ->
{EncBytes,EncLen} = 'enc_Attributes_components'(Val,[],0),
encode_tags(TagIn, EncBytes, EncLen).
'enc_Attributes_components'([], AccBytes, AccLen) ->
{dynamicsort_SETOF(AccBytes),AccLen};
'enc_Attributes_components'([H|T],AccBytes, AccLen) ->
{EncBytes,EncLen} = 'enc_Attributes_PKAttribute'(H, [<<48>>]),
'enc_Attributes_components'(T,[EncBytes|AccBytes], AccLen + EncLen).
%%================================
%% Attributes_PKAttribute
%%================================
enc_Attributes_PKAttribute(Val, TagIn) ->
{_,Cindex1,Cindex2,Cindex3} = Val,
Objtype =
'PKCS-FRAME':'getenc_internal_object_set_argument_8'( Cindex1),
%%-------------------------------------------------
%% attribute type(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute values(2) with type SET OF
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_Attributes_PKAttribute_values'(Cindex2, [<<49>>], Objtype),
%%-------------------------------------------------
%% attribute valuesWithContext(3) with type SET OF OPTIONAL
%%-------------------------------------------------
{EncBytes3,EncLen3} = case Cindex3 of
asn1_NOVALUE -> {<<>>,0};
_ ->
'enc_Attributes_PKAttribute_valuesWithContext'(Cindex3, [<<49>>], Objtype)
end,
BytesSoFar = [EncBytes1, EncBytes2, EncBytes3],
LenSoFar = EncLen1 + EncLen2 + EncLen3,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% Attributes_PKAttribute_values
%%================================
enc_Attributes_PKAttribute_values(Val, TagIn, ObjFun) ->
{EncBytes,EncLen} = 'enc_Attributes_PKAttribute_values_components'(Val, ObjFun,[],0),
encode_tags(TagIn, EncBytes, EncLen).
'enc_Attributes_PKAttribute_values_components'([], _, AccBytes, AccLen) ->
{dynamicsort_SETOF(AccBytes),AccLen};
'enc_Attributes_PKAttribute_values_components'([H|T], ObjFun,AccBytes, AccLen) ->
{TmpBytes,_} = ObjFun('Type', H, []),
{EncBytes,EncLen} = encode_open_type(TmpBytes, [])
,
'enc_Attributes_PKAttribute_values_components'(T, ObjFun,[EncBytes|AccBytes], AccLen + EncLen).
%%================================
%% Attributes_PKAttribute_valuesWithContext
%%================================
enc_Attributes_PKAttribute_valuesWithContext(Val, TagIn, ObjFun) ->
{EncBytes,EncLen} = 'enc_Attributes_PKAttribute_valuesWithContext_components'(Val, ObjFun,[],0),
encode_tags(TagIn, EncBytes, EncLen).
'enc_Attributes_PKAttribute_valuesWithContext_components'([], _, AccBytes, AccLen) ->
{dynamicsort_SETOF(AccBytes),AccLen};
'enc_Attributes_PKAttribute_valuesWithContext_components'([H|T], ObjFun,AccBytes, AccLen) ->
{EncBytes,EncLen} = 'enc_Attributes_PKAttribute_valuesWithContext_SETOF'(H, [<<48>>], ObjFun),
'enc_Attributes_PKAttribute_valuesWithContext_components'(T, ObjFun,[EncBytes|AccBytes], AccLen + EncLen).
%%================================
%% Attributes_PKAttribute_valuesWithContext_SETOF
%%================================
enc_Attributes_PKAttribute_valuesWithContext_SETOF(Val, TagIn, ObjFun) ->
{_,Cindex1,Cindex2} = Val,
%%-------------------------------------------------
%% attribute value(1) with type typefieldType
%%-------------------------------------------------
{TmpBytes1,_} = ObjFun('Type', Cindex1, []),
{EncBytes1,EncLen1} = encode_open_type(TmpBytes1, [])
,
%%-------------------------------------------------
%% attribute contextList(2) with type SET OF
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_Attributes_PKAttribute_valuesWithContext_SETOF_contextList'(Cindex2, [<<49>>]),
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% Attributes_PKAttribute_valuesWithContext_SETOF_contextList
%%================================
enc_Attributes_PKAttribute_valuesWithContext_SETOF_contextList(Val, TagIn) ->
{EncBytes,EncLen} = 'enc_Attributes_PKAttribute_valuesWithContext_SETOF_contextList_components'(Val,[],0),
encode_tags(TagIn, EncBytes, EncLen).
'enc_Attributes_PKAttribute_valuesWithContext_SETOF_contextList_components'([], AccBytes, AccLen) ->
{dynamicsort_SETOF(AccBytes),AccLen};
'enc_Attributes_PKAttribute_valuesWithContext_SETOF_contextList_components'([H|T],AccBytes, AccLen) ->
{EncBytes,EncLen} = 'enc_Context'(H, [<<48>>]),
'enc_Attributes_PKAttribute_valuesWithContext_SETOF_contextList_components'(T,[EncBytes|AccBytes], AccLen + EncLen).
dec_Attributes(Tlv) ->
dec_Attributes(Tlv, [17]).
dec_Attributes(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
['dec_Attributes_PKAttribute'(V1, [16]) || V1 <- Tlv1].
'dec_Attributes_PKAttribute'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute type(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
ObjFun = 'PKCS-FRAME':'getdec_internal_object_set_argument_8'(Term1),
%%-------------------------------------------------
%% attribute values(2) with type SET OF
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_Attributes_PKAttribute_values'(V2, [17], ObjFun),
%%-------------------------------------------------
%% attribute valuesWithContext(3) with type SET OF OPTIONAL
%%-------------------------------------------------
{Term3,Tlv4} = case Tlv3 of
[{17,V3}|TempTlv4] ->
{'dec_Attributes_PKAttribute_valuesWithContext'(V3, [], ObjFun), TempTlv4};
_ ->
{ asn1_NOVALUE, Tlv3}
end,
case Tlv4 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv4}}}) % extra fields not allowed
end,
Res1 = {'PKAttribute',Term1,Term2,Term3},
Res1.
'dec_Attributes_PKAttribute_values'(Tlv, TagIn, ObjFun) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
[
begin
Tmptlv1 = decode_open_type(V1, []),
case (catch ObjFun('Type', Tmptlv1, [])) of
{'EXIT',Reason1} ->
exit({'Type not compatible with table constraint', Reason1});
Tmpterm1 ->
Tmpterm1
end
end
|| V1 <- Tlv1].
'dec_Attributes_PKAttribute_valuesWithContext'(Tlv, TagIn, ObjFun) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
['dec_Attributes_PKAttribute_valuesWithContext_SETOF'(V1, [16], ObjFun) || V1 <- Tlv1].
'dec_Attributes_PKAttribute_valuesWithContext_SETOF'(Tlv, TagIn, ObjFun) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute value(1) with type typefieldType
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 =
begin
Tmptlv1 = decode_open_type(V1, []),
case (catch ObjFun('Type', Tmptlv1, [])) of
{'EXIT',Reason1} ->
exit({'Type not compatible with table constraint', Reason1});
Tmpterm1 ->
Tmpterm1
end
end
,
%%-------------------------------------------------
%% attribute contextList(2) with type SET OF
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_Attributes_PKAttribute_valuesWithContext_SETOF_contextList'(V2, [17]),
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'Attributes_PKAttribute_valuesWithContext_SETOF',Term1,Term2},
Res1.
'dec_Attributes_PKAttribute_valuesWithContext_SETOF_contextList'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
['dec_Context'(V1, [16]) || V1 <- Tlv1].
%%================================
%% PrivateKey
%%================================
enc_PrivateKey(Val) ->
enc_PrivateKey(Val, [<<4>>]).
enc_PrivateKey(Val, TagIn) ->
encode_restricted_string(Val, TagIn).
dec_PrivateKey(Tlv) ->
dec_PrivateKey(Tlv, [4]).
dec_PrivateKey(Tlv, TagIn) ->
decode_octet_string(Tlv, TagIn).
%%================================
%% Version
%%================================
enc_Version(Val) ->
enc_Version(Val, [<<2>>]).
enc_Version(Val, TagIn) ->
encode_integer(Val, [{v1,0}], TagIn).
dec_Version(Tlv) ->
dec_Version(Tlv, [2]).
dec_Version(Tlv, TagIn) ->
begin
Val1 = decode_integer(Tlv, TagIn),
number2name(Val1, [{v1,0}])
end
.
%%================================
%% PublicKey
%%================================
enc_PublicKey(Val) ->
enc_PublicKey(Val, [<<3>>]).
enc_PublicKey(Val, TagIn) ->
encode_unnamed_bit_string(Val, TagIn).
dec_PublicKey(Tlv) ->
dec_PublicKey(Tlv, [3]).
dec_PublicKey(Tlv, TagIn) ->
decode_native_bit_string(Tlv, TagIn).
%%================================
%% OneAsymmetricKey
%%================================
enc_OneAsymmetricKey(Val) ->
enc_OneAsymmetricKey(Val, [<<48>>]).
enc_OneAsymmetricKey(Val, TagIn) ->
{_,Cindex1,Cindex2,Cindex3,Cindex4,Cindex5} = Val,
%%-------------------------------------------------
%% attribute version(1) with type INTEGER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_integer(Cindex1, [{v1,0}], [<<2>>]),
%%-------------------------------------------------
%% attribute privateKeyAlgorithm(2) with type SEQUENCE
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_OneAsymmetricKey_privateKeyAlgorithm'(Cindex2, [<<48>>]),
%%-------------------------------------------------
%% attribute privateKey(3) with type OCTET STRING
%%-------------------------------------------------
{EncBytes3,EncLen3} = encode_restricted_string(Cindex3, [<<4>>]),
%%-------------------------------------------------
%% attribute attributes(4) External PKCS-FRAME:Attributes OPTIONAL
%%-------------------------------------------------
{EncBytes4,EncLen4} = case Cindex4 of
asn1_NOVALUE -> {<<>>,0};
_ ->
'enc_Attributes'(Cindex4, [<<160>>])
end,
%%-------------------------------------------------
%% attribute publicKey(5) with type BIT STRING OPTIONAL
%%-------------------------------------------------
{EncBytes5,EncLen5} = case Cindex5 of
asn1_NOVALUE -> {<<>>,0};
_ ->
encode_unnamed_bit_string(Cindex5, [<<129>>])
end,
BytesSoFar = [EncBytes1, EncBytes2, EncBytes3, EncBytes4, EncBytes5],
LenSoFar = EncLen1 + EncLen2 + EncLen3 + EncLen4 + EncLen5,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% OneAsymmetricKey_privateKeyAlgorithm
%%================================
enc_OneAsymmetricKey_privateKeyAlgorithm(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_9'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
dec_OneAsymmetricKey(Tlv) ->
dec_OneAsymmetricKey(Tlv, [16]).
dec_OneAsymmetricKey(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute version(1) with type INTEGER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = begin
Val1 = decode_integer(V1, [2]),
number2name(Val1, [{v1,0}])
end
,
%%-------------------------------------------------
%% attribute privateKeyAlgorithm(2) with type SEQUENCE
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_OneAsymmetricKey_privateKeyAlgorithm'(V2, [16]),
%%-------------------------------------------------
%% attribute privateKey(3) with type OCTET STRING
%%-------------------------------------------------
[V3|Tlv4] = Tlv3,
Term3 = decode_octet_string(V3, [4]),
%%-------------------------------------------------
%% attribute attributes(4) External PKCS-FRAME:Attributes OPTIONAL
%%-------------------------------------------------
{Term4,Tlv5} = case Tlv4 of
[{131072,V4}|TempTlv5] ->
{'dec_Attributes'(V4, []), TempTlv5};
_ ->
{ asn1_NOVALUE, Tlv4}
end,
%%-------------------------------------------------
%% attribute publicKey(5) with type BIT STRING OPTIONAL
%%-------------------------------------------------
{Term5,Tlv6} = case Tlv5 of
[{131073,V5}|TempTlv6] ->
{decode_native_bit_string(V5, []), TempTlv6};
_ ->
{ asn1_NOVALUE, Tlv5}
end,
Tlv7 = skip_ExtensionAdditions(Tlv6, []),
case Tlv7 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv7}}}) % extra fields not allowed
end,
Res1 = {'OneAsymmetricKey',Term1,Term2,Term3,Term4,Term5},
Res1.
'dec_OneAsymmetricKey_privateKeyAlgorithm'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_9'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'OneAsymmetricKey_privateKeyAlgorithm',Term1,Term2},
Res1.
%%================================
%% PrivateKeyInfo
%%================================
enc_PrivateKeyInfo(Val) ->
enc_PrivateKeyInfo(Val, [<<48>>]).
enc_PrivateKeyInfo(Val, TagIn) ->
{_,Cindex1,Cindex2,Cindex3,Cindex4} = Val,
%%-------------------------------------------------
%% attribute version(1) with type INTEGER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_integer(Cindex1, [{v1,0}], [<<2>>]),
%%-------------------------------------------------
%% attribute privateKeyAlgorithm(2) with type SEQUENCE
%%-------------------------------------------------
{EncBytes2,EncLen2} = 'enc_PrivateKeyInfo_privateKeyAlgorithm'(Cindex2, [<<48>>]),
%%-------------------------------------------------
%% attribute privateKey(3) with type OCTET STRING
%%-------------------------------------------------
{EncBytes3,EncLen3} = encode_restricted_string(Cindex3, [<<4>>]),
%%-------------------------------------------------
%% attribute attributes(4) External PKCS-FRAME:Attributes OPTIONAL
%%-------------------------------------------------
{EncBytes4,EncLen4} = case Cindex4 of
asn1_NOVALUE -> {<<>>,0};
_ ->
'enc_Attributes'(Cindex4, [<<160>>])
end,
BytesSoFar = [EncBytes1, EncBytes2, EncBytes3, EncBytes4],
LenSoFar = EncLen1 + EncLen2 + EncLen3 + EncLen4,
encode_tags(TagIn, BytesSoFar, LenSoFar).
%%================================
%% PrivateKeyInfo_privateKeyAlgorithm
%%================================
enc_PrivateKeyInfo_privateKeyAlgorithm(Val, TagIn) ->
{_,Cindex1,Cindex2} = Val,
Objalgorithm =
'PKCS-FRAME':'getenc_internal_object_set_argument_10'( Cindex1),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
{EncBytes1,EncLen1} = encode_object_identifier(Cindex1, [<<6>>]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{EncBytes2,EncLen2} = case Cindex2 of
asn1_NOVALUE -> {<<>>,0};
_ ->
{TmpBytes2,_ } = Objalgorithm('Type', Cindex2, []),
encode_open_type(TmpBytes2, [])
end,
BytesSoFar = [EncBytes1, EncBytes2],
LenSoFar = EncLen1 + EncLen2,
encode_tags(TagIn, BytesSoFar, LenSoFar).
dec_PrivateKeyInfo(Tlv) ->
dec_PrivateKeyInfo(Tlv, [16]).
dec_PrivateKeyInfo(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute version(1) with type INTEGER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = begin
Val1 = decode_integer(V1, [2]),
number2name(Val1, [{v1,0}])
end
,
%%-------------------------------------------------
%% attribute privateKeyAlgorithm(2) with type SEQUENCE
%%-------------------------------------------------
[V2|Tlv3] = Tlv2,
Term2 = 'dec_PrivateKeyInfo_privateKeyAlgorithm'(V2, [16]),
%%-------------------------------------------------
%% attribute privateKey(3) with type OCTET STRING
%%-------------------------------------------------
[V3|Tlv4] = Tlv3,
Term3 = decode_octet_string(V3, [4]),
%%-------------------------------------------------
%% attribute attributes(4) External PKCS-FRAME:Attributes OPTIONAL
%%-------------------------------------------------
{Term4,Tlv5} = case Tlv4 of
[{131072,V4}|TempTlv5] ->
{'dec_Attributes'(V4, []), TempTlv5};
_ ->
{ asn1_NOVALUE, Tlv4}
end,
case Tlv5 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv5}}}) % extra fields not allowed
end,
Res1 = {'PrivateKeyInfo',Term1,Term2,Term3,Term4},
Res1.
'dec_PrivateKeyInfo_privateKeyAlgorithm'(Tlv, TagIn) ->
%%-------------------------------------------------
%% decode tag and length
%%-------------------------------------------------
Tlv1 = match_tags(Tlv, TagIn),
%%-------------------------------------------------
%% attribute algorithm(1) with type OBJECT IDENTIFIER
%%-------------------------------------------------
[V1|Tlv2] = Tlv1,
Term1 = decode_object_identifier(V1, [6]),
%%-------------------------------------------------
%% attribute parameters(2) with type typefieldType OPTIONAL
%%-------------------------------------------------
{Tmpterm1,Tlv3} = case Tlv2 of
[V2|TempTlv3] ->
{decode_open_type(V2, []), TempTlv3};
_ ->
{ asn1_NOVALUE, Tlv2}
end,
DecObjalgorithmTerm1 =
'PKCS-FRAME':'getdec_internal_object_set_argument_10'(Term1),
Term2 =
case Tmpterm1 of
asn1_NOVALUE ->asn1_NOVALUE;
_ ->
case (catch DecObjalgorithmTerm1('Type', Tmpterm1, [])) of
{'EXIT', Reason1} ->
exit({'Type not compatible with table constraint',Reason1});
Tmpterm2 ->
Tmpterm2
end
end,
case Tlv3 of
[] -> true;_ -> exit({error,{asn1, {unexpected,Tlv3}}}) % extra fields not allowed
end,
Res1 = {'PrivateKeyInfo_privateKeyAlgorithm',Term1,Term2},
Res1.
'rc5-CBC-PAD'() ->
{1,2,840,113549,3,9}.
rc2CBC() ->
{1,2,840,113549,3,2}.
'des-EDE3-CBC'() ->
{1,2,840,113549,3,7}.
desCBC() ->
{1,3,14,3,2,7}.
'id-hmacWithSHA1'() ->
{1,2,840,113549,2,7}.
encryptionAlgorithm() ->
{1,2,840,113549,3}.
digestAlgorithm() ->
{1,2,840,113549,2}.
'id-PBMAC1'() ->
{1,2,840,113549,1,5,14}.
'id-PBES2'() ->
{1,2,840,113549,1,5,13}.
'pbeWithSHA1AndRC2-CBC'() ->
{1,2,840,113549,1,5,11}.
'pbeWithSHA1AndDES-CBC'() ->
{1,2,840,113549,1,5,10}.
'pbeWithMD5AndRC2-CBC'() ->
{1,2,840,113549,1,5,6}.
'pbeWithMD5AndDES-CBC'() ->
{1,2,840,113549,1,5,3}.
'pbeWithMD2AndRC2-CBC'() ->
{1,2,840,113549,1,5,4}.
'pbeWithMD2AndDES-CBC'() ->
{1,2,840,113549,1,5,1}.
'id-PBKDF2'() ->
{1,2,840,113549,1,5,12}.
'pkcs-5'() ->
{1,2,840,113549,1,5}.
pkcs() ->
{1,2,840,113549,1}.
rsadsi() ->
{1,2,840,113549}.
%%================================
%% SupportingAlgorithms
%%================================
getenc_SupportingAlgorithms({1,2,840,113549,2,7}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
encode_null(Val, [<<5>>])
end
end;
getenc_SupportingAlgorithms({1,2,840,113549,3,2}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_RC2-CBC-Parameter'(Val)
end
end;
getenc_SupportingAlgorithms({1,2,840,113549,3,7}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
encode_restricted_string(Val, [<<4>>])
end
end;
getenc_SupportingAlgorithms({1,2,840,113549,3,9}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_RC5-CBC-Parameters'(Val)
end
end;
getenc_SupportingAlgorithms({1,3,14,3,2,7}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
encode_restricted_string(Val, [<<4>>])
end
end;
getenc_SupportingAlgorithms(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_SupportingAlgorithms'({1,2,840,113549,2,7}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
decode_null(Bytes, [5])
end
end;
'getdec_SupportingAlgorithms'({1,2,840,113549,3,2}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_RC2-CBC-Parameter'(Bytes)
end
end;
'getdec_SupportingAlgorithms'({1,2,840,113549,3,7}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
begin
Val1 = decode_octet_string(Bytes, [4]),
C1 = byte_size(Val1),
if C1 =:= 8 ->
Val1;
true ->
exit({error,{asn1,bad_range}})
end
end
end
end;
'getdec_SupportingAlgorithms'({1,2,840,113549,3,9}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_RC5-CBC-Parameters'(Bytes)
end
end;
'getdec_SupportingAlgorithms'({1,3,14,3,2,7}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
begin
Val2 = decode_octet_string(Bytes, [4]),
C2 = byte_size(Val2),
if C2 =:= 8 ->
Val2;
true ->
exit({error,{asn1,bad_range}})
end
end
end
end;
getdec_SupportingAlgorithms(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBMAC1-MACs
%%================================
'getenc_PBMAC1-MACs'(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBMAC1-MACs'(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBMAC1-KDFs
%%================================
'getenc_PBMAC1-KDFs'({1,2,840,113549,1,5,12}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBKDF2-params'(Val)
end
end;
'getenc_PBMAC1-KDFs'(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBMAC1-KDFs'({1,2,840,113549,1,5,12}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBKDF2-params'(Bytes)
end
end;
'getdec_PBMAC1-KDFs'(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBMAC1Algorithms
%%================================
getenc_PBMAC1Algorithms({1,2,840,113549,1,5,14}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBMAC1-params'(Val)
end
end;
getenc_PBMAC1Algorithms(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBMAC1Algorithms'({1,2,840,113549,1,5,14}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBMAC1-params'(Bytes)
end
end;
getdec_PBMAC1Algorithms(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBES2-Encs
%%================================
'getenc_PBES2-Encs'(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBES2-Encs'(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBES2-KDFs
%%================================
'getenc_PBES2-KDFs'({1,2,840,113549,1,5,12}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBKDF2-params'(Val)
end
end;
'getenc_PBES2-KDFs'(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBES2-KDFs'({1,2,840,113549,1,5,12}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBKDF2-params'(Bytes)
end
end;
'getdec_PBES2-KDFs'(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBES2Algorithms
%%================================
getenc_PBES2Algorithms({1,2,840,113549,1,5,13}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBES2-params'(Val)
end
end;
getenc_PBES2Algorithms(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBES2Algorithms'({1,2,840,113549,1,5,13}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBES2-params'(Bytes)
end
end;
getdec_PBES2Algorithms(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBES1Algorithms
%%================================
getenc_PBES1Algorithms({1,2,840,113549,1,5,1}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBEParameter'(Val)
end
end;
getenc_PBES1Algorithms({1,2,840,113549,1,5,3}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBEParameter'(Val)
end
end;
getenc_PBES1Algorithms({1,2,840,113549,1,5,4}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBEParameter'(Val)
end
end;
getenc_PBES1Algorithms({1,2,840,113549,1,5,6}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBEParameter'(Val)
end
end;
getenc_PBES1Algorithms({1,2,840,113549,1,5,10}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBEParameter'(Val)
end
end;
getenc_PBES1Algorithms({1,2,840,113549,1,5,11}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBEParameter'(Val)
end
end;
getenc_PBES1Algorithms(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBES1Algorithms'({1,2,840,113549,1,5,1}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBEParameter'(Bytes)
end
end;
'getdec_PBES1Algorithms'({1,2,840,113549,1,5,3}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBEParameter'(Bytes)
end
end;
'getdec_PBES1Algorithms'({1,2,840,113549,1,5,4}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBEParameter'(Bytes)
end
end;
'getdec_PBES1Algorithms'({1,2,840,113549,1,5,6}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBEParameter'(Bytes)
end
end;
'getdec_PBES1Algorithms'({1,2,840,113549,1,5,10}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBEParameter'(Bytes)
end
end;
'getdec_PBES1Algorithms'({1,2,840,113549,1,5,11}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBEParameter'(Bytes)
end
end;
getdec_PBES1Algorithms(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBKDF2-PRFs
%%================================
'getenc_PBKDF2-PRFs'({1,2,840,113549,2,7}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
encode_null(Val, [<<5>>])
end
end;
'getenc_PBKDF2-PRFs'(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBKDF2-PRFs'({1,2,840,113549,2,7}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
decode_null(Bytes, [5])
end
end;
'getdec_PBKDF2-PRFs'(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PBKDF2-SaltSources
%%================================
'getenc_PBKDF2-SaltSources'(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_PBKDF2-SaltSources'(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% SupportedContexts
%%================================
getenc_SupportedContexts(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_SupportedContexts(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% KeyEncryptionAlgorithms
%%================================
getenc_KeyEncryptionAlgorithms(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_KeyEncryptionAlgorithms(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% PrivateKeyAlgorithms
%%================================
getenc_PrivateKeyAlgorithms(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_PrivateKeyAlgorithms(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_9
%%================================
getenc_internal_object_set_argument_9(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_9(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_8
%%================================
getenc_internal_object_set_argument_8(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_8(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_7
%%================================
getenc_internal_object_set_argument_7(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_7(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_6
%%================================
getenc_internal_object_set_argument_6({1,2,840,113549,2,7}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
encode_null(Val, [<<5>>])
end
end;
getenc_internal_object_set_argument_6(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_internal_object_set_argument_6'({1,2,840,113549,2,7}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
decode_null(Bytes, [5])
end
end;
getdec_internal_object_set_argument_6(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_5
%%================================
getenc_internal_object_set_argument_5(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_5(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_4
%%================================
getenc_internal_object_set_argument_4(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_4(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_3
%%================================
getenc_internal_object_set_argument_3({1,2,840,113549,1,5,12}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBKDF2-params'(Val)
end
end;
getenc_internal_object_set_argument_3(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_internal_object_set_argument_3'({1,2,840,113549,1,5,12}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBKDF2-params'(Bytes)
end
end;
getdec_internal_object_set_argument_3(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_2
%%================================
getenc_internal_object_set_argument_2(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_2(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_1
%%================================
getenc_internal_object_set_argument_1({1,2,840,113549,1,5,12}) ->
fun(Type, Val, _RestPrimFieldName) ->
case Type of
'Type' ->
'enc_PBKDF2-params'(Val)
end
end;
getenc_internal_object_set_argument_1(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
'getdec_internal_object_set_argument_1'({1,2,840,113549,1,5,12}) ->
fun(Type, Bytes, _RestPrimFieldName) ->
case Type of
'Type' ->
'dec_PBKDF2-params'(Bytes)
end
end;
getdec_internal_object_set_argument_1(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%================================
%% internal_object_set_argument_10
%%================================
getenc_internal_object_set_argument_10(_) ->
fun(_, Val, _RestPrimFieldName) ->
case Val of
{asn1_OPENTYPE,Bin} when is_binary(Bin) ->
{Bin,byte_size(Bin)}
end
end.
getdec_internal_object_set_argument_10(_) ->
fun(_,Bytes, _RestPrimFieldName) ->
case Bytes of
Bin when is_binary(Bin) ->
{asn1_OPENTYPE,Bin};
_ ->
{asn1_OPENTYPE,ber_encode(Bytes)}
end
end.
%%%
%%% Run-time functions.
%%%
'dialyzer-suppressions'(Arg) ->
ok.
is_default_1(asn1_DEFAULT) ->
true;
is_default_1(Value) ->
try is_default_cs_3(Value) of
_ -> true
catch throw:false -> false
end.
is_default_2(asn1_DEFAULT) ->
true;
is_default_2(Def) when Def =:= false ->
true;
is_default_2(_) ->
false.
is_default_cs_3(Value) ->
case Value of
{'PBKDF2-params_prf',
E1,
'NULL'} ->
check_objectidentifier(E1, {[[1,iso],[2,'member-body']],[840,113549,2,7]});
_ ->
throw(false)
end.
ber_decode_nif(B) ->
asn1rt_nif:decode_ber_tlv(B).
ber_encode([Tlv]) ->
ber_encode(Tlv);
ber_encode(Tlv) when is_binary(Tlv) ->
Tlv;
ber_encode(Tlv) ->
asn1rt_nif:encode_ber_tlv(Tlv).
check_objectidentifier(Value, {Prefix, Tail}) when is_tuple(Value) ->
check_oid(tuple_to_list(Value), Prefix, Tail);
check_objectidentifier(_, _) ->
throw(false).
check_oid([H | T], [K | Ks], Tail) ->
case lists:member(H, K) of
false ->
throw(false);
true ->
check_oid(T, Ks, Tail)
end;
check_oid(Tail, [], Tail) ->
true;
check_oid(_, _, _) ->
throw(false).
collect_parts(TlvList) ->
collect_parts(TlvList, []).
collect_parts([{_, L} | Rest], Acc) when is_list(L) ->
collect_parts(Rest, [collect_parts(L) | Acc]);
collect_parts([{3, <<Unused,Bits/binary>>} | Rest], _Acc) ->
collect_parts_bit(Rest, [Bits], Unused);
collect_parts([{_T, V} | Rest], Acc) ->
collect_parts(Rest, [V | Acc]);
collect_parts([], Acc) ->
list_to_binary(lists:reverse(Acc)).
collect_parts_bit([{3, <<Unused,Bits/binary>>} | Rest], Acc, Uacc) ->
collect_parts_bit(Rest, [Bits | Acc], Unused + Uacc);
collect_parts_bit([], Acc, Uacc) ->
list_to_binary([Uacc | lists:reverse(Acc)]).
dec_subidentifiers(<<>>, _Av, Al) ->
lists:reverse(Al);
dec_subidentifiers(<<1:1,H:7,T/binary>>, Av, Al) ->
dec_subidentifiers(T, Av bsl 7 + H, Al);
dec_subidentifiers(<<H,T/binary>>, Av, Al) ->
dec_subidentifiers(T, 0, [Av bsl 7 + H | Al]).
decode_boolean(Tlv, TagIn) ->
Val = match_tags(Tlv, TagIn),
case Val of
<<0:8>> ->
false;
<<_:8>> ->
true;
_ ->
exit({error, {asn1, {decode_boolean, Val}}})
end.
decode_integer(Tlv, TagIn) ->
Bin = match_tags(Tlv, TagIn),
Len = byte_size(Bin),
<<Int:Len/signed-unit:8>> = Bin,
Int.
decode_native_bit_string(Buffer, Tags) ->
case match_and_collect(Buffer, Tags) of
<<0>> ->
<<>>;
<<Unused,Bits/binary>> ->
Size = bit_size(Bits) - Unused,
<<Val:Size/bitstring,_:Unused/bitstring>> = Bits,
Val
end.
decode_null(Tlv, Tags) ->
Val = match_tags(Tlv, Tags),
case Val of
<<>> ->
'NULL';
_ ->
exit({error, {asn1, {decode_null, Val}}})
end.
decode_object_identifier(Tlv, Tags) ->
Val = match_tags(Tlv, Tags),
[AddedObjVal | ObjVals] = dec_subidentifiers(Val, 0, []),
{Val1, Val2} =
if
AddedObjVal < 40 ->
{0, AddedObjVal};
AddedObjVal < 80 ->
{1, AddedObjVal - 40};
true ->
{2, AddedObjVal - 80}
end,
list_to_tuple([Val1, Val2 | ObjVals]).
decode_octet_string(Tlv, TagsIn) ->
Bin = match_and_collect(Tlv, TagsIn),
binary:copy(Bin).
decode_open_type(Tlv, TagIn) ->
case match_tags(Tlv, TagIn) of
Bin when is_binary(Bin) ->
{InnerTlv, _} = ber_decode_nif(Bin),
InnerTlv;
TlvBytes ->
TlvBytes
end.
dynamicsort_SETOF(ListOfEncVal) ->
BinL =
lists:map(fun(L) when is_list(L) ->
list_to_binary(L);
(B) ->
B
end,
ListOfEncVal),
lists:sort(BinL).
e_object_identifier({'OBJECT IDENTIFIER', V}) ->
e_object_identifier(V);
e_object_identifier(V) when is_tuple(V) ->
e_object_identifier(tuple_to_list(V));
e_object_identifier([E1, E2 | Tail]) ->
Head = 40 * E1 + E2,
{H, Lh} = mk_object_val(Head),
{R, Lr} = lists:mapfoldl(fun enc_obj_id_tail/2, 0, Tail),
{[H | R], Lh + Lr}.
enc_obj_id_tail(H, Len) ->
{B, L} = mk_object_val(H),
{B, Len + L}.
encode_boolean(true, TagIn) ->
encode_tags(TagIn, [255], 1);
encode_boolean(false, TagIn) ->
encode_tags(TagIn, [0], 1);
encode_boolean(X, _) ->
exit({error, {asn1, {encode_boolean, X}}}).
encode_integer(Val) ->
Bytes =
if
Val >= 0 ->
encode_integer_pos(Val, []);
true ->
encode_integer_neg(Val, [])
end,
{Bytes, length(Bytes)}.
encode_integer(Val, NamedNumberList, Tag) when is_atom(Val) ->
case lists:keyfind(Val, 1, NamedNumberList) of
{_, NewVal} ->
encode_tags(Tag, encode_integer(NewVal));
_ ->
exit({error, {asn1, {encode_integer_namednumber, Val}}})
end;
encode_integer(Val, _NamedNumberList, Tag) ->
encode_tags(Tag, encode_integer(Val)).
encode_integer(Val, Tag) when is_integer(Val) ->
encode_tags(Tag, encode_integer(Val));
encode_integer(Val, _Tag) ->
exit({error, {asn1, {encode_integer, Val}}}).
encode_integer_neg(-1, [B1 | _T] = L) when B1 > 127 ->
L;
encode_integer_neg(N, Acc) ->
encode_integer_neg(N bsr 8, [N band 255 | Acc]).
encode_integer_pos(0, [B | _Acc] = L) when B < 128 ->
L;
encode_integer_pos(N, Acc) ->
encode_integer_pos(N bsr 8, [N band 255 | Acc]).
encode_length(L) when L =< 127 ->
{[L], 1};
encode_length(L) ->
Oct = minimum_octets(L),
Len = length(Oct),
if
Len =< 126 ->
{[128 bor Len | Oct], Len + 1};
true ->
exit({error, {asn1, too_long_length_oct, Len}})
end.
encode_null(_Val, TagIn) ->
encode_tags(TagIn, [], 0).
encode_object_identifier(Val, TagIn) ->
encode_tags(TagIn, e_object_identifier(Val)).
encode_open_type(Val, T) when is_list(Val) ->
encode_open_type(list_to_binary(Val), T);
encode_open_type(Val, Tag) ->
encode_tags(Tag, Val, byte_size(Val)).
encode_restricted_string(OctetList, TagIn) when is_binary(OctetList) ->
encode_tags(TagIn, OctetList, byte_size(OctetList));
encode_restricted_string(OctetList, TagIn) when is_list(OctetList) ->
encode_tags(TagIn, OctetList, length(OctetList)).
encode_tags(TagIn, {BytesSoFar, LenSoFar}) ->
encode_tags(TagIn, BytesSoFar, LenSoFar).
encode_tags([Tag | Trest], BytesSoFar, LenSoFar) ->
{Bytes2, L2} = encode_length(LenSoFar),
encode_tags(Trest,
[Tag, Bytes2 | BytesSoFar],
LenSoFar + byte_size(Tag) + L2);
encode_tags([], BytesSoFar, LenSoFar) ->
{BytesSoFar, LenSoFar}.
encode_unnamed_bit_string(Bits, TagIn) ->
Unused = (8 - bit_size(Bits) band 7) band 7,
Bin = <<Unused,Bits/bitstring,0:Unused>>,
encode_tags(TagIn, Bin, byte_size(Bin)).
match_and_collect(Tlv, TagsIn) ->
Val = match_tags(Tlv, TagsIn),
case Val of
[_ | _] = PartList ->
collect_parts(PartList);
Bin when is_binary(Bin) ->
Bin
end.
match_tags({T, V}, [T]) ->
V;
match_tags({T, V}, [T | Tt]) ->
match_tags(V, Tt);
match_tags([{T, V}], [T | Tt]) ->
match_tags(V, Tt);
match_tags([{T, _V} | _] = Vlist, [T]) ->
Vlist;
match_tags(Tlv, []) ->
Tlv;
match_tags({Tag, _V} = Tlv, [T | _Tt]) ->
exit({error, {asn1, {wrong_tag, {{expected, T}, {got, Tag, Tlv}}}}}).
minimum_octets(0, Acc) ->
Acc;
minimum_octets(Val, Acc) ->
minimum_octets(Val bsr 8, [Val band 255 | Acc]).
minimum_octets(Val) ->
minimum_octets(Val, []).
mk_object_val(0, Ack, Len) ->
{Ack, Len};
mk_object_val(Val, Ack, Len) ->
mk_object_val(Val bsr 7, [Val band 127 bor 128 | Ack], Len + 1).
mk_object_val(Val) when Val =< 127 ->
{[255 band Val], 1};
mk_object_val(Val) ->
mk_object_val(Val bsr 7, [Val band 127], 1).
number2name(Int, NamedNumberList) ->
case lists:keyfind(Int, 2, NamedNumberList) of
{NamedVal, _} ->
NamedVal;
_ ->
Int
end.
skip_ExtensionAdditions([], _Tags) ->
[];
skip_ExtensionAdditions([{Tag, _} | Rest] = TLV, Tags) ->
case
[
X ||
X = T <- Tags,
T =:= Tag
]
of
[] ->
skip_ExtensionAdditions(Rest, Tags);
_ ->
TLV
end.