diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/api/authorization/PrivilegeType.java b/src/main/java/ch/ethz/seb/sebserver/gbl/api/authorization/PrivilegeType.java index e4bc9c20..2e8abfde 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/api/authorization/PrivilegeType.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/api/authorization/PrivilegeType.java @@ -29,7 +29,7 @@ public enum PrivilegeType { * and so on. * * @param type the PrivilegeType - * @return true if given PrivilegeType is implicit form this PrivilegeType */ + * @return true if given PrivilegeType is implicit from this PrivilegeType */ public boolean hasImplicit(final PrivilegeType type) { if (type == null) { return false; diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/async/AsyncService.java b/src/main/java/ch/ethz/seb/sebserver/gbl/async/AsyncService.java index 17f9f816..a6a1d46e 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/async/AsyncService.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/async/AsyncService.java @@ -36,7 +36,7 @@ public class AsyncService { * * @param maxFailingAttempts maximal number of attempts the CircuitBreaker allows before going onto open state. * @param maxBlockingTime maximal time since call CircuitBreaker waits for a response before going onto open state. - * @param timeToRecover the time the CircuitBreaker takes to recover form open state. + * @param timeToRecover the time the CircuitBreaker takes to recover from open state. * @param the type of the CircuitBreaker * @return a CircuitBreaker of specified type */ public CircuitBreaker createCircuitBreaker( @@ -57,7 +57,7 @@ public class AsyncService { * @param blockingSupplier the blocking result supplier that the MemoizingCircuitBreaker must call * @param maxFailingAttempts maximal number of attempts the CircuitBreaker allows before going onto open state. * @param maxBlockingTime maximal time since call CircuitBreaker waits for a response before going onto open state. - * @param timeToRecover the time the CircuitBreaker takes to recover form open state. + * @param timeToRecover the time the CircuitBreaker takes to recover from open state. * @param momoized whether the memoizing functionality is on or off * @param maxMemoizingTime the maximal time memorized data is valid * @param the type of the CircuitBreaker diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java b/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java index 5a236a5d..f32f3a62 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/async/MemoizingCircuitBreaker.java @@ -94,7 +94,7 @@ public final class MemoizingCircuitBreaker implements Supplier> { * * @param asyncRunner the AsyncRunner used to create asynchronous calls on the given supplier function * @param supplier The Supplier function that can fail or block for a long time - * @param maxFailingAttempts the number of maximal failing attempts before go form CLOSE into HALF_OPEN state + * @param maxFailingAttempts the number of maximal failing attempts before go from CLOSE into HALF_OPEN state * @param maxBlockingTime the maximal time that an call attempt can block until an error is responded * @param timeToRecover the time the circuit breaker needs to cool-down on OPEN-STATE before going back to HALF_OPEN * state diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/client/ClientCredentialService.java b/src/main/java/ch/ethz/seb/sebserver/gbl/client/ClientCredentialService.java index d28e6664..a61e8b39 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/client/ClientCredentialService.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/client/ClientCredentialService.java @@ -55,13 +55,13 @@ public interface ClientCredentialService { return encryptClientCredentials(clientIdPlaintext, secretPlaintext, null); } - /** Use this to get a decrypted plain text secret form given ClientCredentials + /** Use this to get a decrypted plain text secret from given ClientCredentials * * @param credentials ClientCredentials containing the secret to decrypt * @return decrypted plain text secret */ Result getPlainClientSecret(ClientCredentials credentials); - /** Use this to get a decrypted plain text accessToken form given ClientCredentials + /** Use this to get a decrypted plain text accessToken from given ClientCredentials * * @param credentials ClientCredentials containing the accessToken to decrypt * @return decrypted plain text accessToken */ diff --git a/src/main/java/ch/ethz/seb/sebserver/gbl/model/Entity.java b/src/main/java/ch/ethz/seb/sebserver/gbl/model/Entity.java index ada4b1ae..451913f3 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gbl/model/Entity.java +++ b/src/main/java/ch/ethz/seb/sebserver/gbl/model/Entity.java @@ -48,7 +48,7 @@ public interface Entity extends ModelIdAware { /** Creates an EntityName instance from this Entity instance. * - * @return EntityName instance created form given Entity */ + * @return EntityName instance created from given Entity */ default EntityName toName() { return new EntityName( this.getModelId(), diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/InstitutionalAuthenticationEntryPoint.java b/src/main/java/ch/ethz/seb/sebserver/gui/InstitutionalAuthenticationEntryPoint.java index 8971254b..12d24351 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/InstitutionalAuthenticationEntryPoint.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/InstitutionalAuthenticationEntryPoint.java @@ -231,7 +231,7 @@ public final class InstitutionalAuthenticationEntryPoint implements Authenticati final Object attribute = RWT.getUISession().getHttpSession().getAttribute(INST_SUFFIX_ATTRIBUTE); return (attribute != null) ? String.valueOf(attribute) : null; } catch (final Exception e) { - log.warn("Failed to extract institutional endpoint form user session: {}", e.getMessage()); + log.warn("Failed to extract institutional endpoint from user session: {}", e.getMessage()); return null; } } diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/content/configs/SEBExamConfigBatchStateChangePopup.java b/src/main/java/ch/ethz/seb/sebserver/gui/content/configs/SEBExamConfigBatchStateChangePopup.java index ecb21abd..9842a03a 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/content/configs/SEBExamConfigBatchStateChangePopup.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/content/configs/SEBExamConfigBatchStateChangePopup.java @@ -108,7 +108,7 @@ public class SEBExamConfigBatchStateChangePopup extends AbstractBatchActionWizar final String targetStateName = pageContext.getAttribute(ATTR_SELECTED_TARGET_STATE); if (StringUtils.isBlank(targetStateName)) { - throw new IllegalArgumentException("missing " + ATTR_SELECTED_TARGET_STATE + " form pageContext"); + throw new IllegalArgumentException("missing " + ATTR_SELECTED_TARGET_STATE + " from pageContext"); } batchActionRequestBuilder.withFormParam(BatchAction.ACTION_ATTRIBUT_TARGET_STATE, targetStateName); diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/form/Form.java b/src/main/java/ch/ethz/seb/sebserver/gui/form/Form.java index cd44d9ab..02a90892 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/form/Form.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/form/Form.java @@ -70,7 +70,7 @@ public final class Form implements FormBinding { flush(); return this.jsonMapper.writeValueAsString(this.objectRoot); } catch (final Exception e) { - throw new RuntimeException("Unexpected error while trying to create json form Form post: ", e); + throw new RuntimeException("Unexpected error while trying to create json from form post: ", e); } } diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/TableFieldBuilder.java b/src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/TableFieldBuilder.java index 9b529c7b..c65b4623 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/TableFieldBuilder.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/service/examconfig/impl/TableFieldBuilder.java @@ -168,7 +168,7 @@ public class TableFieldBuilder extends AbstractTableFieldBuilder { private void addRow() { final int index = this.values.size(); - // create new values form default values + // create new values from default values final Map rowValues = this.tableContext.getRowAttributes() .stream() .map(attr -> new TableValue(attr.id, index, attr.defaultValue)) diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/service/i18n/I18nSupport.java b/src/main/java/ch/ethz/seb/sebserver/gui/service/i18n/I18nSupport.java index fe7b70a4..80a35e0c 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/service/i18n/I18nSupport.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/service/i18n/I18nSupport.java @@ -43,7 +43,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.date.display format' * or the Constants.DEFAULT_DISPLAY_DATE_FORMAT * - * Adds time-zone offset information if the currents user time-zone is different form UTC + * Adds time-zone offset information if the currents user time-zone is different from UTC * * @param date the DateTime instance * @return date formatted date String to display */ @@ -53,7 +53,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.date.display format' * or the Constants.DEFAULT_DISPLAY_DATE_FORMAT * - * Adds time-zone offset information if the currents user time-zone is different form UTC + * Adds time-zone offset information if the currents user time-zone is different from UTC * * @param date the DateTime instance * @return date formatted date String to display */ @@ -65,7 +65,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.date.display format' * or the Constants.DEFAULT_DISPLAY_DATE_FORMAT * - * Adds time-zone information if the currents user time-zone is different form UTC + * Adds time-zone information if the currents user time-zone is different from UTC * * @param timestamp the unix-timestamp in milliseconds * @return date formatted date String to display */ @@ -77,7 +77,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.datetime.display format' * or the Constants.DEFAULT_DISPLAY_DATE_TIME_FORMAT * - * Adds time-zone information if the currents user time-zone is different form UTC + * Adds time-zone information if the currents user time-zone is different from UTC * * @param date the DateTime instance * @return date formatted date time String to display */ @@ -87,7 +87,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.datetime.display format' * or the Constants.DEFAULT_DISPLAY_DATE_TIME_FORMAT * - * Adds time-zone information if the currents user time-zone is different form UTC + * Adds time-zone information if the currents user time-zone is different from UTC * * @param timestamp the unix-timestamp in milliseconds * @return date formatted date time String to display */ @@ -99,7 +99,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.time.display format' * or the Constants.DEFAULT_DISPLAY_TIME_FORMAT * - * Adds time-zone information if the currents user time-zone is different form UTC + * Adds time-zone information if the currents user time-zone is different from UTC * * @param date the DateTime instance * @return date formatted time String to display */ @@ -109,7 +109,7 @@ public interface I18nSupport { * This uses the date-format defined by either the attribute 'sebserver.gui.time.display format' * or the Constants.DEFAULT_DISPLAY_TIME_FORMAT * - * Adds time-zone information if the currents user time-zone is different form UTC + * Adds time-zone information if the currents user time-zone is different from UTC * * @param timestamp the unix-timestamp in milliseconds * @return date formatted time String to display */ diff --git a/src/main/java/ch/ethz/seb/sebserver/gui/table/EntityTable.java b/src/main/java/ch/ethz/seb/sebserver/gui/table/EntityTable.java index 8eb9a1d7..152a8706 100644 --- a/src/main/java/ch/ethz/seb/sebserver/gui/table/EntityTable.java +++ b/src/main/java/ch/ethz/seb/sebserver/gui/table/EntityTable.java @@ -716,7 +716,7 @@ public class EntityTable { return 1; } } catch (final Exception e) { - log.error("Failed to get sort attribute form current user attributes", e); + log.error("Failed to get sort attribute from current user attributes", e); return 1; } } @@ -757,7 +757,7 @@ public class EntityTable { setTableSort(); } catch (final Exception e) { - log.error("Failed to get sort attribute form current user attributes", e); + log.error("Failed to get sort attribute from current user attributes", e); } } @@ -794,7 +794,7 @@ public class EntityTable { .getCurrentUser() .getAttribute(this.filterAttrName)); } catch (final Exception e) { - log.error("Failed to get filter attributes form current user attributes", e); + log.error("Failed to get filter attributes from current user attributes", e); } } } diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/WebserviceInfo.java b/src/main/java/ch/ethz/seb/sebserver/webservice/WebserviceInfo.java index ed4557aa..c52d0b19 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/WebserviceInfo.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/WebserviceInfo.java @@ -233,7 +233,7 @@ public class WebserviceInfo { return InetAddress.getLoopbackAddress().getHostAddress(); } - /** Get the server URL prefix in form of; + /** Get the server URL prefix in the form of; * [scheme{http|https}]://[server-address{DNS-name|IP}]:[port] * * E.g.: https://seb.server.ch:8080 diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/PaginationService.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/PaginationService.java index 6212f1d6..fbf24ec2 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/PaginationService.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/PaginationService.java @@ -19,7 +19,7 @@ import ch.ethz.seb.sebserver.gbl.model.Entity; import ch.ethz.seb.sebserver.gbl.model.Page; import ch.ethz.seb.sebserver.gbl.util.Result; -/** A service to apply pagination functionality within collection results form data access layer. +/** A service to apply pagination functionality within collection results from data access layer. * The default implementation uses Mybatis-PageHelper to apply the pagination on SQL level where possible: * https://github.com/pagehelper/Mybatis-PageHelper */ diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/bulkaction/BulkActionService.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/bulkaction/BulkActionService.java index 57e063fa..6787f2cb 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/bulkaction/BulkActionService.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/bulkaction/BulkActionService.java @@ -56,7 +56,7 @@ public interface BulkActionService { * If the given BulkAction has not already been executed, it will be executed first * * @param action the BulkAction of a concrete type - * @return EntityProcessingReport extracted form an executed BulkAction */ + * @return EntityProcessingReport extracted from an executed BulkAction */ Result createReport(BulkAction action); } \ No newline at end of file diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ClientInstructionDAO.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ClientInstructionDAO.java index 795a801f..c18c4e53 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ClientInstructionDAO.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ClientInstructionDAO.java @@ -45,7 +45,7 @@ public interface ClientInstructionDAO { * @return Collection of all active instructions for specified connection token */ Result> getAllActive(String connectionToken); - /** Deletes all old instructions form the persistent storage to clean-up. + /** Deletes all old instructions from the persistent storage to clean-up. * Old in this case means the timestamp is older then one minute or a configured time interval * * @param timestamp the time-stamp (milliseconds) of the time in the past from that earlier instructions are @@ -53,7 +53,7 @@ public interface ClientInstructionDAO { * @return Result collection of keys of deleted entities or refer to an error when happened */ Result> deleteAllInactive(long timestamp); - /** Deletes the specified instruction form the data base + /** Deletes the specified instruction from the data base * * @param id the identifier (PK) if the ClientInstruction to delete * @return Void Result refer to an error if happened */ diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ConfigurationDAO.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ConfigurationDAO.java index 51c1449e..a04e67a4 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ConfigurationDAO.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ConfigurationDAO.java @@ -38,7 +38,7 @@ public interface ConfigurationDAO extends EntityDAO saveToHistory(Long configurationNodeId); diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/EntityDAO.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/EntityDAO.java index c6743587..b1b57af5 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/EntityDAO.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/EntityDAO.java @@ -148,14 +148,14 @@ public interface EntityDAO { * @return Result referring to collection of all matching entities or an error if happened */ Result> allMatching(FilterMap filterMap, Predicate predicate); - /** Context based utility method to extract an expected single resource entry form a Collection of specified type. - * Gets a Result refer to an expected single resource entry form a Collection of specified type or refer + /** Context based utility method to extract an expected single resource entry from a Collection of specified type. + * Gets a Result refer to an expected single resource entry from a Collection of specified type or refer * to a ResourceNotFoundException if specified collection is null or empty or refer to a * unexpected RuntimeException if there are more then the expected single element in the given collection * * @param id The resource id to wrap within a ResourceNotFoundException if needed * @param resources the collection of resource entries - * @return Result refer to an expected single resource entry form a Collection of specified type or refer to an + * @return Result refer to an expected single resource entry from a Collection of specified type or refer to an * error if happened */ default Result getSingleResource(final String id, final Collection resources) { diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ExamDAO.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ExamDAO.java index 370cbfa1..7c6b77c9 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ExamDAO.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/ExamDAO.java @@ -89,7 +89,7 @@ public interface ExamDAO extends ActivatableEntityDAO, BulkActionSup final Predicate predicate, final ExamStatus... status); - /** Gets all for active and none archived exams within the system, independently form institution and LMSSetup. + /** Gets all for active and none archived exams within the system, independently from institution and LMSSetup. * * @return Result refer to all exams for LMS update or to an error when happened */ Result> allForLMSUpdate(); diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/CertificateDAOImpl.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/CertificateDAOImpl.java index 52aeacec..88455581 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/CertificateDAOImpl.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/CertificateDAOImpl.java @@ -239,7 +239,7 @@ public class CertificateDAOImpl implements CertificateDAO { return dn.replace(" ", "_").toLowerCase(); } } catch (final CertificateEncodingException e) { - log.warn("Error while trying to get alias form certificate subject name. Use serial number as alias"); + log.warn("Error while trying to get alias from certificate subject name. Use serial number as alias"); return String.valueOf(certificate.getSerialNumber()); } } diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ExamDAOImpl.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ExamDAOImpl.java index 448ed0af..80b880ed 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ExamDAOImpl.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/dao/impl/ExamDAOImpl.java @@ -187,9 +187,9 @@ public class ExamDAOImpl implements ExamDAO { public void markLMSAvailability(final String externalQuizId, final boolean available, final String updateId) { if (!available) { - log.info("Mark exam quiz data not available form LMS: {}", externalQuizId); + log.info("Mark exam quiz data not available from LMS: {}", externalQuizId); } else { - log.info("Mark exam quiz data back again form LMS: {}", externalQuizId); + log.info("Mark exam quiz data back again from LMS: {}", externalQuizId); } this.examRecordDAO.idByExternalQuizId(externalQuizId) diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/exam/impl/ExamTemplateServiceImpl.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/exam/impl/ExamTemplateServiceImpl.java index 535af44d..cd0f88a0 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/exam/impl/ExamTemplateServiceImpl.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/exam/impl/ExamTemplateServiceImpl.java @@ -127,7 +127,7 @@ public class ExamTemplateServiceImpl implements ExamTemplateService { if (exam.examTemplateId != null) { if (log.isDebugEnabled()) { - log.debug("Init exam: {} with additional attributes form exam template: {}", + log.debug("Init exam: {} with additional attributes from exam template: {}", exam.externalId, exam.examTemplateId); } diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPIService.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPIService.java index 8ca736fd..285a185e 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPIService.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPIService.java @@ -60,7 +60,7 @@ public interface LmsAPIService { * @param pageSize the page size * @param sort the sort parameter * @param filterMap the FilterMap containing all filter criteria - * @return the specified Page of QuizData form all active LMS Setups of the current users institution */ + * @return the specified Page of QuizData from all active LMS Setups of the current users institution */ Result> requestQuizDataPage( final int pageNumber, final int pageSize, @@ -139,7 +139,7 @@ public interface LmsAPIService { * @param sortAttribute the sort attribute for the new Page * @param pageNumber the number of the Page to build * @param pageSize the size of the Page to build - * @return A Page of QuizData extracted form a given list of QuizData */ + * @return A Page of QuizData extracted from a given list of QuizData */ static Function, Page> quizzesToPageFunction( final String sortAttribute, final int pageNumber, diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPITemplate.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPITemplate.java index f6b7d4ee..d739dd40 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPITemplate.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/LmsAPITemplate.java @@ -12,7 +12,6 @@ import ch.ethz.seb.sebserver.gbl.async.CircuitBreaker; import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup; import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetupTestResult; import ch.ethz.seb.sebserver.webservice.servicelayer.lms.impl.AbstractCachedCourseAccess; -import ch.ethz.seb.sebserver.webservice.servicelayer.lms.impl.AbstractCourseAccess; /** Defines an LMS API access template to build SEB Server LMS integration. *

diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/SEBRestrictionAPI.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/SEBRestrictionAPI.java index ada09e56..a88786ee 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/SEBRestrictionAPI.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/SEBRestrictionAPI.java @@ -23,7 +23,7 @@ public interface SEBRestrictionAPI { * @return {@link LmsSetupTestResult } instance with the test result report */ LmsSetupTestResult testCourseRestrictionAPI(); - /** Get SEB restriction data form LMS within a {@link SEBRestrictionData } instance. The available restriction + /** Get SEB restriction data from LMS within a {@link SEBRestrictionData } instance. The available restriction * details * depends on the type of LMS but shall at least contains the config-key(s) and the browser-exam-key(s). * diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/impl/AbstractCourseAccess.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/impl/AbstractCourseAccess.java deleted file mode 100644 index b374eb59..00000000 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/lms/impl/AbstractCourseAccess.java +++ /dev/null @@ -1,188 +0,0 @@ -/* - * Copyright (c) 2020 ETH Zürich, Educational Development and Technology (LET) - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ - -package ch.ethz.seb.sebserver.webservice.servicelayer.lms.impl; - -import java.util.Collection; -import java.util.List; -import java.util.Set; -import java.util.function.Supplier; - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import org.springframework.core.env.Environment; - -import ch.ethz.seb.sebserver.gbl.Constants; -import ch.ethz.seb.sebserver.gbl.async.AsyncService; -import ch.ethz.seb.sebserver.gbl.async.CircuitBreaker; -import ch.ethz.seb.sebserver.gbl.model.exam.Chapters; -import ch.ethz.seb.sebserver.gbl.model.exam.QuizData; -import ch.ethz.seb.sebserver.gbl.model.user.ExamineeAccountDetails; -import ch.ethz.seb.sebserver.gbl.util.Result; -import ch.ethz.seb.sebserver.webservice.servicelayer.dao.FilterMap; - -/** A partial course access API implementation that uses CircuitBreaker to apply LMS - * API requests in a protected environment. - * - * Extend this to implement a concrete course access API for a given type of LMS. */ -public abstract class AbstractCourseAccess { - - private static final Logger log = LoggerFactory.getLogger(AbstractCourseAccess.class); - - /** CircuitBreaker for protected quiz and course data requests */ - protected final CircuitBreaker> allQuizzesRequest; - /** CircuitBreaker for protected quiz and course data requests */ - protected final CircuitBreaker> quizzesRequest; - /** CircuitBreaker for protected quiz and course data requests */ - protected final CircuitBreaker quizRequest; - /** CircuitBreaker for protected chapter data requests */ - protected final CircuitBreaker chaptersRequest; - /** CircuitBreaker for protected examinee account details requests */ - protected final CircuitBreaker accountDetailRequest; - - protected AbstractCourseAccess( - final AsyncService asyncService, - final Environment environment) { - - this.allQuizzesRequest = asyncService.createCircuitBreaker( - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.attempts", - Integer.class, - 3), - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.blockingTime", - Long.class, - Constants.MINUTE_IN_MILLIS), - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.timeToRecover", - Long.class, - Constants.MINUTE_IN_MILLIS)); - - this.quizzesRequest = asyncService.createCircuitBreaker( - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.attempts", - Integer.class, - 3), - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.blockingTime", - Long.class, - Constants.SECOND_IN_MILLIS * 10), - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.timeToRecover", - Long.class, - Constants.MINUTE_IN_MILLIS)); - - this.quizRequest = asyncService.createCircuitBreaker( - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.attempts", - Integer.class, - 3), - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.blockingTime", - Long.class, - Constants.SECOND_IN_MILLIS * 10), - environment.getProperty( - "sebserver.webservice.circuitbreaker.quizzesRequest.timeToRecover", - Long.class, - Constants.MINUTE_IN_MILLIS)); - - this.chaptersRequest = asyncService.createCircuitBreaker( - environment.getProperty( - "sebserver.webservice.circuitbreaker.chaptersRequest.attempts", - Integer.class, - 3), - environment.getProperty( - "sebserver.webservice.circuitbreaker.chaptersRequest.blockingTime", - Long.class, - Constants.SECOND_IN_MILLIS * 10), - environment.getProperty( - "sebserver.webservice.circuitbreaker.chaptersRequest.timeToRecover", - Long.class, - Constants.SECOND_IN_MILLIS * 30)); - - this.accountDetailRequest = asyncService.createCircuitBreaker( - environment.getProperty( - "sebserver.webservice.circuitbreaker.accountDetailRequest.attempts", - Integer.class, - 2), - environment.getProperty( - "sebserver.webservice.circuitbreaker.accountDetailRequest.blockingTime", - Long.class, - Constants.SECOND_IN_MILLIS * 10), - environment.getProperty( - "sebserver.webservice.circuitbreaker.accountDetailRequest.timeToRecover", - Long.class, - Constants.SECOND_IN_MILLIS * 30)); - } - - public Result> protectedQuizzesRequest(final FilterMap filterMap) { - return this.allQuizzesRequest.protectedRun(allQuizzesSupplier(filterMap)) - .onError(error -> log.error( - "Failed to run protectedQuizzesRequest: {}", - error.getMessage())); - } - - public Result> protectedQuizzesRequest(final Set ids) { - return this.quizzesRequest.protectedRun(quizzesSupplier(ids)) - .onError(error -> log.error( - "Failed to run protectedQuizzesRequest: {}", - error.getMessage())); - } - - public Result protectedQuizRequest(final String id) { - return this.quizRequest.protectedRun(quizSupplier(id)) - .onError(error -> log.error( - "Failed to run protectedQuizRequest: {}", - error.getMessage())); - } - - public Result getExamineeAccountDetails(final String examineeSessionId) { - final Supplier accountDetailsSupplier = accountDetailsSupplier(examineeSessionId); - return this.accountDetailRequest.protectedRun(() -> { - try { - return accountDetailsSupplier.get(); - } catch (final Exception e) { - log.error("Unexpected error while trying to get examinee account details: ", e); - throw e; - } - }); - } - - /** Default implementation that uses getExamineeAccountDetails to geht the examinee name - * - * @param examineeSessionId - * @return The examinee account name for the given examineeSessionId */ - public String getExamineeName(final String examineeSessionId) { - return getExamineeAccountDetails(examineeSessionId) - .map(ExamineeAccountDetails::getDisplayName) - .onError(error -> log.warn("Failed to request user-name for ID: {}", error.getMessage(), error)) - .getOr(examineeSessionId); - } - - public Result getCourseChapters(final String courseId) { - return this.chaptersRequest.protectedRun(getCourseChaptersSupplier(courseId)) - .onError(error -> log.error( - "Failed to run getCourseChapters: {}", - error.getMessage())); - } - - protected abstract Supplier accountDetailsSupplier(final String examineeSessionId); - - /** Provides a supplier to supply request to use within the circuit breaker */ - protected abstract Supplier> allQuizzesSupplier(final FilterMap filterMap); - - /** Provides a supplier for the quiz data request to use within the circuit breaker */ - protected abstract Supplier> quizzesSupplier(final Set ids); - - /** Provides a supplier for the quiz data request to use within the circuit breaker */ - protected abstract Supplier quizSupplier(final String id); - - /** Provides a supplier for the course chapter data request to use within the circuit breaker */ - protected abstract Supplier getCourseChaptersSupplier(final String courseId); - -} diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionControlTask.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionControlTask.java index 6b72916f..e028ef35 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionControlTask.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamSessionControlTask.java @@ -151,7 +151,7 @@ public class ExamSessionControlTask implements DisposableBean { private void controlExamLMSUpdate() { if (log.isTraceEnabled()) { - log.trace("Start update exams form LMS"); + log.trace("Start update exams from LMS"); } try { diff --git a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamUpdateHandler.java b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamUpdateHandler.java index e3730943..83f1b9ba 100644 --- a/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamUpdateHandler.java +++ b/src/main/java/ch/ethz/seb/sebserver/webservice/servicelayer/session/impl/ExamUpdateHandler.java @@ -91,7 +91,7 @@ class ExamUpdateHandler { .getLmsAPITemplate(lmsSetupId) .flatMap(template -> template.getQuizzes(new HashSet<>(exams.keySet()))) .onError(error -> log.warn( - "Failed to get quizzes form LMS Setup: {} cause: {}", + "Failed to get quizzes from LMS Setup: {} cause: {}", lmsSetupId, error.getMessage())) .getOr(Collections.emptyList())