Token Based Authentication #30
@ -46,6 +46,9 @@ public final class LoginScene implements EventListener {
|
|||||||
@FXML
|
@FXML
|
||||||
private Button loginButton;
|
private Button loginButton;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private CheckBox cbStaySignedIn;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private Button offlineModeButton;
|
private Button offlineModeButton;
|
||||||
|
|
||||||
@ -55,7 +58,7 @@ public final class LoginScene implements EventListener {
|
|||||||
@FXML
|
@FXML
|
||||||
private ImageView logo;
|
private ImageView logo;
|
||||||
|
|
||||||
private boolean registration = false;
|
private boolean registration;
|
||||||
|
|
||||||
private static final Logger logger = EnvoyLog.getLogger(LoginScene.class);
|
private static final Logger logger = EnvoyLog.getLogger(LoginScene.class);
|
||||||
private static final ClientConfig config = ClientConfig.getInstance();
|
private static final ClientConfig config = ClientConfig.getInstance();
|
||||||
@ -76,6 +79,7 @@ public final class LoginScene implements EventListener {
|
|||||||
@FXML
|
@FXML
|
||||||
private void loginButtonPressed() {
|
private void loginButtonPressed() {
|
||||||
final String user = userTextField.getText(), pass = passwordField.getText(), repeatPass = repeatPasswordField.getText();
|
final String user = userTextField.getText(), pass = passwordField.getText(), repeatPass = repeatPasswordField.getText();
|
||||||
|
final boolean requestToken = cbStaySignedIn.isSelected();
|
||||||
|
|
||||||
// Prevent registration with unequal passwords
|
// Prevent registration with unequal passwords
|
||||||
if (registration && !pass.equals(repeatPass)) {
|
if (registration && !pass.equals(repeatPass)) {
|
||||||
@ -86,8 +90,8 @@ public final class LoginScene implements EventListener {
|
|||||||
userTextField.clear();
|
userTextField.clear();
|
||||||
} else {
|
} else {
|
||||||
Instant lastSync = Startup.loadLastSync(userTextField.getText());
|
Instant lastSync = Startup.loadLastSync(userTextField.getText());
|
||||||
Startup.performHandshake(registration ? LoginCredentials.registration(user, pass, Startup.VERSION, lastSync)
|
Startup.performHandshake(registration ? LoginCredentials.registration(user, pass, requestToken, Startup.VERSION, lastSync)
|
||||||
: LoginCredentials.login(user, pass, Startup.VERSION, lastSync));
|
: LoginCredentials.login(user, pass, requestToken, Startup.VERSION, lastSync));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
<?import javafx.geometry.Insets?>
|
<?import javafx.geometry.Insets?>
|
||||||
<?import javafx.scene.control.Button?>
|
<?import javafx.scene.control.Button?>
|
||||||
|
<?import javafx.scene.control.CheckBox?>
|
||||||
<?import javafx.scene.control.Label?>
|
<?import javafx.scene.control.Label?>
|
||||||
<?import javafx.scene.control.PasswordField?>
|
<?import javafx.scene.control.PasswordField?>
|
||||||
<?import javafx.scene.control.TextField?>
|
<?import javafx.scene.control.TextField?>
|
||||||
@ -32,9 +33,7 @@
|
|||||||
<Insets bottom="5.0" left="5.0" right="5.0" top="5.0" />
|
<Insets bottom="5.0" left="5.0" right="5.0" top="5.0" />
|
||||||
</padding>
|
</padding>
|
||||||
</Label>
|
</Label>
|
||||||
<Label alignment="TOP_CENTER" contentDisplay="CENTER"
|
<Label alignment="TOP_CENTER" contentDisplay="CENTER" prefHeight="33.0" prefWidth="110.0" text="LOGIN" textAlignment="CENTER">
|
||||||
prefHeight="33.0" prefWidth="110.0" text="LOGIN"
|
|
||||||
textAlignment="CENTER">
|
|
||||||
<font>
|
<font>
|
||||||
<Font size="26.0" />
|
<Font size="26.0" />
|
||||||
</font>
|
</font>
|
||||||
@ -92,6 +91,11 @@
|
|||||||
<Insets bottom="2.0" left="125.0" right="125.0" top="2.0" />
|
<Insets bottom="2.0" left="125.0" right="125.0" top="2.0" />
|
||||||
</padding>
|
</padding>
|
||||||
</Button>
|
</Button>
|
||||||
|
<CheckBox fx:id="cbStaySignedIn" mnemonicParsing="false" text="Keep me signed in">
|
||||||
|
<VBox.margin>
|
||||||
|
<Insets bottom="10.0" top="10.0" />
|
||||||
|
</VBox.margin>
|
||||||
|
</CheckBox>
|
||||||
<HBox alignment="CENTER" prefHeight="30.0" prefWidth="200.0">
|
<HBox alignment="CENTER" prefHeight="30.0" prefWidth="200.0">
|
||||||
<children>
|
<children>
|
||||||
<Label fx:id="registerTextLabel" text="No account yet?" />
|
<Label fx:id="registerTextLabel" text="No account yet?" />
|
||||||
|
@ -20,16 +20,18 @@ import java.time.Instant;
|
|||||||
public final class LoginCredentials implements Serializable {
|
public final class LoginCredentials implements Serializable {
|
||||||
|
|
||||||
private final String identifier, password, clientVersion;
|
private final String identifier, password, clientVersion;
|
||||||
private final boolean registration, token;
|
private final boolean registration, token, requestToken;
|
||||||
private final Instant lastSync;
|
private final Instant lastSync;
|
||||||
|
|
||||||
private static final long serialVersionUID = 3;
|
private static final long serialVersionUID = 4;
|
||||||
|
|
||||||
private LoginCredentials(String identifier, String password, boolean registration, boolean token, String clientVersion, Instant lastSync) {
|
private LoginCredentials(String identifier, String password, boolean registration, boolean token, boolean requestToken, String clientVersion,
|
||||||
|
Instant lastSync) {
|
||||||
this.identifier = identifier;
|
this.identifier = identifier;
|
||||||
this.password = password;
|
this.password = password;
|
||||||
this.registration = registration;
|
this.registration = registration;
|
||||||
this.token = token;
|
this.token = token;
|
||||||
|
this.requestToken = requestToken;
|
||||||
this.clientVersion = clientVersion;
|
this.clientVersion = clientVersion;
|
||||||
this.lastSync = lastSync;
|
this.lastSync = lastSync;
|
||||||
}
|
}
|
||||||
@ -39,13 +41,14 @@ public final class LoginCredentials implements Serializable {
|
|||||||
*
|
*
|
||||||
* @param identifier the identifier of the user
|
* @param identifier the identifier of the user
|
||||||
* @param password the password of the user
|
* @param password the password of the user
|
||||||
|
* @param requestToken requests the server to generate an authentication token
|
||||||
* @param clientVersion the version of the client sending these credentials
|
* @param clientVersion the version of the client sending these credentials
|
||||||
* @param lastSync the timestamp of the last synchronization
|
* @param lastSync the timestamp of the last synchronization
|
||||||
* @return the created login credentials
|
* @return the created login credentials
|
||||||
* @since Envoy Common v0.2-beta
|
* @since Envoy Common v0.2-beta
|
||||||
*/
|
*/
|
||||||
public static LoginCredentials login(String identifier, String password, String clientVersion, Instant lastSync) {
|
public static LoginCredentials login(String identifier, String password, boolean requestToken, String clientVersion, Instant lastSync) {
|
||||||
return new LoginCredentials(identifier, password, false, false, clientVersion, lastSync);
|
return new LoginCredentials(identifier, password, false, false, requestToken, clientVersion, lastSync);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -59,7 +62,7 @@ public final class LoginCredentials implements Serializable {
|
|||||||
* @since Envoy Common v0.2-beta
|
* @since Envoy Common v0.2-beta
|
||||||
*/
|
*/
|
||||||
public static LoginCredentials loginWithToken(String identifier, String token, String clientVersion, Instant lastSync) {
|
public static LoginCredentials loginWithToken(String identifier, String token, String clientVersion, Instant lastSync) {
|
||||||
return new LoginCredentials(identifier, token, false, true, clientVersion, lastSync);
|
return new LoginCredentials(identifier, token, false, true, false, clientVersion, lastSync);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -67,21 +70,23 @@ public final class LoginCredentials implements Serializable {
|
|||||||
*
|
*
|
||||||
* @param identifier the identifier of the user
|
* @param identifier the identifier of the user
|
||||||
* @param password the password of the user
|
* @param password the password of the user
|
||||||
|
* @param requestToken requests the server to generate an authentication token
|
||||||
* @param clientVersion the version of the client sending these credentials
|
* @param clientVersion the version of the client sending these credentials
|
||||||
* @param lastSync the timestamp of the last synchronization
|
* @param lastSync the timestamp of the last synchronization
|
||||||
* @return the created login credentials
|
* @return the created login credentials
|
||||||
* @since Envoy Common v0.2-beta
|
* @since Envoy Common v0.2-beta
|
||||||
*/
|
*/
|
||||||
public static LoginCredentials registration(String identifier, String password, String clientVersion, Instant lastSync) {
|
public static LoginCredentials registration(String identifier, String password, boolean requestToken, String clientVersion, Instant lastSync) {
|
||||||
return new LoginCredentials(identifier, password, true, false, clientVersion, lastSync);
|
return new LoginCredentials(identifier, password, true, false, requestToken, clientVersion, lastSync);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return String.format("LoginCredentials[identifier=%s,registration=%b,token=%b,clientVersion=%s,lastSync=%s]",
|
return String.format("LoginCredentials[identifier=%s,registration=%b,token=%b,requestToken=%b,clientVersion=%s,lastSync=%s]",
|
||||||
identifier,
|
identifier,
|
||||||
registration,
|
registration,
|
||||||
token,
|
token,
|
||||||
|
requestToken,
|
||||||
clientVersion,
|
clientVersion,
|
||||||
lastSync);
|
lastSync);
|
||||||
}
|
}
|
||||||
@ -112,6 +117,12 @@ public final class LoginCredentials implements Serializable {
|
|||||||
*/
|
*/
|
||||||
public boolean usesToken() { return token; }
|
public boolean usesToken() { return token; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return {@code true} if the server should generate a new authentication token
|
||||||
|
* @since Envoy Common v0.2-beta
|
||||||
|
*/
|
||||||
|
public boolean requestToken() { return requestToken; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the version of the client sending these credentials
|
* @return the version of the client sending these credentials
|
||||||
* @since Envoy Common v0.1-beta
|
* @since Envoy Common v0.1-beta
|
||||||
@ -119,7 +130,7 @@ public final class LoginCredentials implements Serializable {
|
|||||||
public String getClientVersion() { return clientVersion; }
|
public String getClientVersion() { return clientVersion; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the time stamp of the last synchronization
|
* @return the timestamp of the last synchronization
|
||||||
* @since Envoy Common v0.2-beta
|
* @since Envoy Common v0.2-beta
|
||||||
*/
|
*/
|
||||||
public Instant getLastSync() { return lastSync; }
|
public Instant getLastSync() { return lastSync; }
|
||||||
|
Reference in New Issue
Block a user