Esempio n. 1
0
        public async Task TestVerifyRfc8463ExampleAsync()
        {
            var message  = MimeMessage.Load(Path.Combine(TestHelper.ProjectDir, "TestData", "dkim", "rfc8463-example.msg"));
            var locator  = new DkimPublicKeyLocator();
            var verifier = new DkimVerifier(locator);
            int index;

            locator.Add("brisbane._domainkey.football.example.com", "v=DKIM1; k=ed25519; p=11qYAYKxCrfVS/7TyWQHOg7hcvPapiMlrwIaaPcHURo=");
            locator.Add("test._domainkey.football.example.com", "v=DKIM1; k=rsa; p=MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDkHlOQoBTzWRiGs5V6NpP3idY6Wk08a5qhdR6wy5bdOKb2jLQiY/J16JYi0Qvx/byYzCNb3W91y3FutACDfzwQ/BC/e/8uBsCR+yz1Lxj+PL6lHvqMKrM3rG4hstT5QjvHO9PzoxZyVYLzBfO2EeC3Ip3G+2kryOTIKT+l/K4w3QIDAQAB");

            // the last DKIM-Signature uses rsa-sha256
            index = message.Headers.LastIndexOf(HeaderId.DkimSignature);
            Assert.IsTrue(await verifier.VerifyAsync(message, message.Headers[index]), "Failed to verify rsa-sha256");

            // the first DKIM-Signature uses ed25519-sha256
            index = message.Headers.IndexOf(HeaderId.DkimSignature);
            Assert.IsTrue(await verifier.VerifyAsync(message, message.Headers[index]), "Failed to verify ed25519-sha256");
        }
Esempio n. 2
0
        public async Task TestVerifyGoogleMultipartWithoutEndBoundaryDkimSignatureAsync()
        {
            var message  = MimeMessage.Load(Path.Combine(TestHelper.ProjectDir, "TestData", "dkim", "multipart-no-end-boundary.msg"));
            int index    = message.Headers.IndexOf(HeaderId.DkimSignature);
            var locator  = new DummyPublicKeyLocator(GMailDkimPublicKey);
            var verifier = new DkimVerifier(locator);

            Assert.IsTrue(await verifier.VerifyAsync(message, message.Headers[index]), "Failed to verify GMail signature.");
        }
Esempio n. 3
0
        public async Task TestVerifyGoogleMultipartRelatedDkimSignatureAsync()
        {
            var message  = MimeMessage.Load(Path.Combine("..", "..", "TestData", "dkim", "related.msg"));
            int index    = message.Headers.IndexOf(HeaderId.DkimSignature);
            var locator  = new DummyPublicKeyLocator(GMailDkimPublicKey);
            var verifier = new DkimVerifier(locator);

            Assert.IsTrue(await verifier.VerifyAsync(message, message.Headers[index]), "Failed to verify GMail signature.");
        }
Esempio n. 4
0
        public void TestArgumentExceptions()
        {
            var        locator    = new DummyPublicKeyLocator(DkimKeys.Public);
            var        verifier   = new DkimVerifier(locator);
            var        dkimHeader = new Header(HeaderId.DkimSignature, "value");
            var        arcHeader  = new Header(HeaderId.ArcMessageSignature, "value");
            var        options    = FormatOptions.Default;
            var        message    = new MimeMessage();
            DkimSigner signer;

            Assert.Throws <ArgumentNullException> (() => new DkimSigner((AsymmetricKeyParameter)null, "domain", "selector"));
            Assert.Throws <ArgumentException> (() => new DkimSigner(DkimKeys.Public, "domain", "selector"));
            Assert.Throws <ArgumentNullException> (() => new DkimSigner(DkimKeys.Private, null, "selector"));
            Assert.Throws <ArgumentNullException> (() => new DkimSigner(DkimKeys.Private, "domain", null));
            Assert.Throws <ArgumentNullException> (() => new DkimSigner((string)null, "domain", "selector"));
            Assert.Throws <ArgumentNullException> (() => new DkimSigner("fileName", null, "selector"));
            Assert.Throws <ArgumentNullException> (() => new DkimSigner("fileName", "domain", null));
            Assert.Throws <ArgumentException> (() => new DkimSigner(string.Empty, "domain", "selector"));
            Assert.Throws <ArgumentNullException> (() => new DkimSigner((Stream)null, "domain", "selector"));
            using (var stream = File.OpenRead(Path.Combine(TestHelper.ProjectDir, "TestData", "dkim", "example.pem"))) {
                Assert.Throws <ArgumentNullException> (() => new DkimSigner(stream, null, "selector"));
                Assert.Throws <ArgumentNullException> (() => new DkimSigner(stream, "domain", null));

                signer = new DkimSigner(stream, "example.com", "1433868189.example")
                {
                    SignatureAlgorithm    = DkimSignatureAlgorithm.RsaSha1,
                    AgentOrUserIdentifier = "@eng.example.com",
                    QueryMethod           = "dns/txt",
                };
            }

            Assert.Throws <ArgumentNullException> (() => signer.Sign(null, new HeaderId[] { HeaderId.From }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(message, (IList <HeaderId>)null));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new HeaderId[] { HeaderId.Unknown, HeaderId.From }));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new HeaderId[] { HeaderId.Received, HeaderId.From }));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new HeaderId[] { HeaderId.ContentType }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(null, new string[] { "From" }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(message, (IList <string>)null));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new string[] { "", "From" }));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new string[] { null, "From" }));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new string[] { "Received", "From" }));
            Assert.Throws <ArgumentException> (() => signer.Sign(message, new string[] { "Content-Type" }));

            Assert.Throws <ArgumentNullException> (() => signer.Sign(null, message, new HeaderId[] { HeaderId.From }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(options, null, new HeaderId[] { HeaderId.From }));
            Assert.Throws <ArgumentException> (() => signer.Sign(options, message, new HeaderId[] { HeaderId.From, HeaderId.Unknown }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(options, message, (IList <HeaderId>)null));

            Assert.Throws <ArgumentNullException> (() => signer.Sign(null, message, new string[] { "From" }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(options, null, new string[] { "From" }));
            Assert.Throws <ArgumentException> (() => signer.Sign(options, message, new string[] { "From", null }));
            Assert.Throws <ArgumentNullException> (() => signer.Sign(options, message, (IList <string>)null));

            Assert.Throws <ArgumentNullException> (() => new DkimVerifier(null));

            Assert.Throws <ArgumentNullException> (() => verifier.Verify(null, dkimHeader));
            Assert.Throws <ArgumentNullException> (() => verifier.Verify(message, null));
            Assert.Throws <ArgumentNullException> (() => verifier.Verify(null, message, dkimHeader));
            Assert.Throws <ArgumentNullException> (() => verifier.Verify(FormatOptions.Default, null, dkimHeader));
            Assert.Throws <ArgumentNullException> (() => verifier.Verify(FormatOptions.Default, message, null));
            Assert.Throws <ArgumentException> (() => verifier.Verify(FormatOptions.Default, message, arcHeader));

            Assert.ThrowsAsync <ArgumentNullException> (async() => await verifier.VerifyAsync(null, dkimHeader));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await verifier.VerifyAsync(message, null));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await verifier.VerifyAsync(null, message, dkimHeader));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await verifier.VerifyAsync(FormatOptions.Default, null, dkimHeader));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await verifier.VerifyAsync(FormatOptions.Default, message, null));
            Assert.ThrowsAsync <ArgumentException> (async() => await verifier.VerifyAsync(FormatOptions.Default, message, arcHeader));

            Assert.Throws <ArgumentNullException> (() => message.Sign(null, new HeaderId[] { HeaderId.From }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(signer, (IList <HeaderId>)null));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new HeaderId[] { HeaderId.Unknown, HeaderId.From }));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new HeaderId[] { HeaderId.Received, HeaderId.From }));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new HeaderId[] { HeaderId.ContentType }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(null, new string[] { "From" }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(signer, (IList <string>)null));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new string[] { "", "From" }));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new string[] { null, "From" }));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new string[] { "Received", "From" }));
            Assert.Throws <ArgumentException> (() => message.Sign(signer, new string[] { "Content-Type" }));

            Assert.Throws <ArgumentNullException> (() => message.Sign(null, signer, new HeaderId[] { HeaderId.From }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(options, null, new HeaderId[] { HeaderId.From }));
            Assert.Throws <ArgumentException> (() => message.Sign(options, signer, new HeaderId[] { HeaderId.From, HeaderId.Unknown }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(options, signer, (IList <HeaderId>)null));

            Assert.Throws <ArgumentNullException> (() => message.Sign(null, signer, new string[] { "From" }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(options, null, new string[] { "From" }));
            Assert.Throws <ArgumentException> (() => message.Sign(options, signer, new string[] { "From", null }));
            Assert.Throws <ArgumentNullException> (() => message.Sign(options, signer, (IList <string>)null));

            Assert.Throws <ArgumentNullException> (() => message.Verify(null, locator));
            Assert.Throws <ArgumentNullException> (() => message.Verify(dkimHeader, null));
            Assert.Throws <ArgumentNullException> (() => message.Verify(null, dkimHeader, locator));
            Assert.Throws <ArgumentNullException> (() => message.Verify(FormatOptions.Default, null, locator));
            Assert.Throws <ArgumentNullException> (() => message.Verify(FormatOptions.Default, dkimHeader, null));
            Assert.Throws <ArgumentException> (() => message.Verify(FormatOptions.Default, arcHeader, locator));

            Assert.ThrowsAsync <ArgumentNullException> (async() => await message.VerifyAsync(null, locator));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await message.VerifyAsync(dkimHeader, null));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await message.VerifyAsync(null, dkimHeader, locator));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await message.VerifyAsync(FormatOptions.Default, null, locator));
            Assert.ThrowsAsync <ArgumentNullException> (async() => await message.VerifyAsync(FormatOptions.Default, dkimHeader, null));
            Assert.ThrowsAsync <ArgumentException> (async() => await message.VerifyAsync(FormatOptions.Default, arcHeader, locator));
        }