12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- package com.provectus.kafka.ui.controller;
- import com.provectus.kafka.ui.util.ResourceUtil;
- import java.util.concurrent.atomic.AtomicReference;
- import lombok.RequiredArgsConstructor;
- import lombok.SneakyThrows;
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.core.io.Resource;
- import org.springframework.http.ResponseEntity;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.RestController;
- import org.springframework.web.server.ServerWebExchange;
- import reactor.core.publisher.Mono;
- @RestController
- @RequiredArgsConstructor
- @Slf4j
- public class StaticController {
- @Value("classpath:static/index.html")
- private Resource indexFile;
- @Value("classpath:static/manifest.json")
- private Resource manifestFile;
- private final AtomicReference<String> renderedIndexFile = new AtomicReference<>();
- private final AtomicReference<String> renderedManifestFile = new AtomicReference<>();
- @GetMapping(value = "/index.html", produces = {"text/html"})
- public Mono<ResponseEntity<String>> getIndex(ServerWebExchange exchange) {
- return Mono.just(ResponseEntity.ok(getRenderedFile(exchange, renderedIndexFile, indexFile)));
- }
- @GetMapping(value = "/manifest.json", produces = {"application/json"})
- public Mono<ResponseEntity<String>> getManifest(ServerWebExchange exchange) {
- return Mono.just(ResponseEntity.ok(getRenderedFile(exchange, renderedManifestFile, manifestFile)));
- }
- public String getRenderedFile(ServerWebExchange exchange, AtomicReference<String> renderedFile, Resource file) {
- String rendered = renderedFile.get();
- if (rendered == null) {
- rendered = buildFile(file, exchange.getRequest().getPath().contextPath().value());
- if (renderedFile.compareAndSet(null, rendered)) {
- return rendered;
- } else {
- return renderedFile.get();
- }
- } else {
- return rendered;
- }
- }
- @SneakyThrows
- private String buildFile(Resource file, String contextPath) {
- return ResourceUtil.readAsString(file)
- .replace("\"/assets/", "\"" + contextPath + "/assets/")
- .replace("\"/favicon/", "\"" + contextPath + "/favicon/")
- .replace("/manifest.json", contextPath + "/manifest.json")
- .replace("window.basePath = ''", "window.basePath=\"" + contextPath + "\"");
- }
- }
|