public void Handle_GivenSuccessfulUseCaseResponse_SetsId() { // arrange var presenter = new FindUserPresenter(); // act presenter.Handle(new FindUserResponse(new User(), "1234", true)); // assert FindUserResponse data = JsonSerializer.DeSerializeObject <FindUserResponse>(presenter.ContentResult.Content); Assert.True(data.Success); Assert.Equal("1234", data.Id); }
public async Task CanFindByEmail() { AccountsClient client = new AccountsClient(GrpcChannel);//_serviceProvider.GetRequiredService<AccountsClient>(); Assert.NotNull(client); FindUserResponse response = await client.FindByEmailAsync(new StringInputParameter() { Value = "*****@*****.**" }); // UserManager is NOT case sensitive! Assert.NotNull(response); Assert.NotNull(response.Response); Assert.True(response.Response.Success); Assert.Empty(response.Response.Errors); Assert.False(string.IsNullOrEmpty(response.Id)); Assert.Equal("41532945-599e-4910-9599-0e7402017fbe", response.Id); }
public async Task CanFindById(string id) { AccountsClient client = new AccountsClient(GrpcChannel);//_serviceProvider.GetRequiredService<AccountsClient>(); Assert.NotNull(client); FindUserResponse response = await client.FindByIdAsync(new StringInputParameter() { Value = id }); Assert.NotNull(response); Assert.NotNull(response.Response); Assert.True(response.Response.Success); Assert.Empty(response.Response.Errors); Assert.False(string.IsNullOrEmpty(response.Id)); Assert.Equal(id, response.Id); }
public void start() { string username; string password; int choix = 0; Boolean logged = false; Console.WriteLine("Connection established"); while (true) { TcpClient comm = new TcpClient(hostname, port); do { do { Console.WriteLine("1- Login\n2-Register "); choix = int.Parse(Console.ReadLine()); } while (choix != 1 && choix != 2); switch (choix) { case 1: Console.WriteLine("\n\n-----------LOGIN---------"); Console.WriteLine("Username pls : "); username = Console.ReadLine(); Console.WriteLine("Password pls : "); password = Console.ReadLine(); Net.sendMsg(comm.GetStream(), new LoginRequest(username, password)); LoginResponse loginResponse = (LoginResponse)Net.rcvMsg(comm.GetStream()); logged = loginResponse.IsLogged; id = loginResponse.Id; if (!logged) { Console.WriteLine("Wrong credentials !!"); } else { Console.WriteLine("you've been logged"); status = Status.Logged; this.currentUser = loginResponse.User; } break; case 2: Console.WriteLine("\n\n-----------Register---------"); Console.WriteLine("Username pls : "); username = Console.ReadLine(); bool isSame = false; do { Console.WriteLine("Password pls : "); password = Console.ReadLine(); Console.WriteLine("Repeat Password pls : "); string repatPassword = Console.ReadLine(); if (password != repatPassword) { Console.WriteLine("Please enter the same password !!!"); } else { isSame = true; } } while (!isSame); Net.sendMsg(comm.GetStream(), new RegisterRequest(username, password)); RegisterResponse response = (RegisterResponse)Net.rcvMsg(comm.GetStream()); if (response.HasError) { Console.WriteLine(response.Error); } else { Console.WriteLine("you have been registered as " + response.Username); } break; } } while (status == Status.Disconnected); do { Console.WriteLine("1- List topics \n2- create topic\n3- join a topic\n4- send private message\n"); Console.Write("--> "); try { choix = int.Parse(Console.ReadLine()); } catch { choix = 0; } switch (choix) { case 1: Net.sendMsg(comm.GetStream(), new ListTopicRequest()); ListTopicResponse response = (ListTopicResponse)Net.rcvMsg(comm.GetStream()); response.display(); Console.WriteLine("\n"); break; case 2: Console.WriteLine("Please write down the topic title : "); Console.Write("--> "); string title = Console.ReadLine(); Console.WriteLine("Please write down a description for the topic : "); string content = Console.ReadLine(); Net.sendMsg(comm.GetStream(), new CreateRequest(id, title, content, DateTime.Now)); CreateResponse createResponse = (CreateResponse)Net.rcvMsg(comm.GetStream()); if (createResponse.HasError) { Console.WriteLine(createResponse.Error); } else { Console.WriteLine("Your topic have been created, you can check it out by listing the topics"); } break; case 3: Console.WriteLine("Please choose the number of the topic from the list : "); Console.Write("--> "); int topicNumber; try { topicNumber = int.Parse(Console.ReadLine()); } catch { topicNumber = 0; } Net.sendMsg(comm.GetStream(), new JoinTopicRequest(topicNumber)); JoinTopicResponse joinResponse = (JoinTopicResponse)Net.rcvMsg(comm.GetStream()); if (joinResponse.HasError) { Console.WriteLine(joinResponse.Error); } else { joinResponse.display(); bool continuer = true; do { Console.WriteLine("send a message ? (y/n)"); ConsoleKeyInfo input = Console.ReadKey(true); if (input.Key == ConsoleKey.N) { continuer = false; } else { Console.WriteLine("Please, write your message : "); Console.Write("--> "); string message = Console.ReadLine(); TopicMessage topicMsg = new TopicMessage(DateTime.Now, currentUser.Username, message, topicNumber); Net.sendMsg(comm.GetStream(), new SendTopicMsgRequest(topicMsg)); SendTopicMsgResponse msgResponse = (SendTopicMsgResponse)Net.rcvMsg(comm.GetStream()); if (!msgResponse.HasError) { joinResponse.Topic.addMessage(topicMsg); joinResponse.Topic.displayMessages(); } else { Console.WriteLine("Error : " + msgResponse.Error); } } } while (continuer); } break; case 4: Console.WriteLine("Who do you want to send the message to :"); Console.Write("--> "); String receiver = Console.ReadLine(); if (receiver == currentUser.Username) { Console.WriteLine("\n\nYOU CAN'T SEND A MESSAGE TO YOURSELF !!\n\n"); } else { Net.sendMsg(comm.GetStream(), new FindUserRequest(currentUser.Id, receiver)); FindUserResponse findResponse = (FindUserResponse)Net.rcvMsg(comm.GetStream()); if (!findResponse.HasError) { findResponse.displayChat(); bool continuer = true; do { Console.WriteLine("send a message ? (y/n)"); ConsoleKeyInfo input = Console.ReadKey(true); if (input.Key == ConsoleKey.N) { continuer = false; } else { Console.WriteLine("Please, write your message : "); Console.Write("--> "); string message = Console.ReadLine(); PrivateMessage privateMsg = new PrivateMessage(DateTime.Now, currentUser.Id, findResponse.Receiver.Id, message); Net.sendMsg(comm.GetStream(), new SendPrivateRequest(privateMsg)); SendPrivateResponse msgResponse = (SendPrivateResponse)Net.rcvMsg(comm.GetStream()); if (!msgResponse.HasError) { findResponse.Messages.Add(privateMsg); findResponse.displayChat(); } else { Console.WriteLine("Error : " + msgResponse.Error); } } } while (continuer); } else { Console.WriteLine("Error : " + findResponse.Error); } } break; default: Console.WriteLine("make a wise choice mate"); break; } } while (status == Status.Logged); //Net.sendMsg(comm.GetStream(), new Expr(op1, op2, op)); //Console.WriteLine("Result = " + (Result)Net.rcvMsg(comm.GetStream())); } }
public async Task <ActionResult> Token() { //string tokenString = "test"; try { var header = Request.Headers["Authorization"]; if (header.ToString().StartsWith("Basic")) { var credValue = header.ToString().Substring("Basic ".Length).Trim(); var usernameAndPassenc = Encoding.UTF8.GetString(Convert.FromBase64String(credValue)); //admin:pass var usernameAndPass = usernameAndPassenc.Split(":"); //check in DB username and pass exist FindUserResponse response = await IsUserExist(usernameAndPass[0], usernameAndPass[1]); var claimsdata = new[] { new Claim(ClaimTypes.Name, usernameAndPass[0]) }; var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("ahbasshfbsahjfbshajbfhjasbfashjbfsajhfvashjfashfbsahfbsahfksdjf")); var signInCred = new SigningCredentials(key, SecurityAlgorithms.HmacSha256Signature); var token = new JwtSecurityToken( issuer: "mysite.com", audience: "mysite.com", expires: DateTime.Now.AddMinutes(1), claims: claimsdata, signingCredentials: signInCred ); var tokenString = new JwtSecurityTokenHandler().WriteToken(token); KYCDetailsResponse responseKYC = new KYCDetailsResponse(); if (response.IsUserExist && response.role_id != 4) { responseKYC = await us.CheckKYCDetail(usernameAndPass[0]); response.message = responseKYC.message; if (responseKYC.is_success) { return(Ok(new ResponseModel() { isLoginSuccess = true, access_token = tokenString, role_id = response.role_id, user_id = response.user_id, message = response.message })); } else { return(Ok(new ResponseModel() { isLoginSuccess = false, access_token = tokenString, role_id = response.role_id, user_id = response.user_id, message = response.message })); } } else { return(Ok(new ResponseModel() { isLoginSuccess = true, access_token = tokenString, role_id = response.role_id, user_id = response.user_id, message = response.message })); } } } catch (Exception ex) { Console.WriteLine(ex.Message); } return(Forbid("Username and Password not matching..")); // return View(); }