summaryrefslogtreecommitdiffstats
path: root/dozentenmodulserver/src/main/java
diff options
context:
space:
mode:
authorralph isenmann2021-11-10 16:25:43 +0100
committerralph isenmann2021-11-10 16:25:43 +0100
commit10f2c2f06fb37d20504f2baea280979f91635d55 (patch)
treeff90441c19aa6129f8950613a6a6706f7ab1b38b /dozentenmodulserver/src/main/java
parentMerge branch 'master' of git.openslx.org:openslx-ng/tutor-module (diff)
parentMerge branch 'feature/docker-data-container' of git.openslx.org:openslx-ng/tu... (diff)
downloadtutor-module-10f2c2f06fb37d20504f2baea280979f91635d55.tar.gz
tutor-module-10f2c2f06fb37d20504f2baea280979f91635d55.tar.xz
tutor-module-10f2c2f06fb37d20504f2baea280979f91635d55.zip
Merge branch 'feature/docker-data-container'
Diffstat (limited to 'dozentenmodulserver/src/main/java')
-rw-r--r--dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/database/mappers/DbImage.java67
-rw-r--r--dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/web/WebServer.java60
2 files changed, 82 insertions, 45 deletions
diff --git a/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/database/mappers/DbImage.java b/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/database/mappers/DbImage.java
index bac3ad6c..9c39078c 100644
--- a/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/database/mappers/DbImage.java
+++ b/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/database/mappers/DbImage.java
@@ -1,14 +1,6 @@
package org.openslx.bwlp.sat.database.mappers;
-import java.io.*;
-import java.sql.ResultSet;
-import java.sql.SQLException;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-import java.util.UUID;
-
+import com.google.gson.JsonObject;
import org.apache.log4j.Logger;
import org.openslx.bwlp.sat.RuntimeConfig;
import org.openslx.bwlp.sat.database.Database;
@@ -20,27 +12,20 @@ import org.openslx.bwlp.sat.database.models.LocalImageVersion;
import org.openslx.bwlp.sat.mail.MailGenerator;
import org.openslx.bwlp.sat.permissions.User;
import org.openslx.bwlp.sat.util.FileSystem;
-import org.openslx.bwlp.thrift.iface.ImageBaseWrite;
-import org.openslx.bwlp.thrift.iface.ImageDetailsRead;
-import org.openslx.bwlp.thrift.iface.ImagePermissions;
-import org.openslx.bwlp.thrift.iface.ImagePublishData;
-import org.openslx.bwlp.thrift.iface.ImageSummaryRead;
-import org.openslx.bwlp.thrift.iface.ImageVersionDetails;
-import org.openslx.bwlp.thrift.iface.ImageVersionWrite;
-import org.openslx.bwlp.thrift.iface.Role;
-import org.openslx.bwlp.thrift.iface.ShareMode;
-import org.openslx.bwlp.thrift.iface.TNotFoundException;
-import org.openslx.bwlp.thrift.iface.UserInfo;
+import org.openslx.bwlp.thrift.iface.*;
import org.openslx.filetransfer.util.ChunkList;
import org.openslx.filetransfer.util.FileChunk;
import org.openslx.util.QuickTimer;
import org.openslx.util.QuickTimer.Task;
import org.openslx.util.Util;
-
-// master-sync-shared
import org.openslx.virtualization.configuration.container.ContainerDefinition;
import org.openslx.virtualization.configuration.container.ContainerMeta;
+import java.io.File;
+import java.sql.ResultSet;
+import java.sql.SQLException;
+import java.util.*;
+
public class DbImage {
private static final Logger LOGGER = Logger.getLogger(DbImage.class);
@@ -1162,6 +1147,44 @@ public class DbImage {
}
}
+ public static String getContainerImageMetadata(String imagebaseid) throws SQLException {
+
+ try (MysqlConnection connection = Database.getConnection()) {
+ MysqlStatement stmt = connection.prepareStatement(
+ "SELECT ib.imagebaseid, ib.displayname, iv.filepath, iv.filesize, iv.virtualizerconfig"
+ + " FROM imagebase AS ib"
+ + " JOIN imageversion AS iv ON (ib.latestversionid=iv.imageversionid AND ib.virtid = 'docker' AND ib.latestversionid IS NOT NULL)"
+ + " WHERE ib.imagebaseid = :imagebaseid");
+ stmt.setString("imagebaseid", imagebaseid);
+ ResultSet rs = stmt.executeQuery();
+
+ JsonObject resultJson = new JsonObject();
+ while (rs.next()) {
+ ContainerDefinition condev = ContainerDefinition.fromByteArray(
+ rs.getBytes("iv.virtualizerconfig"));
+ // currently only data images are returned
+ if (condev.getContainerMeta().getImageType() != ContainerMeta.ContainerImageType.DATA)
+ break;
+
+ resultJson.addProperty("displayname", rs.getString("ib.displayname"));
+ resultJson.addProperty("imagepath", rs.getString("iv.filepath"));
+ resultJson.addProperty("filesize", rs.getString("iv.filesize"));
+
+ resultJson.addProperty("image_recipe", condev.getContainerRecipe());
+ resultJson.addProperty("image_repo", condev.getContainerMeta().getImageRepo());
+ resultJson.addProperty("build_context_method",
+ condev.getContainerMeta().getContainerImageContext());
+ resultJson.addProperty("build_context_url", condev.getContainerMeta().getBuildContextUrl());
+ break;
+ }
+
+ return resultJson.toString();
+ } catch (Exception e) {
+ LOGGER.error("Query failed in DbImage.getContainerImages()", e);
+ throw e;
+ }
+ }
+
static class ContainerImages {
public final String owner_firstname;
public final String owner_lastname;
diff --git a/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/web/WebServer.java b/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/web/WebServer.java
index a3d9d293..43e56137 100644
--- a/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/web/WebServer.java
+++ b/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/web/WebServer.java
@@ -41,9 +41,9 @@ import fi.iki.elonen.NanoHTTPD;
public class WebServer extends NanoHTTPD {
private static final Logger LOGGER = Logger.getLogger(WebServer.class);
-
- private static final ThreadPoolExecutor tpe =
- new GrowingThreadPoolExecutor(1, 8, 1, TimeUnit.MINUTES, new LinkedBlockingQueue<Runnable>(16));
+
+ private static final ThreadPoolExecutor tpe = new GrowingThreadPoolExecutor(1, 8, 1, TimeUnit.MINUTES,
+ new LinkedBlockingQueue<Runnable>(16));
private static final Serializer serializer = new Persister();
@@ -93,12 +93,20 @@ public class WebServer extends NanoHTTPD {
return serveMetaData(parts[2]);
if (parts[3].equals("netrules"))
return serveLectureNetRules(parts[2]);
+ if (parts[3].equals("imagemeta"))
+ return serveContainerImageMetaData(parts[2]);
}
return notFound();
}
if (uri.startsWith("/bwlp/container/clusterimages")) {
return serverContainerImages();
}
+ if (uri.startsWith("/image/container/")) {
+ if (parts.length < 4)
+ return badRequest("Bad Request");
+ if (parts[3].equals("metadata"))
+ return serveContainerImageMetaData(parts[2]);
+ }
if (uri.startsWith("/status/fileserver")) {
return serveStatus();
@@ -120,16 +128,14 @@ public class WebServer extends NanoHTTPD {
return new NanoHTTPD.Response(NanoHTTPD.Response.Status.OK, "application/json; charset=utf-8",
Json.serialize(FileServer.instance().getStatus()));
}
-
- private static void tarPutFile(TarOutputStream output, String fileName, String data) throws IOException
- {
+
+ private static void tarPutFile(TarOutputStream output, String fileName, String data) throws IOException {
if (data == null)
return;
tarPutFile(output, fileName, data.getBytes(StandardCharsets.UTF_8));
}
-
- private static void tarPutFile(TarOutputStream output, String fileName, byte[] data) throws IOException
- {
+
+ private static void tarPutFile(TarOutputStream output, String fileName, byte[] data) throws IOException {
if (data == null)
return;
output.putNextEntry(new TarEntry(TarHeader.createHeader(fileName, data.length, Util.unixTime(), false, 0644)));
@@ -166,8 +172,7 @@ public class WebServer extends NanoHTTPD {
if (ld.runScript != null) {
int cnt = 0;
for (RunScript rs : ld.runScript) {
- tarPutFile(output, String.format("adminrun/%04d-%d-%d.%s",
- cnt++, rs.visibility,
+ tarPutFile(output, String.format("adminrun/%04d-%d-%d.%s", cnt++, rs.visibility,
rs.passCreds ? 1 : 0, rs.extension), rs.content);
}
}
@@ -185,10 +190,9 @@ public class WebServer extends NanoHTTPD {
LOGGER.warn("Server overloaded; rejecting VM Metadata request", e2);
return internalServerError();
}
- return new NanoHTTPD.Response(NanoHTTPD.Response.Status.OK, "application/gzip",
- sink);
+ return new NanoHTTPD.Response(NanoHTTPD.Response.Status.OK, "application/gzip", sink);
}
-
+
private Response serveLectureNetRules(String lectureId) {
List<NetRule> list = new ArrayList<>();
boolean defaultAllowed;
@@ -217,13 +221,12 @@ public class WebServer extends NanoHTTPD {
sb.append("IN * 0 REJECT\n");
sb.append("OUT * 0 REJECT\n");
}
- return new NanoHTTPD.Response(NanoHTTPD.Response.Status.OK, "text/plain; charset=utf-8",
- sb.toString());
+ return new NanoHTTPD.Response(NanoHTTPD.Response.Status.OK, "text/plain; charset=utf-8", sb.toString());
}
private String serializeNetShares(List<NetShare> list) {
// openslx.exe expects shares in the following format
- // <path> <letter> <shortcut> <username> <password>
+ // <path> <letter> <shortcut> <username> <password>
// letter is either a drive letter for Windows VMs,
// or a mount point for Linux VMs.
StringBuilder sb = new StringBuilder();
@@ -270,13 +273,13 @@ public class WebServer extends NanoHTTPD {
/**
* Helper for returning "Internal Server Error" Status
- * @param body Message
+ *
+ * @param body Message
*/
public static Response internalServerError(String body) {
- return new NanoHTTPD.Response(NanoHTTPD.Response.Status.INTERNAL_ERROR, "text/plain",
- body);
+ return new NanoHTTPD.Response(NanoHTTPD.Response.Status.INTERNAL_ERROR, "text/plain", body);
}
-
+
public static Response internalServerError() {
return internalServerError("Internal Server Error");
}
@@ -299,9 +302,10 @@ public class WebServer extends NanoHTTPD {
}
/**
- * create a json response with information about existing container images in bwlehrpool
+ * create a json response with information about existing container images in
+ * bwlehrpool
*/
- private Response serverContainerImages () {
+ private Response serverContainerImages() {
try {
return new Response(Response.Status.OK, "application/json; charset=utf-8",
Json.serialize(DbImage.getContainerImageCluster()));
@@ -310,4 +314,14 @@ public class WebServer extends NanoHTTPD {
return internalServerError();
}
}
+
+ private Response serveContainerImageMetaData(String imageBaseId) {
+ try {
+ return new Response(Response.Status.OK, "application/json; charset=utf-8",
+ DbImage.getContainerImageMetadata(imageBaseId));
+ } catch (SQLException e) {
+ LOGGER.error("error -- could not server container image", e);
+ return internalServerError();
+ }
+ }
}