public static void OctetString(byte[] value, byte[] expected) { var reader = new Asn1Reader(value); Assert.Equal(expected, reader.OctetString().ToArray()); Assert.True(reader.SuccessComplete); }
[InlineData(new byte[] { 0x04, 0x82, 0x00, 0x08, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef })] // The length shall be encoded in the minimum number of octets public static void OctetStringInvalid(byte[] value) { var reader = new Asn1Reader(value); Assert.Equal(Array.Empty <byte>(), reader.OctetString().ToArray()); Assert.False(reader.Success); Assert.False(reader.SuccessComplete); }
public static void LengthInvalid(byte[] value) { var reader = new Asn1Reader(value); Assert.Equal(new byte[0], reader.OctetString().ToArray()); Assert.False(reader.Success); Assert.False(reader.SuccessComplete); }
[InlineData(new byte[] { 0x04, 0x82, 0x00, 0x08, 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef })] // The length shall be encoded in the minimum number of octets public static void OctetStringInvalid(byte[] value) { var span = new ReadOnlySpan <byte>(value); var reader = new Asn1Reader(ref span); Assert.Equal(new byte[0], reader.OctetString().ToArray()); Assert.False(reader.Success); Assert.False(reader.SuccessComplete); }
public static void InnerLengthGreaterThanOuterLength() { var span = new ReadOnlySpan <byte>(new byte[] { 0x30, 0x08, 0x04, 0x0A, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xAA }); var reader = new Asn1Reader(ref span); reader.BeginSequence(); Assert.True(reader.Success); Assert.Equal(new byte[0], reader.OctetString().ToArray()); Assert.False(reader.Success); reader.End(); Assert.False(reader.Success); Assert.False(reader.SuccessComplete); }
public static void InnerLengthGreaterThanOuterLength() { var value = new byte[] { 0x30, 0x08, 0x04, 0x0A, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xAA }; var reader = new Asn1Reader(value); reader.BeginSequence(); Assert.True(reader.Success); Assert.Equal(Array.Empty <byte>(), reader.OctetString().ToArray()); Assert.False(reader.Success); reader.End(); Assert.False(reader.Success); Assert.False(reader.SuccessComplete); }
internal override bool TryReadAlgorithmIdentifier( ref Asn1Reader reader, out ReadOnlySpan <byte> nonce) { bool success = true; reader.BeginSequence(); success &= reader.ObjectIdentifier().SequenceEqual(s_oid.Bytes); nonce = reader.OctetString(); success &= (nonce.Length == crypto_aead_chacha20poly1305_ietf_NPUBBYTES); reader.End(); success &= reader.Success; return(success); }
public static void PkixPrivateKey() { var a = new X25519(); var b = Utilities.RandomBytes.Slice(0, a.PrivateKeySize); using (var k = Key.Import(a, b, KeyBlobFormat.RawPrivateKey, KeyExportPolicies.AllowPlaintextExport)) { var blob = k.Export(KeyBlobFormat.PkixPrivateKey); var reader = new Asn1Reader(blob); reader.BeginSequence(); Assert.Equal(0, reader.Integer32()); reader.BeginSequence(); Assert.Equal(s_oid, reader.ObjectIdentifier().ToArray()); reader.End(); var curvePrivateKey = new Asn1Reader(reader.OctetString()); Assert.Equal(b.ToArray(), curvePrivateKey.OctetString().ToArray()); Assert.True(curvePrivateKey.SuccessComplete); reader.End(); Assert.True(reader.SuccessComplete); } }
public static void PkixPrivateKey() { var a = new X25519(); var b = Utilities.RandomBytes.Slice(0, a.PrivateKeySize); using (var k = Key.Import(a, b, KeyBlobFormat.RawPrivateKey, KeyFlags.AllowExport)) { var blob = new ReadOnlySpan <byte>(k.Export(KeyBlobFormat.PkixPrivateKey)); var reader = new Asn1Reader(ref blob); reader.BeginSequence(); Assert.Equal(0, reader.Integer32()); reader.BeginSequence(); Assert.Equal(s_oid, reader.ObjectIdentifier().ToArray()); reader.End(); var edPrivateKey = reader.OctetString(); reader.End(); Assert.True(reader.SuccessComplete); var reader2 = new Asn1Reader(ref edPrivateKey); Assert.Equal(b.ToArray(), reader2.OctetString().ToArray()); Assert.True(reader2.SuccessComplete); } }