implemented login and registration (unfinished)
This commit is contained in:
@ -23,12 +23,12 @@ import envoy.server.net.ObjectWriteProxy;
|
||||
* Created: <strong>30.12.2019</strong><br>
|
||||
*
|
||||
* @author Kai S. K. Engelbart
|
||||
* @author Maximilian Käfer
|
||||
* @since Envoy Server Standalone v0.1-alpha
|
||||
*/
|
||||
public class LoginCredentialProcessor implements ObjectProcessor<LoginCredentials> {
|
||||
|
||||
// TODO: Acquire user IDs from database
|
||||
private static long currentUserId = 1;
|
||||
private PersistenceManager persistenceManager = PersistenceManager.getPersistenceManager();
|
||||
|
||||
@Override
|
||||
public Class<LoginCredentials> getInputClass() { return LoginCredentials.class; }
|
||||
@ -38,7 +38,25 @@ public class LoginCredentialProcessor implements ObjectProcessor<LoginCredential
|
||||
System.out.println(String.format("Received login credentials %s from socket ID %d", input, socketId));
|
||||
|
||||
// Create user
|
||||
User user = new User(currentUserId++, input.getName());
|
||||
User user = null;
|
||||
|
||||
if (input.isRegistration()) {
|
||||
envoy.server.data.User dbUser = new envoy.server.data.User();
|
||||
dbUser.setName(input.getName());
|
||||
dbUser.setLastSeen(new Date());
|
||||
dbUser.setStatus(User.UserStatus.ONLINE);
|
||||
dbUser.setPasswordHash(input.getPasswordHash());
|
||||
persistenceManager.addUser(dbUser);
|
||||
user = dbUser.toCommonUser();
|
||||
}else {
|
||||
// TODO: Implement error when user does not exist
|
||||
envoy.server.data.User requestedUser = persistenceManager.getUserByName(input.getName());
|
||||
if (input.getPasswordHash() == requestedUser.getPasswordHash()) {
|
||||
user = requestedUser.toCommonUser();
|
||||
} else {
|
||||
// TODO: Wrong Password Response
|
||||
}
|
||||
}
|
||||
ConnectionManager.getInstance().registerUser(socketId, user.getId());
|
||||
|
||||
// Create contacts
|
||||
|
Reference in New Issue
Block a user