SEBSERV-564 fixed for Moodle

This commit is contained in:
anhefti 2024-07-11 11:02:32 +02:00
parent c3a03719c9
commit 413fb96240
5 changed files with 88 additions and 48 deletions

View file

@ -105,7 +105,7 @@ public abstract class MoodleUtils {
return shortName.equals(Constants.EMPTY_NOTE) ? null : unmaskShortName(shortName); return shortName.equals(Constants.EMPTY_NOTE) ? null : unmaskShortName(shortName);
} }
public static final String getIdnumber(final String internalQuizId) { public static String getIdnumber(final String internalQuizId) {
if (StringUtils.isBlank(internalQuizId)) { if (StringUtils.isBlank(internalQuizId)) {
return null; return null;
} }
@ -118,6 +118,67 @@ public abstract class MoodleUtils {
return idNumber.equals(Constants.EMPTY_NOTE) ? null : idNumber; return idNumber.equals(Constants.EMPTY_NOTE) ? null : idNumber;
} }
public static String getDisplayName(
final String firstname,
final String lastname,
final String fullname,
final String sessionId) {
if (StringUtils.isNotBlank(firstname) && StringUtils.isNotBlank(lastname)) {
return lastname + Constants.SPACE + firstname;
} else if (StringUtils.isNotBlank(lastname) && StringUtils.isNotBlank(fullname)) {
return lastname + Constants.SPACE + fullname;
} else if (StringUtils.isNotBlank(fullname)) {
return fullname;
} else {
return sessionId;
}
}
public static Map<String, String> getMoodleAccountDetails(final MoodleUserDetails[] userDetails) {
final Map<String, String> additionalAttributes = new HashMap<>();
if (userDetails[0].firstname != null) {
additionalAttributes.put("firstname", userDetails[0].firstname);
}
if (userDetails[0].lastname != null) {
additionalAttributes.put("lastname", userDetails[0].lastname);
}
if (userDetails[0].firstaccess != null) {
additionalAttributes.put("firstaccess", String.valueOf(userDetails[0].firstaccess));
}
if (userDetails[0].lastaccess != null) {
additionalAttributes.put("lastaccess", String.valueOf(userDetails[0].lastaccess));
}
if (userDetails[0].auth != null) {
additionalAttributes.put("auth", userDetails[0].auth);
}
if (userDetails[0].suspended != null) {
additionalAttributes.put("suspended", String.valueOf(userDetails[0].suspended));
}
if (userDetails[0].confirmed != null) {
additionalAttributes.put("confirmed", String.valueOf(userDetails[0].confirmed));
}
if (userDetails[0].lang != null) {
additionalAttributes.put("lang", userDetails[0].lang);
}
if (userDetails[0].theme != null) {
additionalAttributes.put("theme", userDetails[0].theme);
}
if (userDetails[0].timezone != null) {
additionalAttributes.put("timezone", userDetails[0].timezone);
}
if (userDetails[0].description != null) {
additionalAttributes.put("description", userDetails[0].description);
}
if (userDetails[0].mailformat != null) {
additionalAttributes.put("mailformat", String.valueOf(userDetails[0].mailformat));
}
if (userDetails[0].descriptionformat != null) {
additionalAttributes.put("descriptionformat", String.valueOf(userDetails[0].descriptionformat));
}
return additionalAttributes;
}
public static void logMoodleWarning( public static void logMoodleWarning(
final Collection<Warning> warnings, final Collection<Warning> warnings,
final String lmsSetupName, final String lmsSetupName,

View file

@ -403,24 +403,14 @@ public class MoodleCourseAccess implements CourseAccessAPI {
throw new RuntimeException("No user details on Moodle API request"); throw new RuntimeException("No user details on Moodle API request");
} }
final Map<String, String> additionalAttributes = new HashMap<>(); final Map<String, String> additionalAttributes = MoodleUtils.getMoodleAccountDetails(userDetails);
additionalAttributes.put("firstname", userDetails[0].firstname);
additionalAttributes.put("lastname", userDetails[0].lastname);
additionalAttributes.put("department", userDetails[0].department);
additionalAttributes.put("firstaccess", String.valueOf(userDetails[0].firstaccess));
additionalAttributes.put("lastaccess", String.valueOf(userDetails[0].lastaccess));
additionalAttributes.put("auth", userDetails[0].auth);
additionalAttributes.put("suspended", String.valueOf(userDetails[0].suspended));
additionalAttributes.put("confirmed", String.valueOf(userDetails[0].confirmed));
additionalAttributes.put("lang", userDetails[0].lang);
additionalAttributes.put("theme", userDetails[0].theme);
additionalAttributes.put("timezone", userDetails[0].timezone);
additionalAttributes.put("description", userDetails[0].description);
additionalAttributes.put("mailformat", String.valueOf(userDetails[0].mailformat));
additionalAttributes.put("descriptionformat", String.valueOf(userDetails[0].descriptionformat));
return new ExamineeAccountDetails( return new ExamineeAccountDetails(
userDetails[0].id, userDetails[0].id,
userDetails[0].lastname + " " + userDetails[0].firstname, MoodleUtils.getDisplayName(
userDetails[0].firstname,
userDetails[0].lastname,
userDetails[0].fullname,
examineeSessionId),
userDetails[0].username, userDetails[0].username,
userDetails[0].email, userDetails[0].email,
additionalAttributes); additionalAttributes);

View file

@ -339,24 +339,14 @@ public class MoodlePluginCourseAccess extends AbstractCachedCourseAccess impleme
throw new RuntimeException("No user details on Moodle API request"); throw new RuntimeException("No user details on Moodle API request");
} }
final Map<String, String> additionalAttributes = new HashMap<>(); final Map<String, String> additionalAttributes = MoodleUtils.getMoodleAccountDetails(userDetails);
additionalAttributes.put("firstname", userDetails[0].firstname);
additionalAttributes.put("lastname", userDetails[0].lastname);
additionalAttributes.put("department", userDetails[0].department);
additionalAttributes.put("firstaccess", String.valueOf(userDetails[0].firstaccess));
additionalAttributes.put("lastaccess", String.valueOf(userDetails[0].lastaccess));
additionalAttributes.put("auth", userDetails[0].auth);
additionalAttributes.put("suspended", String.valueOf(userDetails[0].suspended));
additionalAttributes.put("confirmed", String.valueOf(userDetails[0].confirmed));
additionalAttributes.put("lang", userDetails[0].lang);
additionalAttributes.put("theme", userDetails[0].theme);
additionalAttributes.put("timezone", userDetails[0].timezone);
additionalAttributes.put("description", userDetails[0].description);
additionalAttributes.put("mailformat", String.valueOf(userDetails[0].mailformat));
additionalAttributes.put("descriptionformat", String.valueOf(userDetails[0].descriptionformat));
return new ExamineeAccountDetails( return new ExamineeAccountDetails(
userDetails[0].id, userDetails[0].id,
userDetails[0].lastname + " " + userDetails[0].firstname, MoodleUtils.getDisplayName(
userDetails[0].firstname,
userDetails[0].lastname,
userDetails[0].fullname,
examineeSessionId),
userDetails[0].username, userDetails[0].username,
userDetails[0].email, userDetails[0].email,
additionalAttributes); additionalAttributes);

View file

@ -103,19 +103,18 @@ public class MoodleCourseAccessTest {
assertEquals("user1 seb", userDetails.name); assertEquals("user1 seb", userDetails.name);
assertEquals("demo1@safeexambrowser.org", userDetails.email); assertEquals("demo1@safeexambrowser.org", userDetails.email);
assertEquals( assertEquals(
"{auth=manual, " "{auth=manual, " +
+ "confirmed=true, " "confirmed=true, " +
+ "department=, " "description=, " +
+ "description=, " "descriptionformat=1, " +
+ "descriptionformat=1, " "firstaccess=1523400731, " +
+ "firstaccess=1523400731, " "firstname=seb, " +
+ "firstname=seb, " "lang=en, " +
+ "lang=en, " "lastaccess=1596457337, " +
+ "lastaccess=1596457337, " "lastname=user1, " +
+ "lastname=user1, " "mailformat=1, " +
+ "mailformat=1, " "suspended=false, " +
+ "suspended=false, " "theme=, timezone=99}",
+ "theme=, timezone=99}",
new TreeMap<>(userDetails.additionalAttributes).toString()); new TreeMap<>(userDetails.additionalAttributes).toString());
} }

View file

@ -252,8 +252,8 @@ public class MoodlePluginCourseAccessTest {
assertFalse(userDetailsResult.hasError()); assertFalse(userDetailsResult.hasError());
final ExamineeAccountDetails examineeAccountDetails = userDetailsResult.get(); final ExamineeAccountDetails examineeAccountDetails = userDetailsResult.get();
assertEquals( assertEquals(
"ExamineeAccountDetails [id=2, name=user test, username=testuser, email=text@user.mail, " "ExamineeAccountDetails [id=2, name=user test, username=testuser, email=text@user.mail, " +
+ "additionalAttributes={mailformat=null, firstname=test, auth=null, timezone=null, description=null, firstaccess=null, confirmed=null, suspended=null, lastname=user, lastaccess=null, theme=null, descriptionformat=null, department=null, lang=null}]", "additionalAttributes={firstname=test, lastname=user}]",
examineeAccountDetails.toString()); examineeAccountDetails.toString());
assertEquals( assertEquals(