Merge remote-tracking branch 'origin/dev-1.2' into development
Conflicts: .github/workflows/buildReporting.yml src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/SEBClientConnectionServiceImpl.java
This commit is contained in:
commit
2fd3850186
1 changed files with 57 additions and 26 deletions
|
@ -185,22 +185,7 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
final String clientId) {
|
final String clientId) {
|
||||||
|
|
||||||
return Result.tryCatch(() -> {
|
return Result.tryCatch(() -> {
|
||||||
if (log.isDebugEnabled()) {
|
|
||||||
log.debug(
|
|
||||||
"SEB client connection, update ClientConnection for "
|
|
||||||
+ "connectionToken {} "
|
|
||||||
+ "institutionId: {}"
|
|
||||||
+ "exam: {} "
|
|
||||||
+ "client address: {} "
|
|
||||||
+ "userSessionId: {}"
|
|
||||||
+ "clientId: {}",
|
|
||||||
connectionToken,
|
|
||||||
institutionId,
|
|
||||||
examId,
|
|
||||||
clientAddress,
|
|
||||||
userSessionId,
|
|
||||||
clientId);
|
|
||||||
}
|
|
||||||
|
|
||||||
final ClientConnection clientConnection = getClientConnection(connectionToken);
|
final ClientConnection clientConnection = getClientConnection(connectionToken);
|
||||||
|
|
||||||
|
@ -219,6 +204,23 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
checkExamIntegrity(examId);
|
checkExamIntegrity(examId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (log.isDebugEnabled()) {
|
||||||
|
log.debug(
|
||||||
|
"SEB client connection, update ClientConnection for "
|
||||||
|
+ "connectionToken {} "
|
||||||
|
+ "institutionId: {}"
|
||||||
|
+ "exam: {} "
|
||||||
|
+ "client address: {} "
|
||||||
|
+ "userSessionId: {}"
|
||||||
|
+ "clientId: {}",
|
||||||
|
connectionToken,
|
||||||
|
institutionId,
|
||||||
|
examId,
|
||||||
|
clientAddress,
|
||||||
|
userSessionId,
|
||||||
|
clientId);
|
||||||
|
}
|
||||||
|
|
||||||
updateUserSessionId(userSessionId, clientConnection, examId);
|
updateUserSessionId(userSessionId, clientConnection, examId);
|
||||||
final ClientConnection updatedClientConnection = this.clientConnectionDAO
|
final ClientConnection updatedClientConnection = this.clientConnectionDAO
|
||||||
.save(new ClientConnection(
|
.save(new ClientConnection(
|
||||||
|
@ -265,6 +267,34 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
|
|
||||||
return Result.tryCatch(() -> {
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
|
ClientConnection clientConnection = getClientConnection(connectionToken);
|
||||||
|
|
||||||
|
// connection integrity check
|
||||||
|
if (clientConnection.status == ConnectionStatus.ACTIVE) {
|
||||||
|
if (clientConnection.clientAddress != null && clientConnection.clientAddress.equals(clientAddress)) {
|
||||||
|
// It seems that this is the same SEB that tries to establish the connection once again.
|
||||||
|
// Just log this and return already established connection
|
||||||
|
if (log.isDebugEnabled()) {
|
||||||
|
log.debug(
|
||||||
|
"SEB retired to establish an already established client connection. Client adress: {} : {}",
|
||||||
|
clientConnection.clientAddress,
|
||||||
|
clientAddress);
|
||||||
|
}
|
||||||
|
return clientConnection;
|
||||||
|
} else {
|
||||||
|
// It seems that this is a request from an other device then the original
|
||||||
|
log.error("ClientConnection integrity violation: client connection mismatch: {}",
|
||||||
|
clientConnection);
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"ClientConnection integrity violation: client connection mismatch");
|
||||||
|
}
|
||||||
|
} else if (!clientConnection.status.clientActiveStatus) {
|
||||||
|
log.error("ClientConnection integrity violation: client connection is not in expected state: {}",
|
||||||
|
clientConnection);
|
||||||
|
throw new IllegalArgumentException(
|
||||||
|
"ClientConnection integrity violation: client connection is not in expected state");
|
||||||
|
}
|
||||||
|
|
||||||
if (log.isDebugEnabled()) {
|
if (log.isDebugEnabled()) {
|
||||||
log.debug(
|
log.debug(
|
||||||
"SEB client connection, establish ClientConnection for "
|
"SEB client connection, establish ClientConnection for "
|
||||||
|
@ -282,7 +312,6 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
clientId);
|
clientId);
|
||||||
}
|
}
|
||||||
|
|
||||||
ClientConnection clientConnection = getClientConnection(connectionToken);
|
|
||||||
checkInstitutionalIntegrity(institutionId, clientConnection);
|
checkInstitutionalIntegrity(institutionId, clientConnection);
|
||||||
checkExamIntegrity(examId, clientConnection);
|
checkExamIntegrity(examId, clientConnection);
|
||||||
clientConnection = updateUserSessionId(userSessionId, clientConnection, examId);
|
clientConnection = updateUserSessionId(userSessionId, clientConnection, examId);
|
||||||
|
@ -672,15 +701,17 @@ public class SEBClientConnectionServiceImpl implements SEBClientConnectionServic
|
||||||
ClientConnection clientConnection,
|
ClientConnection clientConnection,
|
||||||
final Long examId) {
|
final Long examId) {
|
||||||
|
|
||||||
if (StringUtils.isNotBlank(userSessionId)) {
|
if (StringUtils.isNoneBlank(userSessionId)) {
|
||||||
|
if (StringUtils.isNoneBlank(clientConnection.userSessionId)) {
|
||||||
if (StringUtils.isNoneBlank(clientConnection.userSessionId)
|
if (clientConnection.userSessionId.contains(userSessionId)) {
|
||||||
&& clientConnection.userSessionId.contains(userSessionId)) {
|
if (log.isDebugEnabled()) {
|
||||||
|
log.debug("SEB sent LMS userSessionId but clientConnection has already a userSessionId");
|
||||||
if (log.isDebugEnabled()) {
|
}
|
||||||
log.debug("SEB sent LMS userSessionId but clientConnection has already a userSessionId");
|
} else {
|
||||||
|
log.warn(
|
||||||
|
"Possible client integrity violation: clientConnection has already a userSessionId: {} : {}",
|
||||||
|
userSessionId, clientConnection.userSessionId);
|
||||||
}
|
}
|
||||||
|
|
||||||
return clientConnection;
|
return clientConnection;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue