package io.lumify.web.auth.usernameonly.routes;
import com.google.inject.Inject;
import io.lumify.core.config.Configuration;
import io.lumify.core.model.user.UserRepository;
import io.lumify.core.model.workspace.WorkspaceRepository;
import io.lumify.core.user.User;
import io.lumify.miniweb.HandlerChain;
import io.lumify.miniweb.utils.UrlUtils;
import io.lumify.web.BaseRequestHandler;
import io.lumify.web.CurrentUser;
import org.json.JSONObject;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class Login extends BaseRequestHandler {
@Inject
public Login(UserRepository userRepository, WorkspaceRepository workspaceRepository, Configuration configuration) {
super(userRepository, workspaceRepository, configuration);
}
@Override
public void handle(HttpServletRequest request, HttpServletResponse response, HandlerChain chain) throws Exception {
final String username = UrlUtils.urlDecode(request.getParameter("username"));
User user = getUserRepository().findByUsername(username);
if (user == null) {
// For form based authentication, username and displayName will be the same
String randomPassword = UserRepository.createRandomPassword();
user = getUserRepository().addUser(username, username, null, randomPassword, new String[0]);
}
getUserRepository().recordLogin(user, request.getRemoteAddr());
CurrentUser.set(request, user.getUserId(), user.getUsername());
JSONObject json = new JSONObject();
json.put("status", "OK");
respondWithJson(response, json);
}
}