mirror of
https://github.com/TeamPiped/Piped-Backend.git
synced 2024-08-14 23:51:41 +00:00
Add route to get file content.
This commit is contained in:
parent
0e04526217
commit
37b2a41903
2 changed files with 28 additions and 2 deletions
|
@ -480,8 +480,8 @@ public class ServerLauncher extends MultithreadedHttpServerLauncher {
|
||||||
}
|
}
|
||||||
})).map(GET, "/storage/stat", AsyncServlet.ofBlocking(executor, request -> {
|
})).map(GET, "/storage/stat", AsyncServlet.ofBlocking(executor, request -> {
|
||||||
try {
|
try {
|
||||||
var json = mapper.readTree(request.loadBody().getResult().asArray());
|
var file = request.getQueryParameter("file");
|
||||||
return getJsonResponse(StorageHandlers.statFile(request.getHeader(AUTHORIZATION), json.get("file").textValue()), "private");
|
return getJsonResponse(StorageHandlers.statFile(request.getHeader(AUTHORIZATION), file), "private");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
return getErrorResponse(e, request.getPath());
|
return getErrorResponse(e, request.getPath());
|
||||||
}
|
}
|
||||||
|
@ -496,6 +496,13 @@ public class ServerLauncher extends MultithreadedHttpServerLauncher {
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
return getErrorResponse(e, request.getPath());
|
return getErrorResponse(e, request.getPath());
|
||||||
}
|
}
|
||||||
|
})).map(GET, "/storage/get", AsyncServlet.ofBlocking(executor, request -> {
|
||||||
|
try {
|
||||||
|
var file = request.getQueryParameter("file");
|
||||||
|
return getRawResponse(StorageHandlers.getFile(request.getHeader(AUTHORIZATION), file), "application/octet-stream", "private");
|
||||||
|
} catch (Exception e) {
|
||||||
|
return getErrorResponse(e, request.getPath());
|
||||||
|
}
|
||||||
}))
|
}))
|
||||||
.map(GET, "/", AsyncServlet.ofBlocking(executor, request -> HttpResponse.redirect302(Constants.FRONTEND_URL)));
|
.map(GET, "/", AsyncServlet.ofBlocking(executor, request -> HttpResponse.redirect302(Constants.FRONTEND_URL)));
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package me.kavin.piped.server.handlers.auth;
|
package me.kavin.piped.server.handlers.auth;
|
||||||
|
|
||||||
|
import io.minio.GetObjectArgs;
|
||||||
import io.minio.PutObjectArgs;
|
import io.minio.PutObjectArgs;
|
||||||
import io.minio.StatObjectArgs;
|
import io.minio.StatObjectArgs;
|
||||||
import io.minio.errors.ErrorResponseException;
|
import io.minio.errors.ErrorResponseException;
|
||||||
|
@ -8,6 +9,7 @@ import me.kavin.piped.utils.DatabaseHelper;
|
||||||
import me.kavin.piped.utils.ExceptionHandler;
|
import me.kavin.piped.utils.ExceptionHandler;
|
||||||
import me.kavin.piped.utils.obj.db.User;
|
import me.kavin.piped.utils.obj.db.User;
|
||||||
import me.kavin.piped.utils.resp.SimpleErrorMessage;
|
import me.kavin.piped.utils.resp.SimpleErrorMessage;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.commons.lang3.exception.ExceptionUtils;
|
import org.apache.commons.lang3.exception.ExceptionUtils;
|
||||||
|
|
||||||
|
@ -98,4 +100,21 @@ public class StorageHandlers {
|
||||||
.put("status", "ok")
|
.put("status", "ok")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static byte[] getFile(String session, String name) throws Exception {
|
||||||
|
if (!StringUtils.isAlphanumeric(name) || name.length() > 32)
|
||||||
|
ExceptionHandler.throwErrorResponse(new SimpleErrorMessage("Invalid path provided!"));
|
||||||
|
|
||||||
|
User user = DatabaseHelper.getUserFromSession(session);
|
||||||
|
|
||||||
|
if (user == null)
|
||||||
|
ExceptionHandler.throwErrorResponse(new SimpleErrorMessage("Invalid session provided!"));
|
||||||
|
|
||||||
|
try (var stream = Constants.S3_CLIENT.getObject(GetObjectArgs.builder()
|
||||||
|
.bucket(Constants.S3_BUCKET)
|
||||||
|
.object(user.getId() + "/" + name)
|
||||||
|
.build())) {
|
||||||
|
return IOUtils.toByteArray(stream);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue