demo update
This commit is contained in:
parent
59c437e61d
commit
bdd2b668e5
8 changed files with 164 additions and 20 deletions
|
@ -3,7 +3,7 @@ FROM alpine/git
|
||||||
ARG GIT_TAG
|
ARG GIT_TAG
|
||||||
ARG SEBSERVER_VERSION
|
ARG SEBSERVER_VERSION
|
||||||
|
|
||||||
WORKDIR /demo
|
WORKDIR /sebserver
|
||||||
RUN if [ "x${GIT_TAG}" = "x" ] ; \
|
RUN if [ "x${GIT_TAG}" = "x" ] ; \
|
||||||
then git clone --depth 1 https://github.com/SafeExamBrowser/seb-server.git ; \
|
then git clone --depth 1 https://github.com/SafeExamBrowser/seb-server.git ; \
|
||||||
else git clone -b "$GIT_TAG" --depth 1 https://github.com/SafeExamBrowser/seb-server.git ; fi
|
else git clone -b "$GIT_TAG" --depth 1 https://github.com/SafeExamBrowser/seb-server.git ; fi
|
||||||
|
@ -12,33 +12,35 @@ FROM maven:3.5-jdk-8-alpine
|
||||||
|
|
||||||
ARG SEBSERVER_VERSION
|
ARG SEBSERVER_VERSION
|
||||||
|
|
||||||
WORKDIR /demo
|
WORKDIR /sebserver
|
||||||
COPY --from=0 /demo/seb-server /demo
|
COPY --from=0 /sebserver/seb-server /sebserver
|
||||||
RUN mvn clean install -e -P Demo -DskipTests
|
RUN mvn clean install -e -P Demo -DskipTests
|
||||||
|
|
||||||
FROM openjdk:8-jre-alpine
|
FROM openjdk:8-jre-alpine
|
||||||
|
|
||||||
ARG SEBSERVER_VERSION
|
ARG SEBSERVER_VERSION
|
||||||
ENV SEBSERVER_VERSION=${SEBSERVER_VERSION}
|
ENV SEBSERVER_VERSION=${SEBSERVER_VERSION}
|
||||||
ENV SERVER_ADDRESS="0.0.0.0"
|
|
||||||
ENV SERVER_PORT="8080"
|
ENV SERVER_PORT="8080"
|
||||||
ENV DBSERVER_ADDRESS="seb-server-mariadb"
|
ENV DBSERVER_PWD=
|
||||||
ENV DBSERVER_PORT="3306"
|
ENV GUICLIENT_PWD=
|
||||||
ENV DBSERVER_PWD="[TO_SET]"
|
ENV INTERNAL_PWD=
|
||||||
ENV GUICLIENT_PWD="[TO_SET]"
|
|
||||||
ENV INTERNAL_PWD="[TO_SET]"
|
|
||||||
|
|
||||||
WORKDIR /demo
|
WORKDIR /sebserver
|
||||||
COPY --from=1 /demo/target/seb-server-"$SEBSERVER_VERSION"-SNAPSHOT.jar /demo
|
COPY --from=1 /sebserver/target/seb-server-"$SEBSERVER_VERSION"-SNAPSHOT.jar /sebserver
|
||||||
|
|
||||||
ENTRYPOINT exec java -jar seb-server-"${SEBSERVER_VERSION}"-SNAPSHOT.jar \
|
ENTRYPOINT exec java \
|
||||||
|
-Dcom.sun.management.jmxremote \
|
||||||
|
-Dcom.sun.management.jmxremote.port=9090 \
|
||||||
|
-Dcom.sun.management.jmxremote.rmi.port=9090 \
|
||||||
|
-Djava.rmi.server.hostname=127.0.0.1 \
|
||||||
|
-Dcom.sun.management.jmxremote.ssl=false \
|
||||||
|
-Dcom.sun.management.jmxremote.authenticate=false \
|
||||||
|
-jar seb-server-"${SEBSERVER_VERSION}"-SNAPSHOT.jar \
|
||||||
--server.port="${SERVER_PORT}" \
|
--server.port="${SERVER_PORT}" \
|
||||||
--spring.config.location=classpath:/config/ \
|
|
||||||
--datastore.mariadb.server.address="${DBSERVER_ADDRESS}" \
|
|
||||||
--datastore.mariadb.server.port="${DBSERVER_PORT}" \
|
|
||||||
--spring.profiles.active=demo \
|
--spring.profiles.active=demo \
|
||||||
|
--spring.config.location=file:/sebserver/,classpath:/config/ \
|
||||||
--spring.datasource.password="${DBSERVER_PWD}" \
|
--spring.datasource.password="${DBSERVER_PWD}" \
|
||||||
--sebserver.webservice.api.admin.clientSecret="${GUICLIENT_PWD}" \
|
--sebserver.webservice.api.admin.clientSecret="${GUICLIENT_PWD}" \
|
||||||
--sebserver.webservice.internalSecret="${INTERNAL_PWD}"
|
--sebserver.webservice.internalSecret="${INTERNAL_PWD}"
|
||||||
|
|
||||||
EXPOSE 8080
|
EXPOSE $SERVER_PORT 9090
|
57
docker/demo/application-demo.properties
Normal file
57
docker/demo/application-demo.properties
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
# overall server configuration
|
||||||
|
server.address=0.0.0.0
|
||||||
|
server.port=8080
|
||||||
|
server.servlet.context-path=/
|
||||||
|
server.servlet.session.cookie.http-only=true
|
||||||
|
server.servlet.session.tracking-modes=cookie
|
||||||
|
|
||||||
|
# database server
|
||||||
|
datastore.mariadb.server.address=seb-server-mariadb
|
||||||
|
datastore.mariadb.server.port=3306
|
||||||
|
|
||||||
|
# data source configuration
|
||||||
|
spring.datasource.username=root
|
||||||
|
spring.datasource.initialize=true
|
||||||
|
spring.datasource.initialization-mode=always
|
||||||
|
spring.datasource.url=jdbc:mariadb://${datastore.mariadb.server.address}:${datastore.mariadb.server.port}/SEBServer?useSSL=false&createDatabaseIfNotExist=true
|
||||||
|
spring.datasource.driver-class-name=org.mariadb.jdbc.Driver
|
||||||
|
spring.datasource.platform=demo
|
||||||
|
|
||||||
|
# webservice configuration
|
||||||
|
sebserver.test.property=This is a SEB Server Demo
|
||||||
|
sebserver.webservice.distributed=false
|
||||||
|
sebserver.webservice.http.scheme=http
|
||||||
|
sebserver.webservice.http.server.name=ralph.ethz.ch
|
||||||
|
sebserver.webservice.http.redirect.gui=${sebserver.gui.entrypoint}
|
||||||
|
sebserver.webservice.api.admin.clientId=guiClient
|
||||||
|
sebserver.webservice.api.admin.endpoint=/admin-api/v1
|
||||||
|
sebserver.webservice.api.admin.accessTokenValiditySeconds=3600
|
||||||
|
sebserver.webservice.api.admin.refreshTokenValiditySeconds=-1
|
||||||
|
sebserver.webservice.api.exam.endpoint=/exam-api
|
||||||
|
sebserver.webservice.api.exam.endpoint.discovery=${sebserver.webservice.api.exam.endpoint}/discovery
|
||||||
|
sebserver.webservice.api.exam.endpoint.v1=${sebserver.webservice.api.exam.endpoint}/v1
|
||||||
|
sebserver.webservice.api.exam.accessTokenValiditySeconds=86400
|
||||||
|
sebserver.webservice.api.pagination.maxPageSize=500
|
||||||
|
# comma separated list of known possible OpenEdX API access token request endpoints
|
||||||
|
sebserver.webservice.lms.openedx.api.token.request.paths=/oauth2/access_token
|
||||||
|
# write logs to
|
||||||
|
logging.file=log/sebserver.log
|
||||||
|
|
||||||
|
# actuator configuration
|
||||||
|
management.endpoints.web.base-path=/actuator
|
||||||
|
management.endpoints.web.exposure.include=logfile,loggers
|
||||||
|
|
||||||
|
# GUI server configuration
|
||||||
|
sebserver.gui.entrypoint=/gui
|
||||||
|
sebserver.gui.webservice.protocol=http
|
||||||
|
sebserver.gui.webservice.address=${server.address}
|
||||||
|
sebserver.gui.webservice.port=8080
|
||||||
|
sebserver.gui.webservice.apipath=/admin-api/v1
|
||||||
|
sebserver.gui.theme=css/sebserver.css
|
||||||
|
sebserver.gui.list.page.size=20
|
||||||
|
sebserver.gui.date.displayformat=MM/dd/yyyy HH:mm
|
||||||
|
sebserver.gui.date.displayformat.timezone=|ZZ
|
||||||
|
sebserver.gui.multilingual=false
|
||||||
|
sebserver.gui.languages=en
|
||||||
|
sebserver.gui.seb.client.config.download.filename=SebClientSettings.seb
|
||||||
|
sebserver.gui.seb.exam.config.download.filename=SebClientSettings.seb
|
|
@ -20,15 +20,15 @@ services:
|
||||||
- SEBSERVER_VERSION=0.4.1-beta
|
- SEBSERVER_VERSION=0.4.1-beta
|
||||||
container_name: seb-server
|
container_name: seb-server
|
||||||
environment:
|
environment:
|
||||||
- SERVER_ADDRESS=0.0.0.0
|
|
||||||
- SERVER_PORT=8080
|
- SERVER_PORT=8080
|
||||||
- DBSERVER_ADDRESS=seb-server-mariadb
|
|
||||||
- DBSERVER_PORT=3306
|
|
||||||
- DBSERVER_PWD=somePW
|
- DBSERVER_PWD=somePW
|
||||||
- GUICLIENT_PWD=somePW
|
- GUICLIENT_PWD=somePW
|
||||||
- INTERNAL_PWD=somePW
|
- INTERNAL_PWD=somePW
|
||||||
|
volumes:
|
||||||
|
- ./application-demo.properties:/sebserver/application-demo.properties
|
||||||
ports:
|
ports:
|
||||||
- 8080:8080
|
- 8080:8080
|
||||||
|
- 9090:9090
|
||||||
networks:
|
networks:
|
||||||
- ralph
|
- ralph
|
||||||
depends_on:
|
depends_on:
|
||||||
|
|
5
pom.xml
5
pom.xml
|
@ -247,6 +247,10 @@
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-boot-starter-cache</artifactId>
|
<artifactId>spring-boot-starter-cache</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-quartz</artifactId>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.fasterxml.jackson.dataformat</groupId>
|
<groupId>com.fasterxml.jackson.dataformat</groupId>
|
||||||
<artifactId>jackson-dataformat-xml</artifactId>
|
<artifactId>jackson-dataformat-xml</artifactId>
|
||||||
|
@ -305,6 +309,7 @@
|
||||||
<version>1.2.0</version>
|
<version>1.2.0</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
|
||||||
<!-- Testing -->
|
<!-- Testing -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>junit</groupId>
|
<groupId>junit</groupId>
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
/*
|
||||||
|
* 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.batch;
|
||||||
|
|
||||||
|
import org.quartz.CronScheduleBuilder;
|
||||||
|
import org.quartz.JobBuilder;
|
||||||
|
import org.quartz.JobDetail;
|
||||||
|
import org.quartz.Trigger;
|
||||||
|
import org.quartz.TriggerBuilder;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
public class BatchConfig {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public JobDetail jobADetails() {
|
||||||
|
return JobBuilder
|
||||||
|
.newJob(SimpleBatchJob.class)
|
||||||
|
.withIdentity("sampleJobA")
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public Trigger jobATrigger(final JobDetail jobADetails) {
|
||||||
|
|
||||||
|
return TriggerBuilder
|
||||||
|
.newTrigger()
|
||||||
|
.forJob(jobADetails)
|
||||||
|
.withIdentity("sampleTriggerA")
|
||||||
|
|
||||||
|
.withSchedule(CronScheduleBuilder.cronSchedule("0/30 0 0 ? * * *"))
|
||||||
|
.startNow()
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,34 @@
|
||||||
|
/*
|
||||||
|
* 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.batch;
|
||||||
|
|
||||||
|
import org.quartz.DisallowConcurrentExecution;
|
||||||
|
import org.quartz.Job;
|
||||||
|
import org.quartz.JobExecutionContext;
|
||||||
|
import org.quartz.JobExecutionException;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.ClientConnectionDAO;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
@DisallowConcurrentExecution
|
||||||
|
public class SimpleBatchJob implements Job {
|
||||||
|
|
||||||
|
private final ClientConnectionDAO clientConnectionDAO;
|
||||||
|
|
||||||
|
public SimpleBatchJob(final ClientConnectionDAO clientConnectionDAO) {
|
||||||
|
this.clientConnectionDAO = clientConnectionDAO;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void execute(final JobExecutionContext context) throws JobExecutionException {
|
||||||
|
System.out.print("*********************** " + this.clientConnectionDAO);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -15,6 +15,9 @@ spring.datasource.hikari.connectionTimeout=30000
|
||||||
spring.datasource.hikari.idleTimeout=600000
|
spring.datasource.hikari.idleTimeout=600000
|
||||||
spring.datasource.hikari.maxLifetime=1800000
|
spring.datasource.hikari.maxLifetime=1800000
|
||||||
|
|
||||||
|
spring.quartz.job-store-type=memory
|
||||||
|
spring.quartz.properties.org.quartz.threadPool.threadCount=2
|
||||||
|
|
||||||
# webservice configuration
|
# webservice configuration
|
||||||
sebserver.webservice.distributed=false
|
sebserver.webservice.distributed=false
|
||||||
sebserver.webservice.http.scheme=http
|
sebserver.webservice.http.scheme=http
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
spring.application.name=SEB Server
|
spring.application.name=SEB Server
|
||||||
spring.profiles.active=prod
|
spring.profiles.active=dev
|
||||||
|
|
||||||
spring.mandatory-file-encoding=UTF-8
|
spring.mandatory-file-encoding=UTF-8
|
||||||
spring.http.encoding.charset=UTF-8
|
spring.http.encoding.charset=UTF-8
|
||||||
|
|
Loading…
Reference in a new issue