private static void TestSoftwareOnly() { var key = new SimulatedU2FKey( TestVectors.VENDOR_CERTIFICATE, TestVectors.VENDOR_CERTIFICATE_PRIVATE_KEY, new TestKeyPairGenerator(), new GuidKeyHandleGenerator(), new InMemoryKeyDataStore(), new ConsolePresenceVerifier(), new BouncyCastleKeyCrypto()); var server = new U2FServerReferenceImpl( new ChallengeGenerator(), new InMemoryServerDataStore(new GuidSessionIdGenerator()), new BouncyCastleServerCrypto(), new [] { "http://example.com", "https://example.com" }); var client = new U2FClientReferenceImpl( BouncyCastleClientCrypto.Instance, new SimpleOriginVerifier(new[] { "http://example.com", "https://example.com" }), new ChannelProvider(), server, key, SystemClock.Instance); client.Register("http://example.com", "vbfox"); client.Authenticate("http://example.com", "vbfox"); Console.WriteLine("Done."); Console.ReadLine(); }
public virtual void TestAuthenticate() { var signRequest = new SignRequest(U2FConsts.U2Fv2, SERVER_CHALLENGE_SIGN_BASE64, APP_ID_SIGN, KEY_HANDLE_BASE64, SESSION_ID); mockU2FServer.Setup(x => x.GetSignRequests(ACCOUNT_NAME, ORIGIN)) .Returns(new[] { signRequest }); mockOriginVerifier.Setup(x => x.ValidateOrigin(APP_ID_SIGN, ORIGIN)); mockU2FKey.Setup(x => x.Authenticate(new KeySignRequest(U2FVersion.V2, BROWSER_DATA_SIGN_SHA256, APP_ID_SIGN_SHA256, KEY_HANDLE))) .Returns(new KeySignResponse(UserPresenceVerifierConstants.UserPresentFlag, COUNTER_VALUE, SIGNATURE_AUTHENTICATE)); mockU2FServer.Setup(x => x.ProcessSignResponse(new SignResponse (BROWSER_DATA_SIGN_BASE64, SIGN_RESPONSE_DATA_BASE64, SERVER_CHALLENGE_SIGN_BASE64 , SESSION_ID, APP_ID_SIGN))).Returns(new SecurityKeyData (0L, KEY_HANDLE, USER_PUBLIC_KEY_ENROLL_HEX, VENDOR_CERTIFICATE, 0)); u2FClient.Authenticate(ORIGIN, ACCOUNT_NAME); }
private static async Task TestDual() { var hidFactory = Win32HidDeviceFactory.Instance; var keyFactory = new U2FHidKeyFactory(hidFactory); var keyIds = await keyFactory.FindAllAsync(); var keyId = keyIds.First(); using (var u2f = await keyId.OpenAsync()) { var key = new U2FDeviceKey(u2f); var dataStore = new InMemoryServerDataStore(new GuidSessionIdGenerator()); var server = new U2FServerReferenceImpl( new ChallengeGenerator(), dataStore, new BouncyCastleServerCrypto(), new[] { "http://example.com", "https://example.com" }); var client = new U2FClientReferenceImpl( BouncyCastleClientCrypto.Instance, new SimpleOriginVerifier(new[] { "http://example.com", "https://example.com" }), new ChannelProvider(), server, key, SystemClock.Instance); LoadDataStore(dataStore); //client.Register("http://example.com", "vbfox"); //SaveDataStore(dataStore); client.Authenticate("http://example.com", "vbfox"); SaveDataStore(dataStore); } Console.WriteLine("Done."); Console.ReadLine(); }
private static async Task TestNew() { var hidFactory = Win32HidDeviceFactory.Instance; var keyFactory = new U2FHidKeyFactory(hidFactory); var keyIds = await keyFactory.FindAllAsync(); var keyId = keyIds.First(); var dataStore = new InMemoryServerDataStore(new GuidSessionIdGenerator()); LoadDataStore(dataStore); var server = new U2FServerReferenceImpl( new ChallengeGenerator(), dataStore, new BouncyCastleServerCrypto(), new[] { "http://example.com", "https://example.com" }); var myClient = new U2FClient( new DummySender("http://example.com", new JObject()), (o, a, ct) => Task.FromResult(true), (o, a, ct) => Task.FromResult(true), keyFactory, BouncyCastleClientCrypto.Instance); var signRequests = server.GetSignRequests("vbfox", "http://example.com"); var x = await myClient.Sign(signRequests, CancellationToken.None); return; var origin = "http://example.com"; var channelId = new JObject(); var requestAndClientDatas = signRequests .Select(signRequest => { string clientDataB64; var authRequest = U2FClientReferenceImpl.SignRequestToAuthenticateRequest("http://example.com", signRequest, new JObject(), out clientDataB64, BouncyCastleClientCrypto.Instance); return(Tuple.Create(signRequest, clientDataB64, authRequest)); }) .ToList(); new U2FClient( new DummySender("http://example.com", new JObject()), (o, a, ct) => Task.FromResult(true), (o, a, ct) => Task.FromResult(true), keyFactory, BouncyCastleClientCrypto.Instance); using (var u2f = await keyId.OpenAsync()) { var key = new U2FDeviceKey(u2f); var client = new U2FClientReferenceImpl( BouncyCastleClientCrypto.Instance, new SimpleOriginVerifier(new[] { "http://example.com", "https://example.com" }), new ChannelProvider(), server, key, SystemClock.Instance); //client.Register("http://example.com", "vbfox"); //SaveDataStore(dataStore); client.Authenticate("http://example.com", "vbfox"); SaveDataStore(dataStore); } Console.WriteLine("Done."); Console.ReadLine(); }