Merge remote-tracking branch 'origin/dev-lms-open-olat' into dev-1.2
This commit is contained in:
commit
c743947912
2 changed files with 55 additions and 54 deletions
|
@ -11,22 +11,22 @@ package ch.ethz.seb.sebserver.webservice.servicelayer.lms.impl.olat;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
|
||||||
|
|
||||||
public final class OlatLmsData {
|
public final class OlatLmsData {
|
||||||
|
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
static public final class AssessmentData {
|
static public final class AssessmentData {
|
||||||
/* OLAT API example:
|
/*
|
||||||
{
|
* OLAT API example:
|
||||||
"courseName": "course 1",
|
* {
|
||||||
"dateFrom": 1624420800000,
|
* "courseName": "course 1",
|
||||||
"dateTo": 1624658400000,
|
* "dateFrom": 1624420800000,
|
||||||
"description": "",
|
* "dateTo": 1624658400000,
|
||||||
"key": 6356992,
|
* "description": "",
|
||||||
“repositoryEntryKey”: 462324,
|
* "key": 6356992,
|
||||||
"name": "SEB test"
|
* “repositoryEntryKey”: 462324,
|
||||||
}
|
* "name": "SEB test"
|
||||||
|
* }
|
||||||
*/
|
*/
|
||||||
public long key;
|
public long key;
|
||||||
public long repositoryEntryKey;
|
public long repositoryEntryKey;
|
||||||
|
@ -39,13 +39,14 @@ public final class OlatLmsData {
|
||||||
|
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
static final class UserData {
|
static final class UserData {
|
||||||
/* OLAT API example:
|
/*
|
||||||
{
|
* OLAT API example:
|
||||||
"firstName": "OpenOLAT",
|
* {
|
||||||
"key": 360448,
|
* "firstName": "OpenOLAT",
|
||||||
"lastName": "Administrator",
|
* "key": 360448,
|
||||||
"username": "administrator"
|
* "lastName": "Administrator",
|
||||||
}
|
* "username": "administrator"
|
||||||
|
* }
|
||||||
*/
|
*/
|
||||||
public long key;
|
public long key;
|
||||||
public String firstName;
|
public String firstName;
|
||||||
|
@ -55,12 +56,13 @@ public final class OlatLmsData {
|
||||||
|
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
static final class RestrictionData {
|
static final class RestrictionData {
|
||||||
/* OLAT API example:
|
/*
|
||||||
{
|
* OLAT API example:
|
||||||
"browserExamKeys": [ "1" ],
|
* {
|
||||||
"configKeys": null,
|
* "browserExamKeys": [ "1" ],
|
||||||
"key": 8028160
|
* "configKeys": null,
|
||||||
}
|
* "key": 8028160
|
||||||
|
* }
|
||||||
*/
|
*/
|
||||||
public long key;
|
public long key;
|
||||||
public List<String> browserExamKeys;
|
public List<String> browserExamKeys;
|
||||||
|
@ -69,16 +71,15 @@ public final class OlatLmsData {
|
||||||
|
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
static final class RestrictionDataPost {
|
static final class RestrictionDataPost {
|
||||||
/* OLAT API example:
|
/*
|
||||||
{
|
* OLAT API example:
|
||||||
"configKeys": ["a", "b"],
|
* {
|
||||||
"browserExamKeys": ["1", "2"]
|
* "configKeys": ["a", "b"],
|
||||||
}
|
* "browserExamKeys": ["1", "2"]
|
||||||
|
* }
|
||||||
*/
|
*/
|
||||||
public List<String> browserExamKeys;
|
public List<String> browserExamKeys;
|
||||||
public List<String> configKeys;
|
public List<String> configKeys;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -12,17 +12,15 @@ import java.io.IOException;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import org.springframework.web.client.RestTemplate;
|
|
||||||
import org.springframework.security.oauth2.client.token.grant.client.ClientCredentialsResourceDetails;
|
|
||||||
import org.springframework.http.HttpEntity;
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.http.HttpRequest;
|
|
||||||
import org.springframework.http.HttpHeaders;
|
import org.springframework.http.HttpHeaders;
|
||||||
|
import org.springframework.http.HttpRequest;
|
||||||
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.http.client.ClientHttpRequestExecution;
|
import org.springframework.http.client.ClientHttpRequestExecution;
|
||||||
import org.springframework.http.client.ClientHttpRequestInterceptor;
|
import org.springframework.http.client.ClientHttpRequestInterceptor;
|
||||||
import org.springframework.http.client.ClientHttpResponse;
|
import org.springframework.http.client.ClientHttpResponse;
|
||||||
|
import org.springframework.security.oauth2.client.token.grant.client.ClientCredentialsResourceDetails;
|
||||||
|
import org.springframework.web.client.RestTemplate;
|
||||||
|
|
||||||
public class OlatLmsRestTemplate extends RestTemplate {
|
public class OlatLmsRestTemplate extends RestTemplate {
|
||||||
|
|
||||||
|
@ -31,27 +29,32 @@ public class OlatLmsRestTemplate extends RestTemplate {
|
||||||
private String token;
|
private String token;
|
||||||
private ClientCredentialsResourceDetails details;
|
private ClientCredentialsResourceDetails details;
|
||||||
|
|
||||||
public OlatLmsRestTemplate(ClientCredentialsResourceDetails details) {
|
public OlatLmsRestTemplate(final ClientCredentialsResourceDetails details) {
|
||||||
super();
|
super();
|
||||||
this.details = details;
|
this.details = details;
|
||||||
|
|
||||||
// Add X-OLAT-TOKEN request header to every request done using this RestTemplate
|
// Add X-OLAT-TOKEN request header to every request done using this RestTemplate
|
||||||
this.getInterceptors().add(new ClientHttpRequestInterceptor(){
|
this.getInterceptors().add(new ClientHttpRequestInterceptor() {
|
||||||
@Override
|
@Override
|
||||||
public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) throws IOException {
|
public ClientHttpResponse intercept(final HttpRequest request, final byte[] body,
|
||||||
|
final ClientHttpRequestExecution execution) throws IOException {
|
||||||
// if there's no token, authenticate first
|
// if there's no token, authenticate first
|
||||||
if (token == null) { authenticate(); }
|
if (OlatLmsRestTemplate.this.token == null) {
|
||||||
|
authenticate();
|
||||||
|
}
|
||||||
// when authenticating, just do a normal call
|
// when authenticating, just do a normal call
|
||||||
else if (token.equals("authenticating")) { return execution.execute(request, body); }
|
else if (OlatLmsRestTemplate.this.token.equals("authenticating")) {
|
||||||
|
return execution.execute(request, body);
|
||||||
|
}
|
||||||
// otherwise, add the X-OLAT-TOKEN
|
// otherwise, add the X-OLAT-TOKEN
|
||||||
request.getHeaders().set("accept", "application/json");
|
request.getHeaders().set("accept", "application/json");
|
||||||
request.getHeaders().set("X-OLAT-TOKEN", token);
|
request.getHeaders().set("X-OLAT-TOKEN", OlatLmsRestTemplate.this.token);
|
||||||
ClientHttpResponse response = execution.execute(request, body);
|
ClientHttpResponse response = execution.execute(request, body);
|
||||||
log.debug("OLAT [regular API call] {} Headers: {}", response.getStatusCode(), response.getHeaders());
|
log.debug("OLAT [regular API call] {} Headers: {}", response.getStatusCode(), response.getHeaders());
|
||||||
// If we get a 401, re-authenticate and try once more
|
// If we get a 401, re-authenticate and try once more
|
||||||
if (response.getStatusCode() == HttpStatus.UNAUTHORIZED) {
|
if (response.getStatusCode() == HttpStatus.UNAUTHORIZED) {
|
||||||
authenticate();
|
authenticate();
|
||||||
request.getHeaders().set("X-OLAT-TOKEN", token);
|
request.getHeaders().set("X-OLAT-TOKEN", OlatLmsRestTemplate.this.token);
|
||||||
response = execution.execute(request, body);
|
response = execution.execute(request, body);
|
||||||
log.debug("OLAT [retry API call] {} Headers: {}", response.getStatusCode(), response.getHeaders());
|
log.debug("OLAT [retry API call] {} Headers: {}", response.getStatusCode(), response.getHeaders());
|
||||||
}
|
}
|
||||||
|
@ -62,23 +65,20 @@ public class OlatLmsRestTemplate extends RestTemplate {
|
||||||
|
|
||||||
private void authenticate() {
|
private void authenticate() {
|
||||||
// Authenticate with OLAT and store the received X-OLAT-TOKEN
|
// Authenticate with OLAT and store the received X-OLAT-TOKEN
|
||||||
token = "authenticating";
|
this.token = "authenticating";
|
||||||
final String authUrl = String.format("%s%s?password=%s",
|
final String authUrl = String.format("%s%s?password=%s",
|
||||||
details.getAccessTokenUri(),
|
this.details.getAccessTokenUri(),
|
||||||
details.getClientId(),
|
this.details.getClientId(),
|
||||||
details.getClientSecret());
|
this.details.getClientSecret());
|
||||||
try {
|
try {
|
||||||
final ResponseEntity<String> response = this.getForEntity(authUrl, String.class);
|
final ResponseEntity<String> response = this.getForEntity(authUrl, String.class);
|
||||||
final HttpHeaders responseHeaders = response.getHeaders();
|
final HttpHeaders responseHeaders = response.getHeaders();
|
||||||
log.debug("OLAT [authenticate] {} Headers: {}", response.getStatusCode(), responseHeaders);
|
log.debug("OLAT [authenticate] {} Headers: {}", response.getStatusCode(), responseHeaders);
|
||||||
token = responseHeaders.getFirst("X-OLAT-TOKEN");
|
this.token = responseHeaders.getFirst("X-OLAT-TOKEN");
|
||||||
}
|
} catch (final Exception e) {
|
||||||
catch (Exception e) {
|
this.token = null;
|
||||||
token = null;
|
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue