mirror of
https://github.com/TeamPiped/Piped-Backend.git
synced 2024-08-14 23:51:41 +00:00
perf: add server timings
This commit is contained in:
parent
6d8ccdb728
commit
ec247f5bce
1 changed files with 46 additions and 31 deletions
|
@ -30,19 +30,22 @@ public class Main {
|
||||||
|
|
||||||
routes.get("/webhooks/pubsub", (req, res) -> {
|
routes.get("/webhooks/pubsub", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, query.parameters().get("hub.challenge").get(0), 200, "private");
|
return writeResponse(res, query.parameters().get("hub.challenge").get(0), 200, "private", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.post("/webhooks/pubsub", (req, res) -> {
|
routes.post("/webhooks/pubsub", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
req.receive().asInputStream().subscribe(in -> {
|
req.receive().asInputStream().subscribe(in -> {
|
||||||
try {
|
try {
|
||||||
|
@ -57,145 +60,155 @@ public class Main {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return writeResponse(res, "ok", 200, "private");
|
return writeResponse(res, "ok", 200, "private", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/sponsors/{videoId}", (req, res) -> {
|
routes.get("/sponsors/{videoId}", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, SponsorBlockUtils.getSponsors(req.param("videoId"),
|
return writeResponse(res, SponsorBlockUtils.getSponsors(req.param("videoId"),
|
||||||
query.parameters().get("category").get(0)), 200, "public, max-age=3600");
|
query.parameters().get("category").get(0)), 200, "public, max-age=3600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/streams/{videoId}", (req, res) -> {
|
routes.get("/streams/{videoId}", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
try {
|
try {
|
||||||
// The stream links are valid for 6 hours.
|
// The stream links are valid for 6 hours.
|
||||||
return writeResponse(res, ResponseHelper.streamsResponse(req.param("videoId")), 200,
|
return writeResponse(res, ResponseHelper.streamsResponse(req.param("videoId")), 200,
|
||||||
"public, s-maxage=21540");
|
"public, s-maxage=21540", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/channels/{channelId}", (req, res) -> {
|
routes.get("/channels/{channelId}", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, ResponseHelper.channelResponse(req.param("channelId")), 200,
|
return writeResponse(res, ResponseHelper.channelResponse(req.param("channelId")), 200,
|
||||||
"public, max-age=600");
|
"public, max-age=600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/nextpage/channels/{channelId}", (req, res) -> {
|
routes.get("/nextpage/channels/{channelId}", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, ResponseHelper.channelPageResponse(req.param("channelId"),
|
return writeResponse(res, ResponseHelper.channelPageResponse(req.param("channelId"),
|
||||||
query.parameters().get("url").get(0)), 200, "public, max-age=3600");
|
query.parameters().get("url").get(0)), 200, "public, max-age=3600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/playlists/{playlistId}", (req, res) -> {
|
routes.get("/playlists/{playlistId}", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, ResponseHelper.playlistResponse(req.param("playlistId")), 200,
|
return writeResponse(res, ResponseHelper.playlistResponse(req.param("playlistId")), 200,
|
||||||
"public, max-age=600");
|
"public, max-age=600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/nextpage/playlists/{playlistId}", (req, res) -> {
|
routes.get("/nextpage/playlists/{playlistId}", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, ResponseHelper.playlistPageResponse(req.param("playlistId"),
|
return writeResponse(res, ResponseHelper.playlistPageResponse(req.param("playlistId"),
|
||||||
query.parameters().get("url").get(0)), 200, "public, max-age=3600");
|
query.parameters().get("url").get(0)), 200, "public, max-age=3600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/suggestions", (req, res) -> {
|
routes.get("/suggestions", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res,
|
return writeResponse(res,
|
||||||
ResponseHelper.suggestionsResponse(query.parameters().get("query").get(0)), 200,
|
ResponseHelper.suggestionsResponse(query.parameters().get("query").get(0)), 200,
|
||||||
"public, max-age=600");
|
"public, max-age=600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/search", (req, res) -> {
|
routes.get("/search", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, ResponseHelper.searchResponse(query.parameters().get("q").get(0)), 200,
|
return writeResponse(res, ResponseHelper.searchResponse(query.parameters().get("q").get(0)), 200,
|
||||||
"public, max-age=600");
|
"public, max-age=600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/nextpage/search", (req, res) -> {
|
routes.get("/nextpage/search", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
QueryStringDecoder query = new QueryStringDecoder(req.uri());
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return writeResponse(res,
|
return writeResponse(res,
|
||||||
ResponseHelper.searchPageResponse(query.parameters().get("q").get(0),
|
ResponseHelper.searchPageResponse(query.parameters().get("q").get(0),
|
||||||
query.parameters().get("url").get(0), query.parameters().get("id").get(0)),
|
query.parameters().get("url").get(0), query.parameters().get("id").get(0)),
|
||||||
200, "public, max-age=3600");
|
200, "public, max-age=3600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
routes.get("/trending", (req, res) -> {
|
routes.get("/trending", (req, res) -> {
|
||||||
|
|
||||||
|
long start = System.nanoTime();
|
||||||
try {
|
try {
|
||||||
return writeResponse(res, ResponseHelper.trendingResponse(), 200, "public, max-age=3600");
|
return writeResponse(res, ResponseHelper.trendingResponse(), 200, "public, max-age=3600", start);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private");
|
return writeResponse(res, ExceptionUtils.getStackTrace(e), 500, "private", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -205,14 +218,16 @@ public class Main {
|
||||||
Thread.sleep(Long.MAX_VALUE);
|
Thread.sleep(Long.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static NettyOutbound writeResponse(HttpServerResponse res, String resp, int code, String cache) {
|
public static NettyOutbound writeResponse(HttpServerResponse res, String resp, int code, String cache, long time) {
|
||||||
return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache)
|
return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache)
|
||||||
|
.addHeader("Server-Timing", "app;dur=" + (System.nanoTime() - time) / 1000000.0)
|
||||||
.send(ByteBufFlux.fromString(Flux.just(resp), java.nio.charset.StandardCharsets.UTF_8,
|
.send(ByteBufFlux.fromString(Flux.just(resp), java.nio.charset.StandardCharsets.UTF_8,
|
||||||
ByteBufAllocator.DEFAULT));
|
ByteBufAllocator.DEFAULT));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static NettyOutbound writeResponse(HttpServerResponse res, byte[] resp, int code, String cache) {
|
public static NettyOutbound writeResponse(HttpServerResponse res, byte[] resp, int code, String cache, long time) {
|
||||||
return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache)
|
return res.compression(true).addHeader("Access-Control-Allow-Origin", "*").addHeader("Cache-Control", cache)
|
||||||
|
.addHeader("Server-Timing", "app;dur=" + (System.nanoTime() - time) / 1000000.0)
|
||||||
.sendByteArray(Flux.just(resp));
|
.sendByteArray(Flux.just(resp));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue