Skip to content

Commit

Permalink
fixed Moodle file upload
Browse files Browse the repository at this point in the history
  • Loading branch information
anhefti committed Jun 26, 2024
1 parent b33998b commit 644f0a4
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 43 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -63,8 +63,9 @@ String callMoodleAPIFunction(

String uploadMultiPart(
String uploadEndpoint,
MultiValueMap<String, Object> multiPartAttributes,
MultiValueMap<String, String> queryAttributes);
String quizId,
String fileName,
byte[] configData);


/** This maps a Moodle warning JSON object */
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,12 +26,7 @@
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpEntity;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.http.*;
import org.springframework.http.client.ClientHttpRequestFactory;
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;
Expand Down Expand Up @@ -429,31 +424,60 @@ public String callMoodleAPIFunction(
@Override
public String uploadMultiPart(
final String uploadEndpoint,
final MultiValueMap<String, Object> multiPartAttributes,
final MultiValueMap<String, String> queryAttributes) {
final String quizId,
final String fileName,
final byte[] configData) {

final LmsSetup lmsSetup = this.apiTemplateDataSupplier.getLmsSetup();
final StringBuilder uri = new StringBuilder(lmsSetup.lmsApiUrl + uploadEndpoint);
getAccessToken();
queryAttributes.add("token", this.accessToken.toString());

queryAttributes.forEach((key, values) -> {
if (values.isEmpty()) {
return;
}
if (uri.toString().contains("?")) {
uri.append("&").append(key).append("=").append(values.get(0));
} else {
uri.append("?").append(key).append("=").append(values.get(0));
}
});

log.info("Upload to Moodle url: {}", uri.toString());

return super.postForObject(
final HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.MULTIPART_FORM_DATA);
final MultiValueMap<String, String> fileMap = new LinkedMultiValueMap<>();
final ContentDisposition contentDisposition = ContentDisposition
.builder("form-data")
.name("file")
.filename(fileName)
.build();
fileMap.add(HttpHeaders.CONTENT_DISPOSITION, contentDisposition.toString());
final HttpEntity<byte[]> fileEntity = new HttpEntity<>(configData, fileMap);

final MultiValueMap<String, Object> body = new LinkedMultiValueMap<>();
body.add("token", this.accessToken.toString());
body.add("quizid", quizId);
body.add("file", fileEntity);

final HttpEntity<MultiValueMap<String, Object>> requestEntity =
new HttpEntity<>(body, headers);

final ResponseEntity<String> exchange = super.exchange(
uri.toString(),
multiPartAttributes,
HttpMethod.POST,
requestEntity,
String.class);

return exchange.getBody();

// multiPartAttributes.add("token", this.accessToken.toString());
//
// queryAttributes.forEach((key, values) -> {
// if (values.isEmpty()) {
// return;
// }
// if (uri.toString().contains("?")) {
// uri.append("&").append(key).append("=").append(values.get(0));
// } else {
// uri.append("?").append(key).append("=").append(values.get(0));
// }
// });
//
// log.info("Upload to Moodle url: {}", uri.toString());
//
// return super.postForObject(
// uri.toString(),
// multiPartAttributes,
// String.class);
}

private String doRequest(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -246,27 +246,28 @@ public Result<Exam> applyConnectionConfiguration(final Exam exam, final byte[] c
final String quizId = MoodleUtils.getQuizId(exam.externalId);
final String fileName = getConnectionConfigFileName(exam);

final MultiValueMap<String, Object> multiPartAttributes = new LinkedMultiValueMap<>();
multiPartAttributes.add("quizid", quizId);
multiPartAttributes.add("name", fileName);
multiPartAttributes.add("filename", fileName);

final MultiValueMap<String, String> queryAttributes = new LinkedMultiValueMap<>();
queryAttributes.add("quizid", quizId);
final ByteArrayResource contentsAsResource = new ByteArrayResource(configData) {
@Override
public String getFilename() {
return fileName; // Filename has to be returned in order to be able to post.
}
};

multiPartAttributes.add("file", contentsAsResource);
// final MultiValueMap<String, Object> multiPartAttributes = new LinkedMultiValueMap<>();
// multiPartAttributes.add("quizid", quizId);
// multiPartAttributes.add("name", fileName);
// multiPartAttributes.add("filename", fileName);

// final MultiValueMap<String, String> queryAttributes = new LinkedMultiValueMap<>();
// //queryAttributes.add("quizid", quizId);
// final ByteArrayResource contentsAsResource = new ByteArrayResource(configData) {
// @Override
// public String getFilename() {
// return fileName; // Filename has to be returned in order to be able to post.
// }
// };
//
// multiPartAttributes.add("file", contentsAsResource);

final MoodleAPIRestTemplate rest = getRestTemplate().getOrThrow();
final String response = rest.uploadMultiPart(
UPLOAD_ENDPOINT,
multiPartAttributes,
queryAttributes);
quizId,
fileName,
configData);

if (response != null) {
log.info("Upload Connection Configuration to Moodle: quizid: {}, fileName: {} response: {}", quizId, fileName, response );
Expand Down

0 comments on commit 644f0a4

Please sign in to comment.