SEBSERV-46 created Domain Model
This commit is contained in:
parent
fb6894e17c
commit
489b61a4d5
34 changed files with 1148 additions and 156 deletions
|
@ -18,6 +18,7 @@ import org.joda.time.DateTimeZone;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
@ -26,6 +27,7 @@ import ch.ethz.seb.sebserver.gbl.model.Activatable;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Domain.EXAM;
|
import ch.ethz.seb.sebserver.gbl.model.Domain.EXAM;
|
||||||
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public final class Exam implements GrantEntity, Activatable {
|
public final class Exam implements GrantEntity, Activatable {
|
||||||
|
|
||||||
public static final String ATTR_STATUS = "examStatus";
|
public static final String ATTR_STATUS = "examStatus";
|
||||||
|
@ -243,31 +245,6 @@ public final class Exam implements GrantEntity, Activatable {
|
||||||
return this.active;
|
return this.active;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((this.id == null) ? 0 : this.id.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final Exam other = (Exam) obj;
|
|
||||||
if (this.id == null) {
|
|
||||||
if (other.id != null)
|
|
||||||
return false;
|
|
||||||
} else if (!this.id.equals(other.id))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Exam [id=" + this.id + ", institutionId=" + this.institutionId + ", lmsSetupId=" + this.lmsSetupId
|
return "Exam [id=" + this.id + ", institutionId=" + this.institutionId + ", lmsSetupId=" + this.lmsSetupId
|
||||||
|
|
|
@ -15,6 +15,7 @@ import javax.validation.constraints.NotNull;
|
||||||
import javax.validation.constraints.Size;
|
import javax.validation.constraints.Size;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator;
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
@ -26,6 +27,7 @@ import ch.ethz.seb.sebserver.gbl.model.Domain.THRESHOLD;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Utils;
|
import ch.ethz.seb.sebserver.gbl.util.Utils;
|
||||||
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public final class Indicator implements GrantEntity {
|
public final class Indicator implements GrantEntity {
|
||||||
|
|
||||||
public static final String FILTER_ATTR_EXAM = "exam";
|
public static final String FILTER_ATTR_EXAM = "exam";
|
||||||
|
@ -61,6 +63,7 @@ public final class Indicator implements GrantEntity {
|
||||||
@JsonProperty(THRESHOLD.REFERENCE_NAME)
|
@JsonProperty(THRESHOLD.REFERENCE_NAME)
|
||||||
public final List<Threshold> thresholds;
|
public final List<Threshold> thresholds;
|
||||||
|
|
||||||
|
@JsonProperty(EXAM.ATTR_OWNER)
|
||||||
public final String examOwner;
|
public final String examOwner;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
|
@ -154,13 +157,6 @@ public final class Indicator implements GrantEntity {
|
||||||
|
|
||||||
public static final class Threshold {
|
public static final class Threshold {
|
||||||
|
|
||||||
// @JsonProperty(THRESHOLD.ATTR_ID)
|
|
||||||
// public final Long id;
|
|
||||||
//
|
|
||||||
// @JsonProperty(THRESHOLD.ATTR_INDICATOR_ID)
|
|
||||||
// @NotNull
|
|
||||||
// public final Long indicatorId;
|
|
||||||
|
|
||||||
@JsonProperty(THRESHOLD.ATTR_VALUE)
|
@JsonProperty(THRESHOLD.ATTR_VALUE)
|
||||||
@NotNull
|
@NotNull
|
||||||
public final Double value;
|
public final Double value;
|
||||||
|
@ -170,25 +166,13 @@ public final class Indicator implements GrantEntity {
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
public Threshold(
|
public Threshold(
|
||||||
// @JsonProperty(THRESHOLD.ATTR_ID) final Long id,
|
|
||||||
// @JsonProperty(THRESHOLD.ATTR_INDICATOR_ID) final Long indicatorId,
|
|
||||||
@JsonProperty(THRESHOLD.ATTR_VALUE) final Double value,
|
@JsonProperty(THRESHOLD.ATTR_VALUE) final Double value,
|
||||||
@JsonProperty(THRESHOLD.ATTR_COLOR) final String color) {
|
@JsonProperty(THRESHOLD.ATTR_COLOR) final String color) {
|
||||||
|
|
||||||
// this.id = id;
|
|
||||||
// this.indicatorId = indicatorId;
|
|
||||||
this.value = value;
|
this.value = value;
|
||||||
this.color = color;
|
this.color = color;
|
||||||
}
|
}
|
||||||
|
|
||||||
// public Long getId() {
|
|
||||||
// return this.id;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// public Long getIndicatorId() {
|
|
||||||
// return this.indicatorId;
|
|
||||||
// }
|
|
||||||
|
|
||||||
public Double getValue() {
|
public Double getValue() {
|
||||||
return this.value;
|
return this.value;
|
||||||
}
|
}
|
||||||
|
@ -197,12 +181,10 @@ public final class Indicator implements GrantEntity {
|
||||||
return this.color;
|
return this.color;
|
||||||
}
|
}
|
||||||
|
|
||||||
// @Override
|
@Override
|
||||||
// public String toString() {
|
public String toString() {
|
||||||
// return "Threshold [id=" + this.id + ", indicatorId=" + this.indicatorId + ", value=" + this.value
|
return "Threshold [value=" + this.value + ", color=" + this.color + "]";
|
||||||
// + ", color=" + this.color
|
}
|
||||||
// + "]";
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -149,11 +149,6 @@ public final class QuizData implements GrantEntity {
|
||||||
return this.lmsType;
|
return this.lmsType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getOwnerId() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return this.name;
|
return this.name;
|
||||||
|
@ -175,37 +170,6 @@ public final class QuizData implements GrantEntity {
|
||||||
return this.startURL;
|
return this.startURL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((this.id == null) ? 0 : this.id.hashCode());
|
|
||||||
result = prime * result + ((this.institutionId == null) ? 0 : this.institutionId.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final QuizData other = (QuizData) obj;
|
|
||||||
if (this.id == null) {
|
|
||||||
if (other.id != null)
|
|
||||||
return false;
|
|
||||||
} else if (!this.id.equals(other.id))
|
|
||||||
return false;
|
|
||||||
if (this.institutionId == null) {
|
|
||||||
if (other.institutionId != null)
|
|
||||||
return false;
|
|
||||||
} else if (!this.institutionId.equals(other.institutionId))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "QuizData [id=" + this.id + ", institutionId=" + this.institutionId + ", lmsSetupId=" + this.lmsSetupId
|
return "QuizData [id=" + this.id + ", institutionId=" + this.institutionId + ", lmsSetupId=" + this.lmsSetupId
|
||||||
|
|
|
@ -94,11 +94,6 @@ public final class Institution implements GrantEntity, Activatable {
|
||||||
return this.id;
|
return this.id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getOwnerId() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return this.name;
|
return this.name;
|
||||||
|
|
|
@ -26,6 +26,7 @@ import ch.ethz.seb.sebserver.gbl.model.Domain.LMS_SETUP;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityName;
|
import ch.ethz.seb.sebserver.gbl.model.EntityName;
|
||||||
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public final class LmsSetup implements GrantEntity, Activatable {
|
public final class LmsSetup implements GrantEntity, Activatable {
|
||||||
|
|
||||||
public static final String FILTER_ATTR_LMS_SETUP = "lms_setup";
|
public static final String FILTER_ATTR_LMS_SETUP = "lms_setup";
|
||||||
|
@ -70,7 +71,6 @@ public final class LmsSetup implements GrantEntity, Activatable {
|
||||||
public final Boolean active;
|
public final Boolean active;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
|
||||||
public LmsSetup(
|
public LmsSetup(
|
||||||
@JsonProperty(LMS_SETUP.ATTR_ID) final Long id,
|
@JsonProperty(LMS_SETUP.ATTR_ID) final Long id,
|
||||||
@JsonProperty(LMS_SETUP.ATTR_INSTITUTION_ID) final Long institutionId,
|
@JsonProperty(LMS_SETUP.ATTR_INSTITUTION_ID) final Long institutionId,
|
||||||
|
@ -110,12 +110,6 @@ public final class LmsSetup implements GrantEntity, Activatable {
|
||||||
return EntityType.LMS_SETUP;
|
return EntityType.LMS_SETUP;
|
||||||
}
|
}
|
||||||
|
|
||||||
@JsonIgnore
|
|
||||||
@Override
|
|
||||||
public String getOwnerId() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getId() {
|
public Long getId() {
|
||||||
return this.id;
|
return this.id;
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,11 +83,6 @@ public final class SebClientConfig implements GrantEntity, Activatable {
|
||||||
return this.institutionId;
|
return this.institutionId;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getOwnerId() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getId() {
|
public Long getId() {
|
||||||
return this.id;
|
return this.id;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import static ch.ethz.seb.sebserver.gbl.model.sebconfig.AttributeValueType.*;
|
||||||
|
|
||||||
|
/** Enumeration of known SEB configuration attribute types */
|
||||||
|
public enum AttributeType {
|
||||||
|
/** Single read-only label */
|
||||||
|
LABEL(NONE),
|
||||||
|
/** Single lined text value */
|
||||||
|
TEXT_FIELD(TEXT),
|
||||||
|
/** Multiple lined text value */
|
||||||
|
TEXT_AREA(TEXT),
|
||||||
|
/** Check Box or boolean type */
|
||||||
|
CHECKBOX(TEXT),
|
||||||
|
/** Check Box or boolean type without label (e.g.: used in a table) */
|
||||||
|
CHECK_FIELD(TEXT),
|
||||||
|
|
||||||
|
/** Integer number type */
|
||||||
|
INTEGER(TEXT),
|
||||||
|
/** Decimal number type */
|
||||||
|
DECIMAL(TEXT),
|
||||||
|
/** Single selection type (Drop-down) */
|
||||||
|
SINGLE_SELECTION(TEXT),
|
||||||
|
/** Multiple selection type */
|
||||||
|
MULTI_SELECTION(LIST),
|
||||||
|
/** Radio selection type (like single selection but with check-boxes) */
|
||||||
|
RADIO_SELECTION(TEXT),
|
||||||
|
|
||||||
|
FILE_UPLOAD(BASE64_BINARY),
|
||||||
|
|
||||||
|
/** Table type is a list of composite */
|
||||||
|
TABLE(COMPOSITE_LIST),
|
||||||
|
;
|
||||||
|
|
||||||
|
public final AttributeValueType attributeValueType;
|
||||||
|
|
||||||
|
private AttributeType(final AttributeValueType attributeValueType) {
|
||||||
|
this.attributeValueType = attributeValueType;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
/** Enumeration of known SEB configuration attribute value types */
|
||||||
|
public enum AttributeValueType {
|
||||||
|
/** Not defined or unknown */
|
||||||
|
NONE,
|
||||||
|
/** Short text (255 chars) */
|
||||||
|
TEXT,
|
||||||
|
/** Large texts MEDIUMTEXT */
|
||||||
|
LARGE_TEXT,
|
||||||
|
/** Base 64 encoded binary data */
|
||||||
|
BASE64_BINARY,
|
||||||
|
/** A list of single values of the same type */
|
||||||
|
LIST,
|
||||||
|
/** A composite of different typed values like a Map or Dictionary */
|
||||||
|
COMPOSITE,
|
||||||
|
/** A list of composites of the same type like a Table */
|
||||||
|
COMPOSITE_LIST
|
||||||
|
}
|
|
@ -0,0 +1,118 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
|
import org.joda.time.DateTime;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.Constants;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.CONFIGURATION;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.CONFIGURATION_NODE;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class Configuration implements GrantEntity {
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_ID)
|
||||||
|
public final Long id;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_INSTITUTION_ID)
|
||||||
|
public final Long institutionId;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_CONFIGURATION_NODE_ID)
|
||||||
|
public final Long nodeId;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_VERSION)
|
||||||
|
public final String version;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_VERSION_DATE)
|
||||||
|
public final DateTime versionDate;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_FOLLOWUP)
|
||||||
|
public final Boolean followup;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public Configuration(
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_ID) final Long id,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_INSTITUTION_ID) final Long institutionId,
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_CONFIGURATION_NODE_ID) final Long nodeId,
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_VERSION) final String version,
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_VERSION_DATE) final DateTime versionDate,
|
||||||
|
@JsonProperty(CONFIGURATION.ATTR_FOLLOWUP) final Boolean followup) {
|
||||||
|
|
||||||
|
this.id = id;
|
||||||
|
this.institutionId = institutionId;
|
||||||
|
this.nodeId = nodeId;
|
||||||
|
this.version = version;
|
||||||
|
this.versionDate = versionDate;
|
||||||
|
this.followup = followup;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.CONFIGURATION;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName() {
|
||||||
|
return (this.version != null)
|
||||||
|
? this.version
|
||||||
|
: this.versionDate.toString(Constants.DEFAULT_DISPLAY_DATE_FORMAT);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getModelId() {
|
||||||
|
return (this.id != null)
|
||||||
|
? String.valueOf(this.id)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Long getInstitutionId() {
|
||||||
|
return this.institutionId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return this.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getNodeId() {
|
||||||
|
return this.nodeId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getVersion() {
|
||||||
|
return this.version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DateTime getVersionDate() {
|
||||||
|
return this.versionDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean getFollowup() {
|
||||||
|
return this.followup;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Configuration [id=" + this.id + ", nodeId=" + this.nodeId + ", version=" + this.version
|
||||||
|
+ ", versionDate="
|
||||||
|
+ this.versionDate + ", followup=" + this.followup + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,118 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.CONFIGURATION_ATTRIBUTE;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class ConfigurationAttribute implements Entity {
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_ID)
|
||||||
|
public final Long id;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_PARENT_ID)
|
||||||
|
public final Long parentId;
|
||||||
|
|
||||||
|
@NotNull(message = "configurationAttribute:name:notNull")
|
||||||
|
@Size(min = 3, max = 255, message = "configurationAttribute:name:size:{min}:{max}:${validatedValue}")
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_NAME)
|
||||||
|
public final String name;
|
||||||
|
|
||||||
|
@NotNull(message = "configurationAttribute:type:notNull")
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_TYPE)
|
||||||
|
public final AttributeType type;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_RESOURCES)
|
||||||
|
public final String resources;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_DEPENDENCIES)
|
||||||
|
public final String dependencies;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_DEFAULT_VALUE)
|
||||||
|
public final String defaultValue;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public ConfigurationAttribute(
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_ID) final Long id,
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_PARENT_ID) final Long parentId,
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_NAME) final String name,
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_TYPE) final AttributeType type,
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_RESOURCES) final String resources,
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_DEPENDENCIES) final String dependencies,
|
||||||
|
@JsonProperty(CONFIGURATION_ATTRIBUTE.ATTR_DEFAULT_VALUE) final String defaultValue) {
|
||||||
|
|
||||||
|
this.id = id;
|
||||||
|
this.parentId = parentId;
|
||||||
|
this.name = name;
|
||||||
|
this.type = type;
|
||||||
|
this.resources = resources;
|
||||||
|
this.dependencies = dependencies;
|
||||||
|
this.defaultValue = defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getModelId() {
|
||||||
|
return (this.id != null)
|
||||||
|
? String.valueOf(this.id)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.CONFIGURATION_ATTRIBUTE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return this.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getParentId() {
|
||||||
|
return this.parentId;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public AttributeType getType() {
|
||||||
|
return this.type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getResources() {
|
||||||
|
return this.resources;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDependencies() {
|
||||||
|
return this.dependencies;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDefaultValue() {
|
||||||
|
return this.defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "ConfigurationAttribute [id=" + this.id + ", parentId=" + this.parentId + ", name=" + this.name
|
||||||
|
+ ", type=" + this.type
|
||||||
|
+ ", resources=" + this.resources + ", dependencies=" + this.dependencies + ", defaultValue="
|
||||||
|
+ this.defaultValue
|
||||||
|
+ "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,125 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.CONFIGURATION_NODE;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class ConfigurationNode implements GrantEntity {
|
||||||
|
|
||||||
|
public enum ConfigurationType {
|
||||||
|
TEMPLATE,
|
||||||
|
EXAM_CONFIG
|
||||||
|
}
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_ID)
|
||||||
|
public final Long id;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_INSTITUTION_ID)
|
||||||
|
public final Long institutionId;
|
||||||
|
|
||||||
|
@NotNull(message = "configurationNode:name:notNull")
|
||||||
|
@Size(min = 3, max = 255, message = "configurationNode:name:size:{min}:{max}:${validatedValue}")
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_NAME)
|
||||||
|
public final String name;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_DESCRIPTION)
|
||||||
|
public final String description;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_TYPE)
|
||||||
|
public final ConfigurationType type;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_TEMPLATE)
|
||||||
|
public final String templateName;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_OWNER)
|
||||||
|
public final String owner;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public ConfigurationNode(
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_ID) final Long id,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_INSTITUTION_ID) final Long institutionId,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_NAME) final String name,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_DESCRIPTION) final String description,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_TYPE) final ConfigurationType type,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_TEMPLATE) final String templateName,
|
||||||
|
@JsonProperty(CONFIGURATION_NODE.ATTR_OWNER) final String owner) {
|
||||||
|
|
||||||
|
this.id = id;
|
||||||
|
this.institutionId = institutionId;
|
||||||
|
this.name = name;
|
||||||
|
this.description = description;
|
||||||
|
this.type = type;
|
||||||
|
this.templateName = templateName;
|
||||||
|
this.owner = owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.CONFIGURATION_NODE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return this.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getModelId() {
|
||||||
|
return (this.id != null)
|
||||||
|
? String.valueOf(this.id)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Long getInstitutionId() {
|
||||||
|
return this.institutionId;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getOwnerId() {
|
||||||
|
return this.owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDescription() {
|
||||||
|
return this.description;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ConfigurationType getType() {
|
||||||
|
return this.type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTemplateName() {
|
||||||
|
return this.templateName;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "ConfigurationNode [id=" + this.id + ", institutionId=" + this.institutionId + ", name=" + this.name
|
||||||
|
+ ", description="
|
||||||
|
+ this.description + ", type=" + this.type + ", templateName=" + this.templateName + ", owner="
|
||||||
|
+ this.owner + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,73 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.CONFIGURATION_VALUE;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class ConfigurationTableValue {
|
||||||
|
|
||||||
|
public static final String ATTR_COLUMNS = "columnAttributeIds";
|
||||||
|
public static final String ATTR_VALUES = "values";
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ID)
|
||||||
|
public final Long configurationId;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ATTRIBUTE_ID)
|
||||||
|
public final long attributeId;
|
||||||
|
|
||||||
|
@JsonProperty(ATTR_COLUMNS)
|
||||||
|
public final List<Long> columnAttributeIds;
|
||||||
|
|
||||||
|
@JsonProperty(ATTR_VALUES)
|
||||||
|
public final List<String> values;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public ConfigurationTableValue(
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ID) final Long configurationId,
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ATTRIBUTE_ID) final Long attributeId,
|
||||||
|
@JsonProperty(ATTR_COLUMNS) final List<Long> columns,
|
||||||
|
@JsonProperty(ATTR_VALUES) final List<String> values) {
|
||||||
|
|
||||||
|
this.configurationId = configurationId;
|
||||||
|
this.attributeId = attributeId;
|
||||||
|
this.columnAttributeIds = Collections.unmodifiableList(columns);
|
||||||
|
this.values = Collections.unmodifiableList(values);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getConfigurationId() {
|
||||||
|
return this.configurationId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getAttributeId() {
|
||||||
|
return this.attributeId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Long> getColumnAttributeIds() {
|
||||||
|
return this.columnAttributeIds;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<String> getValues() {
|
||||||
|
return this.values;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "ConfigurationTableValue [configurationId=" + this.configurationId + ", attributeId=" + this.attributeId
|
||||||
|
+ ", columnAttributeIds=" + this.columnAttributeIds + ", values=" + this.values + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,96 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.CONFIGURATION_VALUE;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class ConfigurationValue implements Entity {
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_ID)
|
||||||
|
public final Long id;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ID)
|
||||||
|
public final Long configurationId;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ATTRIBUTE_ID)
|
||||||
|
public final long attributeId;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_LIST_INDEX)
|
||||||
|
public final Integer listIndex;
|
||||||
|
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_VALUE)
|
||||||
|
public final String value;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public ConfigurationValue(
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_ID) final Long id,
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ID) final Long configurationId,
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_CONFIGURATION_ATTRIBUTE_ID) final Long attributeId,
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_LIST_INDEX) final Integer listIndex,
|
||||||
|
@JsonProperty(CONFIGURATION_VALUE.ATTR_VALUE) final String value) {
|
||||||
|
|
||||||
|
this.id = id;
|
||||||
|
this.configurationId = configurationId;
|
||||||
|
this.attributeId = attributeId;
|
||||||
|
this.listIndex = listIndex;
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getModelId() {
|
||||||
|
return (this.id != null)
|
||||||
|
? String.valueOf(this.id)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.CONFIGURATION_VALUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName() {
|
||||||
|
return getModelId();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return this.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getConfigurationId() {
|
||||||
|
return this.configurationId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getAttributeId() {
|
||||||
|
return this.attributeId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getListIndex() {
|
||||||
|
return this.listIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getValue() {
|
||||||
|
return this.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "ConfigurationValue [id=" + this.id + ", configurationId=" + this.configurationId + ", attributeId="
|
||||||
|
+ this.attributeId
|
||||||
|
+ ", listIndex=" + this.listIndex + ", value=" + this.value + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,102 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.EXAM;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.EXAM_CONFIGURATION_MAP;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class ExamConfiguration implements GrantEntity {
|
||||||
|
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_ID)
|
||||||
|
public final Long id;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(EXAM.ATTR_INSTITUTION_ID)
|
||||||
|
public final Long institutionId;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_EXAM_ID)
|
||||||
|
public final Long examId;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_CONFIGURATION_NODE_ID)
|
||||||
|
public final Long configurationNodeId;
|
||||||
|
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_USER_NAMES)
|
||||||
|
public final String userNames;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public ExamConfiguration(
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_ID) final Long id,
|
||||||
|
@JsonProperty(EXAM.ATTR_INSTITUTION_ID) final Long institutionId,
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_EXAM_ID) final Long examId,
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_CONFIGURATION_NODE_ID) final Long configurationNodeId,
|
||||||
|
@JsonProperty(EXAM_CONFIGURATION_MAP.ATTR_USER_NAMES) final String userNames) {
|
||||||
|
|
||||||
|
this.id = id;
|
||||||
|
this.institutionId = institutionId;
|
||||||
|
this.examId = examId;
|
||||||
|
this.configurationNodeId = configurationNodeId;
|
||||||
|
this.userNames = userNames;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.EXAM_CONFIGURATION_MAP;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName() {
|
||||||
|
return getModelId();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getModelId() {
|
||||||
|
return (this.id != null)
|
||||||
|
? String.valueOf(this.id)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Long getInstitutionId() {
|
||||||
|
return this.institutionId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return this.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getExamId() {
|
||||||
|
return this.examId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getConfigurationNodeId() {
|
||||||
|
return this.configurationNodeId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getUserNames() {
|
||||||
|
return this.userNames;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "ExamConfiguration [id=" + this.id + ", institutionId=" + this.institutionId + ", examId=" + this.examId
|
||||||
|
+ ", configurationNodeId=" + this.configurationNodeId + ", userNames=" + this.userNames + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,141 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 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.gbl.model.sebconfig;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonCreator;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Domain.ORIENTATION;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
|
public final class Orientation implements Entity {
|
||||||
|
|
||||||
|
public static final String FILTER_ATTR_TEMPLATE = "template";
|
||||||
|
public static final String FILTER_ATTR_VIEW = "view";
|
||||||
|
public static final String FILTER_ATTR_GROUP = "group";
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_ID)
|
||||||
|
public final Long id;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_CONFIG_ATTRIBUTE_ID)
|
||||||
|
public final Long attributeId;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_TEMPLATE)
|
||||||
|
public final String template;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_VIEW)
|
||||||
|
public final String view;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_GROUP)
|
||||||
|
public final String group;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_X_POSITION)
|
||||||
|
public final Integer xPosition;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_Y_POSITION)
|
||||||
|
public final Integer yPosition;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_WIDTH)
|
||||||
|
public final Integer width;
|
||||||
|
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_HEIGHT)
|
||||||
|
public final Integer height;
|
||||||
|
|
||||||
|
@JsonCreator
|
||||||
|
public Orientation(
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_ID) final Long id,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_CONFIG_ATTRIBUTE_ID) final Long attributeId,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_TEMPLATE) final String template,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_VIEW) final String view,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_GROUP) final String group,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_X_POSITION) final Integer xPosition,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_Y_POSITION) final Integer yPosition,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_WIDTH) final Integer width,
|
||||||
|
@JsonProperty(ORIENTATION.ATTR_HEIGHT) final Integer height) {
|
||||||
|
|
||||||
|
this.id = id;
|
||||||
|
this.attributeId = attributeId;
|
||||||
|
this.template = template;
|
||||||
|
this.view = view;
|
||||||
|
this.group = group;
|
||||||
|
this.xPosition = xPosition;
|
||||||
|
this.yPosition = yPosition;
|
||||||
|
this.width = width;
|
||||||
|
this.height = height;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getModelId() {
|
||||||
|
return (this.id != null)
|
||||||
|
? String.valueOf(this.id)
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.ORIENTATION;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName() {
|
||||||
|
return getModelId();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return this.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Long getAttributeId() {
|
||||||
|
return this.attributeId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTemplate() {
|
||||||
|
return this.template;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getView() {
|
||||||
|
return this.view;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getGroup() {
|
||||||
|
return this.group;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getXPosition() {
|
||||||
|
return this.xPosition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getYPosition() {
|
||||||
|
return this.yPosition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getWidth() {
|
||||||
|
return this.width;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getHeight() {
|
||||||
|
return this.height;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Orientation [id=" + this.id + ", attributeId=" + this.attributeId + ", template=" + this.template
|
||||||
|
+ ", view=" + this.view
|
||||||
|
+ ", group=" + this.group + ", xPosition=" + this.xPosition + ", yPosition=" + this.yPosition
|
||||||
|
+ ", width=" + this.width
|
||||||
|
+ ", height=" + this.height + "]";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -17,37 +17,46 @@ import org.joda.time.DateTimeZone;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
import ch.ethz.seb.sebserver.webservice.servicelayer.authorization.GrantEntity;
|
||||||
|
|
||||||
|
/** Defines a User-Account object */
|
||||||
public interface UserAccount extends GrantEntity {
|
public interface UserAccount extends GrantEntity {
|
||||||
|
|
||||||
|
/** The model id of the User-Account (UUID) */
|
||||||
@Override
|
@Override
|
||||||
String getModelId();
|
String getModelId();
|
||||||
|
|
||||||
|
/** The institution identifier where the User-Account belongs to */
|
||||||
@Override
|
@Override
|
||||||
Long getInstitutionId();
|
Long getInstitutionId();
|
||||||
|
|
||||||
|
/** The name of the User-Account */
|
||||||
@Override
|
@Override
|
||||||
String getName();
|
String getName();
|
||||||
|
|
||||||
|
/** The user-name or login-name of the User-Account */
|
||||||
String getUsername();
|
String getUsername();
|
||||||
|
|
||||||
|
/** The email of the User-Account */
|
||||||
String getEmail();
|
String getEmail();
|
||||||
|
|
||||||
|
/** Indicates whether the User-Account is active or not */
|
||||||
Boolean getActive();
|
Boolean getActive();
|
||||||
|
|
||||||
|
/** Indicates whether the User-Account is active or not */
|
||||||
boolean isActive();
|
boolean isActive();
|
||||||
|
|
||||||
|
/** The language of the User-Account */
|
||||||
Locale getLanguage();
|
Locale getLanguage();
|
||||||
|
|
||||||
|
/** The time-zone of the User-Account */
|
||||||
DateTimeZone getTimeZone();
|
DateTimeZone getTimeZone();
|
||||||
|
|
||||||
|
/** The roles of the User-Account */
|
||||||
Set<String> getRoles();
|
Set<String> getRoles();
|
||||||
|
|
||||||
|
/** The roles of the User-Account as UerRole */
|
||||||
EnumSet<UserRole> getUserRoles();
|
EnumSet<UserRole> getUserRoles();
|
||||||
|
|
||||||
String getNewPassword();
|
/** The EntityKey (ModelId plus EntityType) of the User-Account */
|
||||||
|
|
||||||
String getRetypedNewPassword();
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
EntityKey getEntityKey();
|
EntityKey getEntityKey();
|
||||||
|
|
||||||
|
|
|
@ -41,6 +41,7 @@ import ch.ethz.seb.sebserver.gbl.util.Utils;
|
||||||
* to and from JSON within the Jackson library.
|
* to and from JSON within the Jackson library.
|
||||||
*
|
*
|
||||||
* This domain model is immutable and thread-save */
|
* This domain model is immutable and thread-save */
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public final class UserInfo implements UserAccount, Activatable, Serializable {
|
public final class UserInfo implements UserAccount, Activatable, Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = 2526446136264377808L;
|
private static final long serialVersionUID = 2526446136264377808L;
|
||||||
|
@ -98,7 +99,6 @@ public final class UserInfo implements UserAccount, Activatable, Serializable {
|
||||||
public final Set<String> roles;
|
public final Set<String> roles;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
|
||||||
public UserInfo(
|
public UserInfo(
|
||||||
@JsonProperty(USER.ATTR_UUID) final String uuid,
|
@JsonProperty(USER.ATTR_UUID) final String uuid,
|
||||||
@JsonProperty(USER.ATTR_INSTITUTION_ID) final Long institutionId,
|
@JsonProperty(USER.ATTR_INSTITUTION_ID) final Long institutionId,
|
||||||
|
@ -201,18 +201,6 @@ public final class UserInfo implements UserAccount, Activatable, Serializable {
|
||||||
return this.roles.contains(userRole.name());
|
return this.roles.contains(userRole.name());
|
||||||
}
|
}
|
||||||
|
|
||||||
@JsonIgnore
|
|
||||||
@Override
|
|
||||||
public String getNewPassword() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonIgnore
|
|
||||||
@Override
|
|
||||||
public String getRetypedNewPassword() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
@Override
|
@Override
|
||||||
public EntityKey getEntityKey() {
|
public EntityKey getEntityKey() {
|
||||||
|
@ -222,36 +210,11 @@ public final class UserInfo implements UserAccount, Activatable, Serializable {
|
||||||
return new EntityKey(this.uuid, entityType());
|
return new EntityKey(this.uuid, entityType());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((this.uuid == null) ? 0 : this.uuid.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Object clone() throws CloneNotSupportedException {
|
protected Object clone() throws CloneNotSupportedException {
|
||||||
return UserInfo.of(this);
|
return UserInfo.of(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final UserInfo other = (UserInfo) obj;
|
|
||||||
if (this.uuid == null) {
|
|
||||||
if (other.uuid != null)
|
|
||||||
return false;
|
|
||||||
} else if (!this.uuid.equals(other.uuid))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "UserInfo [uuid=" + this.uuid + ", institutionId=" + this.institutionId + ", name=" + this.name
|
return "UserInfo [uuid=" + this.uuid + ", institutionId=" + this.institutionId + ", name=" + this.name
|
||||||
|
|
|
@ -34,8 +34,10 @@ import ch.ethz.seb.sebserver.gbl.model.Domain.USER;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Domain.USER_ROLE;
|
import ch.ethz.seb.sebserver.gbl.model.Domain.USER_ROLE;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
|
|
||||||
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public final class UserMod implements UserAccount {
|
public final class UserMod implements UserAccount {
|
||||||
|
|
||||||
|
@JsonProperty(USER.ATTR_UUID)
|
||||||
public final String uuid;
|
public final String uuid;
|
||||||
|
|
||||||
/** The foreign key identifier to the institution where the User belongs to */
|
/** The foreign key identifier to the institution where the User belongs to */
|
||||||
|
@ -86,7 +88,6 @@ public final class UserMod implements UserAccount {
|
||||||
private final String confirmNewPassword;
|
private final String confirmNewPassword;
|
||||||
|
|
||||||
@JsonCreator
|
@JsonCreator
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
|
||||||
public UserMod(
|
public UserMod(
|
||||||
@JsonProperty(USER.ATTR_UUID) final String uuid,
|
@JsonProperty(USER.ATTR_UUID) final String uuid,
|
||||||
@JsonProperty(USER.ATTR_INSTITUTION_ID) final Long institutionId,
|
@JsonProperty(USER.ATTR_INSTITUTION_ID) final Long institutionId,
|
||||||
|
@ -146,7 +147,6 @@ public final class UserMod implements UserAccount {
|
||||||
return this.uuid;
|
return this.uuid;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getNewPassword() {
|
public String getNewPassword() {
|
||||||
return this.newPassword;
|
return this.newPassword;
|
||||||
}
|
}
|
||||||
|
@ -190,7 +190,6 @@ public final class UserMod implements UserAccount {
|
||||||
.collect(Collectors.toList()));
|
.collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getRetypedNewPassword() {
|
public String getRetypedNewPassword() {
|
||||||
return this.confirmNewPassword;
|
return this.confirmNewPassword;
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,8 @@ public interface GrantEntity extends Entity {
|
||||||
*
|
*
|
||||||
* @return The institution association of a GrantEntity */
|
* @return The institution association of a GrantEntity */
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
String getOwnerId();
|
default String getOwnerId() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,7 @@ import ch.ethz.seb.sebserver.gbl.model.exam.Exam;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserInfo;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserInfo;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Utils;
|
import ch.ethz.seb.sebserver.gbl.util.Utils;
|
||||||
|
|
||||||
|
@ -101,6 +102,18 @@ public class FilterMap extends POSTMapper {
|
||||||
return getSQLWildcard(Indicator.FILTER_ATTR_NAME);
|
return getSQLWildcard(Indicator.FILTER_ATTR_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getOrientationTemplate() {
|
||||||
|
return getSQLWildcard(Orientation.FILTER_ATTR_TEMPLATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOrientationView() {
|
||||||
|
return getSQLWildcard(Orientation.FILTER_ATTR_VIEW);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOrientationGroup() {
|
||||||
|
return getSQLWildcard(Orientation.FILTER_ATTR_GROUP);
|
||||||
|
}
|
||||||
|
|
||||||
public String getSQLWildcard(final String name) {
|
public String getSQLWildcard(final String name) {
|
||||||
return toSQLWildcard(this.params.getFirst(name));
|
return toSQLWildcard(this.params.getFirst(name));
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 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.dao;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
|
|
||||||
|
public interface OrientationDAO extends EntityDAO<Orientation, Orientation> {
|
||||||
|
|
||||||
|
Result<Collection<EntityKey>> deleteAllOfTemplate(String templateName);
|
||||||
|
|
||||||
|
}
|
|
@ -34,6 +34,7 @@ import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Exam;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Exam;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Exam.ExamType;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Exam.ExamType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Utils;
|
import ch.ethz.seb.sebserver.gbl.util.Utils;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordDynamicSqlSupport;
|
||||||
|
@ -48,6 +49,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.lms.LmsAPIService;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class ExamDAOImpl implements ExamDAO {
|
public class ExamDAOImpl implements ExamDAO {
|
||||||
|
|
||||||
private final ExamRecordMapper examRecordMapper;
|
private final ExamRecordMapper examRecordMapper;
|
||||||
|
|
|
@ -30,6 +30,7 @@ import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator.IndicatorType;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator.IndicatorType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator.Threshold;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator.Threshold;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordMapper;
|
||||||
|
@ -49,6 +50,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class IndicatorDAOImpl implements IndicatorDAO {
|
public class IndicatorDAOImpl implements IndicatorDAO {
|
||||||
|
|
||||||
private final IndicatorRecordMapper indicatorRecordMapper;
|
private final IndicatorRecordMapper indicatorRecordMapper;
|
||||||
|
|
|
@ -30,6 +30,7 @@ import ch.ethz.seb.sebserver.gbl.api.APIMessage.FieldValidationException;
|
||||||
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.Institution;
|
import ch.ethz.seb.sebserver.gbl.model.institution.Institution;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordMapper;
|
||||||
|
@ -43,6 +44,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class InstitutionDAOImpl implements InstitutionDAO {
|
public class InstitutionDAOImpl implements InstitutionDAO {
|
||||||
|
|
||||||
private final InstitutionRecordMapper institutionRecordMapper;
|
private final InstitutionRecordMapper institutionRecordMapper;
|
||||||
|
|
|
@ -27,6 +27,7 @@ import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup.LmsType;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup.LmsType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.LmsSetupRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.LmsSetupRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.LmsSetupRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.LmsSetupRecordMapper;
|
||||||
|
@ -42,6 +43,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class LmsSetupDAOImpl implements LmsSetupDAO {
|
public class LmsSetupDAOImpl implements LmsSetupDAO {
|
||||||
|
|
||||||
private final LmsSetupRecordMapper lmsSetupRecordMapper;
|
private final LmsSetupRecordMapper lmsSetupRecordMapper;
|
||||||
|
|
|
@ -0,0 +1,216 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 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.dao.impl;
|
||||||
|
|
||||||
|
import static org.mybatis.dynamic.sql.SqlBuilder.isEqualTo;
|
||||||
|
import static org.mybatis.dynamic.sql.SqlBuilder.isIn;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.function.Predicate;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import org.mybatis.dynamic.sql.SqlBuilder;
|
||||||
|
import org.springframework.context.annotation.Lazy;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.OrientationRecordDynamicSqlSupport;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.OrientationRecordMapper;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.model.OrientationRecord;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.DAOLoggingSupport;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.FilterMap;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.OrientationDAO;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.ResourceNotFoundException;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler;
|
||||||
|
|
||||||
|
@Lazy
|
||||||
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
|
public class OrientationDAOImpl implements OrientationDAO {
|
||||||
|
|
||||||
|
private final OrientationRecordMapper orientationRecordMapper;
|
||||||
|
|
||||||
|
protected OrientationDAOImpl(final OrientationRecordMapper orientationRecordMapper) {
|
||||||
|
this.orientationRecordMapper = orientationRecordMapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(readOnly = true)
|
||||||
|
public EntityType entityType() {
|
||||||
|
return EntityType.ORIENTATION;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(readOnly = true)
|
||||||
|
public Result<Orientation> byPK(final Long id) {
|
||||||
|
return recordById(id)
|
||||||
|
.flatMap(OrientationDAOImpl::toDomainModel);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(readOnly = true)
|
||||||
|
public Result<Collection<Orientation>> byEntityKeys(final Set<EntityKey> keys) {
|
||||||
|
return Result.tryCatch(() -> {
|
||||||
|
final List<Long> ids = extractPKsFromKeys(keys);
|
||||||
|
|
||||||
|
return this.orientationRecordMapper.selectByExample()
|
||||||
|
.where(OrientationRecordDynamicSqlSupport.id, isIn(ids))
|
||||||
|
.build()
|
||||||
|
.execute()
|
||||||
|
.stream()
|
||||||
|
.map(OrientationDAOImpl::toDomainModel)
|
||||||
|
.flatMap(DAOLoggingSupport::logUnexpectedErrorAndSkip)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional(readOnly = true)
|
||||||
|
public Result<Collection<Orientation>> allMatching(
|
||||||
|
final FilterMap filterMap,
|
||||||
|
final Predicate<Orientation> predicate) {
|
||||||
|
|
||||||
|
return Result.tryCatch(() -> this.orientationRecordMapper
|
||||||
|
.selectByExample()
|
||||||
|
.where(
|
||||||
|
OrientationRecordDynamicSqlSupport.template,
|
||||||
|
SqlBuilder.isEqualToWhenPresent(filterMap.getOrientationTemplate()))
|
||||||
|
.and(
|
||||||
|
OrientationRecordDynamicSqlSupport.view,
|
||||||
|
SqlBuilder.isEqualToWhenPresent(filterMap.getOrientationView()))
|
||||||
|
.and(
|
||||||
|
OrientationRecordDynamicSqlSupport.group,
|
||||||
|
SqlBuilder.isEqualToWhenPresent(filterMap.getOrientationGroup()))
|
||||||
|
.build()
|
||||||
|
.execute()
|
||||||
|
.stream()
|
||||||
|
.map(OrientationDAOImpl::toDomainModel)
|
||||||
|
.flatMap(DAOLoggingSupport::logUnexpectedErrorAndSkip)
|
||||||
|
.filter(predicate)
|
||||||
|
.collect(Collectors.toList()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional
|
||||||
|
public Result<Orientation> createNew(final Orientation data) {
|
||||||
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
|
final OrientationRecord newRecord = new OrientationRecord(
|
||||||
|
null,
|
||||||
|
data.attributeId,
|
||||||
|
data.template,
|
||||||
|
data.view,
|
||||||
|
data.group,
|
||||||
|
data.xPosition,
|
||||||
|
data.yPosition,
|
||||||
|
data.width,
|
||||||
|
data.height);
|
||||||
|
|
||||||
|
this.orientationRecordMapper.insert(newRecord);
|
||||||
|
return newRecord;
|
||||||
|
})
|
||||||
|
.flatMap(OrientationDAOImpl::toDomainModel)
|
||||||
|
.onErrorDo(TransactionHandler::rollback);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional
|
||||||
|
public Result<Orientation> save(final Orientation data) {
|
||||||
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
|
final OrientationRecord newRecord = new OrientationRecord(
|
||||||
|
data.id,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
data.group,
|
||||||
|
data.xPosition,
|
||||||
|
data.yPosition,
|
||||||
|
data.width,
|
||||||
|
data.height);
|
||||||
|
|
||||||
|
this.orientationRecordMapper.updateByPrimaryKeySelective(newRecord);
|
||||||
|
return this.orientationRecordMapper.selectByPrimaryKey(data.id);
|
||||||
|
})
|
||||||
|
.flatMap(OrientationDAOImpl::toDomainModel)
|
||||||
|
.onErrorDo(TransactionHandler::rollback);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional
|
||||||
|
public Result<Collection<EntityKey>> delete(final Set<EntityKey> all) {
|
||||||
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
|
final List<Long> ids = extractPKsFromKeys(all);
|
||||||
|
|
||||||
|
this.orientationRecordMapper.deleteByExample()
|
||||||
|
.where(OrientationRecordDynamicSqlSupport.id, isIn(ids))
|
||||||
|
.build()
|
||||||
|
.execute();
|
||||||
|
|
||||||
|
return ids.stream()
|
||||||
|
.map(id -> new EntityKey(id, EntityType.ORIENTATION))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional
|
||||||
|
public Result<Collection<EntityKey>> deleteAllOfTemplate(final String templateName) {
|
||||||
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
|
final List<Long> ids = this.orientationRecordMapper.selectIdsByExample()
|
||||||
|
.where(OrientationRecordDynamicSqlSupport.template, isEqualTo(templateName))
|
||||||
|
.build()
|
||||||
|
.execute();
|
||||||
|
|
||||||
|
this.orientationRecordMapper.deleteByExample()
|
||||||
|
.where(OrientationRecordDynamicSqlSupport.template, isEqualTo(templateName))
|
||||||
|
.build()
|
||||||
|
.execute();
|
||||||
|
|
||||||
|
return ids.stream()
|
||||||
|
.map(id -> new EntityKey(id, EntityType.ORIENTATION))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private Result<OrientationRecord> recordById(final Long id) {
|
||||||
|
return Result.tryCatch(() -> {
|
||||||
|
final OrientationRecord record = this.orientationRecordMapper.selectByPrimaryKey(id);
|
||||||
|
if (record == null) {
|
||||||
|
throw new ResourceNotFoundException(
|
||||||
|
EntityType.ORIENTATION,
|
||||||
|
String.valueOf(id));
|
||||||
|
}
|
||||||
|
return record;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Result<Orientation> toDomainModel(final OrientationRecord record) {
|
||||||
|
return Result.tryCatch(() -> new Orientation(
|
||||||
|
record.getId(),
|
||||||
|
record.getConfigAttributeId(),
|
||||||
|
record.getTemplate(),
|
||||||
|
record.getView(),
|
||||||
|
record.getGroup(),
|
||||||
|
record.getxPosition(),
|
||||||
|
record.getyPosition(),
|
||||||
|
record.getWidth(),
|
||||||
|
record.getHeight()));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -28,6 +28,7 @@ import org.springframework.transaction.annotation.Transactional;
|
||||||
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.SebClientConfig;
|
import ch.ethz.seb.sebserver.gbl.model.institution.SebClientConfig;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.SebClientConfigRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.SebClientConfigRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.SebClientConfigRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.SebClientConfigRecordMapper;
|
||||||
|
@ -43,6 +44,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.TransactionHandler;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class SebClientConfigDAOImpl implements SebClientConfigDAO {
|
public class SebClientConfigDAOImpl implements SebClientConfigDAO {
|
||||||
|
|
||||||
private final SebClientConfigRecordMapper sebClientConfigRecordMapper;
|
private final SebClientConfigRecordMapper sebClientConfigRecordMapper;
|
||||||
|
|
|
@ -31,6 +31,7 @@ import ch.ethz.seb.sebserver.gbl.api.EntityType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserActivityLog;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserActivityLog;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.UserActivityLogRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.UserActivityLogRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.UserActivityLogRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.UserActivityLogRecordMapper;
|
||||||
|
@ -45,6 +46,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.UserActivityLogDAO;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class UserActivityLogDAOImpl implements UserActivityLogDAO {
|
public class UserActivityLogDAOImpl implements UserActivityLogDAO {
|
||||||
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(UserActivityLogDAOImpl.class);
|
private static final Logger log = LoggerFactory.getLogger(UserActivityLogDAOImpl.class);
|
||||||
|
|
|
@ -43,6 +43,7 @@ import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserAccount;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserAccount;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserInfo;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserInfo;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserMod;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserMod;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.RoleRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.RoleRecordDynamicSqlSupport;
|
||||||
|
@ -60,6 +61,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.dao.UserDAO;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
@Component
|
@Component
|
||||||
|
@WebServiceProfile
|
||||||
public class UserDAOImpl implements UserDAO {
|
public class UserDAOImpl implements UserDAO {
|
||||||
|
|
||||||
private static final Logger log = LoggerFactory.getLogger(UserDAOImpl.class);
|
private static final Logger log = LoggerFactory.getLogger(UserDAOImpl.class);
|
||||||
|
|
|
@ -46,7 +46,7 @@ import org.springframework.util.MultiValueMap;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.api.APIMessage;
|
import ch.ethz.seb.sebserver.gbl.api.APIMessage;
|
||||||
import ch.ethz.seb.sebserver.gbl.async.AsyncService;
|
import ch.ethz.seb.sebserver.gbl.async.AsyncService;
|
||||||
import ch.ethz.seb.sebserver.gbl.async.CircuitBreakerSupplier;
|
import ch.ethz.seb.sebserver.gbl.async.MemoizingCircuitBreaker;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetupTestResult;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetupTestResult;
|
||||||
|
@ -75,7 +75,7 @@ final class OpenEdxLmsAPITemplate implements LmsAPITemplate {
|
||||||
private final Set<String> knownTokenAccessPaths;
|
private final Set<String> knownTokenAccessPaths;
|
||||||
|
|
||||||
private OAuth2RestTemplate restTemplate = null;
|
private OAuth2RestTemplate restTemplate = null;
|
||||||
private final CircuitBreakerSupplier<List<QuizData>> allQuizzesSupplier;
|
private final MemoizingCircuitBreaker<List<QuizData>> allQuizzesSupplier;
|
||||||
|
|
||||||
OpenEdxLmsAPITemplate(
|
OpenEdxLmsAPITemplate(
|
||||||
final AsyncService asyncService,
|
final AsyncService asyncService,
|
||||||
|
|
|
@ -40,7 +40,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.validation.BeanValidationSe
|
||||||
* @param <T> The concrete Entity domain-model type used on all GET, PUT
|
* @param <T> The concrete Entity domain-model type used on all GET, PUT
|
||||||
* @param <M> The concrete Entity domain-model type used for POST methods (new) */
|
* @param <M> The concrete Entity domain-model type used for POST methods (new) */
|
||||||
public abstract class ActivatableEntityController<T extends GrantEntity, M extends GrantEntity>
|
public abstract class ActivatableEntityController<T extends GrantEntity, M extends GrantEntity>
|
||||||
extends EntityController<T, M> {
|
extends GrantEntityController<T, M> {
|
||||||
|
|
||||||
public ActivatableEntityController(
|
public ActivatableEntityController(
|
||||||
final AuthorizationService authorizationGrantService,
|
final AuthorizationService authorizationGrantService,
|
||||||
|
|
|
@ -55,7 +55,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.validation.BeanValidationSe
|
||||||
*
|
*
|
||||||
* @param <T> The concrete Entity domain-model type used on all GET, PUT
|
* @param <T> The concrete Entity domain-model type used on all GET, PUT
|
||||||
* @param <M> The concrete Entity domain-model type used for POST methods (new) */
|
* @param <M> The concrete Entity domain-model type used for POST methods (new) */
|
||||||
public abstract class EntityController<T extends GrantEntity, M extends GrantEntity> {
|
public abstract class GrantEntityController<T extends GrantEntity, M extends GrantEntity> {
|
||||||
|
|
||||||
protected final AuthorizationService authorization;
|
protected final AuthorizationService authorization;
|
||||||
protected final BulkActionService bulkActionService;
|
protected final BulkActionService bulkActionService;
|
||||||
|
@ -64,7 +64,7 @@ public abstract class EntityController<T extends GrantEntity, M extends GrantEnt
|
||||||
protected final PaginationService paginationService;
|
protected final PaginationService paginationService;
|
||||||
protected final BeanValidationService beanValidationService;
|
protected final BeanValidationService beanValidationService;
|
||||||
|
|
||||||
protected EntityController(
|
protected GrantEntityController(
|
||||||
final AuthorizationService authorization,
|
final AuthorizationService authorization,
|
||||||
final BulkActionService bulkActionService,
|
final BulkActionService bulkActionService,
|
||||||
final EntityDAO<T, M> entityDAO,
|
final EntityDAO<T, M> entityDAO,
|
|
@ -29,7 +29,7 @@ import ch.ethz.seb.sebserver.webservice.servicelayer.validation.BeanValidationSe
|
||||||
@WebServiceProfile
|
@WebServiceProfile
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/${sebserver.webservice.api.admin.endpoint}" + API.EXAM_INDICATOR_ENDPOINT)
|
@RequestMapping("/${sebserver.webservice.api.admin.endpoint}" + API.EXAM_INDICATOR_ENDPOINT)
|
||||||
public class IndicatorController extends EntityController<Indicator, Indicator> {
|
public class IndicatorController extends GrantEntityController<Indicator, Indicator> {
|
||||||
|
|
||||||
private final ExamDAO examDao;
|
private final ExamDAO examDao;
|
||||||
|
|
||||||
|
|
|
@ -473,7 +473,7 @@ public class UserAPITest extends AdministrationAPIIntegrationTester {
|
||||||
});
|
});
|
||||||
|
|
||||||
assertNotNull(createdUserGet);
|
assertNotNull(createdUserGet);
|
||||||
assertEquals(createdUser, createdUserGet);
|
assertEquals(createdUser.getEntityKey(), createdUserGet.getEntityKey());
|
||||||
assertFalse(createdUserGet.isActive());
|
assertFalse(createdUserGet.isActive());
|
||||||
|
|
||||||
// check user activity log for newly created user
|
// check user activity log for newly created user
|
||||||
|
|
Loading…
Reference in a new issue