Skip to content
Snippets Groups Projects
Select Git revision
  • v2
  • Coscine/FederationAdaption default
  • gitkeep
  • dev protected
  • Sprint/2022-01
  • fixmerge
  • master
  • develop protected
  • dependabot/nuget/Samples/SampleMvcApplication/bootstrap-3.4.1
  • dependabot/nuget/Samples/SampleOwinApplication/bootstrap-3.4.1
  • v1
  • netcore-cookiemanager
  • limitingcookiemanager
  • owin-cookiemanager
  • owin-cookiemanger-changeinterface
  • excess-cookies
  • missing_nodes_exceptions
  • empty_ref_exception
  • fix_shared_options
  • csphashsupport
  • v2.7.0
  • v1.0.2
  • v2.6.0
  • v2.5.0
  • v1.0.1
  • v2.4.0
  • v2.3.0
  • v2.2.0
  • v2.1.0
  • v2.0.0
  • v1.0.0
  • v0.24.0
  • v0.23.0
  • v2.0.0-preview01
  • v0.22.0
  • v0.21.2
  • v0.21.1
  • v0.21.0
  • v0.20.0
  • v0.19.0
40 results

RelayStateGenerator.cs

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    RelayStateGenerator.cs 1.40 KiB
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Security.Cryptography;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace Sustainsys.Saml2
    {
        /// <summary>
        /// Generator of secure random keys..
        /// </summary>
        static class SecureKeyGenerator
        {
            private static RNGCryptoServiceProvider random =
                new RNGCryptoServiceProvider();
    
            /// <summary>
            /// Create a unique random string with a cryptographically secure
            /// random function.
            /// </summary>
            /// <returns>Random string 56-chars string</returns>
            public static string CreateRelayState()
            {
                // 16 is considered secure, but Base64 pads 16 bytes so
                // use 18 to make it even with Base64 that encodes multiples 
                // of 3 bytes)
                var bytes = new byte[18];
                random.GetBytes(bytes);
    
                return Convert.ToBase64String(bytes)
                    .Replace('/', '-')
                    .Replace('+', '_');
            }
    
            /// <summary>
            /// Create a unique random array with a cryptographically secure
            /// random function.
            /// </summary>
            /// <returns>20 random bytes.</returns>
            public static byte[] CreateArtifactMessageHandle()
            {
                var bytes = new byte[20];
                random.GetBytes(bytes);
    
                return bytes;
            }
        }
    }