diff --git a/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/Consul.java b/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/Consul.java index 6901ca2d00a..7e78c4fb735 100644 --- a/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/Consul.java +++ b/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/Consul.java @@ -8,6 +8,7 @@ public class Consul { public static final String BOOTSTRAP_FAST_PROPERTIES = "bootstrap-fast.properties"; private static final String DOCKER_CONSUL_IMAGE = "consul:1.11.1"; + private static final String DOCKER_CONSUL_CONFIG_LOADER_IMAGE = "jhipster/consul-config-loader:v0.4.1"; private static final String SPRING_CLOUD = "org.springframework.cloud"; private static final String SPRING_CLOUD_VERSION = "2021.0.0"; @@ -21,6 +22,10 @@ public static String getSpringCloudVersion() { return SPRING_CLOUD_VERSION; } + public static String getDockerConsulConfigLoaderImage() { + return DOCKER_CONSUL_CONFIG_LOADER_IMAGE; + } + public static Dependency springCloudDependencyManagement() { return Dependency .builder() diff --git a/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/ConsulDomainService.java b/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/ConsulDomainService.java index 8384e91d7b7..69f74e3a239 100644 --- a/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/ConsulDomainService.java +++ b/src/main/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/domain/ConsulDomainService.java @@ -5,6 +5,7 @@ import static tech.jhipster.lite.generator.project.domain.DefaultConfig.BASE_NAME; import static tech.jhipster.lite.generator.server.springboot.springcloud.consul.domain.Consul.*; +import tech.jhipster.lite.common.domain.Base64Utils; import tech.jhipster.lite.generator.buildtool.generic.domain.BuildToolService; import tech.jhipster.lite.generator.project.domain.Project; import tech.jhipster.lite.generator.project.domain.ProjectRepository; @@ -49,6 +50,17 @@ public void addProperties(Project project) { @Override public void addDockerConsul(Project project) { project.addConfig("dockerConsulImage", getDockerConsulImage()); + project.addConfig("dockerConsulConfigLoaderImage", getDockerConsulConfigLoaderImage()); + projectRepository.template(project, getPath(SOURCE, "src"), "consul.yml", "src/main/docker", "consul.yml"); + + project.addConfig("base64JwtSecret", Base64Utils.getBase64Secret()); + projectRepository.template( + project, + getPath(SOURCE, "docker"), + "application.config.yml", + "src/main/docker/central-server-config/", + "application.yml" + ); } } diff --git a/src/main/resources/generator/server/springboot/springcloud/consul/docker/application.config.yml.mustache b/src/main/resources/generator/server/springboot/springcloud/consul/docker/application.config.yml.mustache new file mode 100644 index 00000000000..4b753780630 --- /dev/null +++ b/src/main/resources/generator/server/springboot/springcloud/consul/docker/application.config.yml.mustache @@ -0,0 +1,12 @@ +# Common configuration shared between all applications +# This file is in format yaml as it is loaded by https://github.com/jhipster/consul-config-loader +configserver: + name: Docker Consul Service + status: Connected to Consul Server running in Docker + +jhipster: + security: + authentication: + jwt: + # secret key which should be base64 encoded and changed in production + base64-secret: {{{base64JwtSecret}}} diff --git a/src/main/resources/generator/server/springboot/springcloud/consul/src/bootstrap.properties.mustache b/src/main/resources/generator/server/springboot/springcloud/consul/src/bootstrap.properties.mustache index 2376cfdb764..c79986116b1 100644 --- a/src/main/resources/generator/server/springboot/springcloud/consul/src/bootstrap.properties.mustache +++ b/src/main/resources/generator/server/springboot/springcloud/consul/src/bootstrap.properties.mustache @@ -8,3 +8,5 @@ spring.cloud.consul.discovery.tags[0]=version=@project.version@ spring.cloud.consul.discovery.tags[1]=context-path=${server.servlet.context-path:} spring.cloud.consul.host=localhost spring.cloud.consul.port=8500 +spring.cloud.consul.config.format=yaml +spring.cloud.consul.config.profile-separator=- diff --git a/src/main/resources/generator/server/springboot/springcloud/consul/src/consul.yml.mustache b/src/main/resources/generator/server/springboot/springcloud/consul/src/consul.yml.mustache index dc16748cf5b..2d0d07f45de 100644 --- a/src/main/resources/generator/server/springboot/springcloud/consul/src/consul.yml.mustache +++ b/src/main/resources/generator/server/springboot/springcloud/consul/src/consul.yml.mustache @@ -10,3 +10,16 @@ services: - 127.0.0.1:8500:8500 - 127.0.0.1:8600:8600 command: consul agent -dev -ui -client 0.0.0.0 -log-level=INFO + + consul-config-loader: + image: {{dockerConsulConfigLoaderImage}} + volumes: + - ./central-server-config:/config + environment: + - INIT_SLEEP_SECONDS=5 + - CONSUL_URL=consul + - CONSUL_PORT=8500 + # Uncomment to load configuration into Consul from a Git repository + # as configured in central-server-config/git2consul.json + # Also set SPRING_CLOUD_CONSUL_CONFIG_FORMAT=files on your apps + # - CONFIG_MODE=git diff --git a/src/test/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/application/ConsulAssert.java b/src/test/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/application/ConsulAssert.java index ebce4055fa6..14e39561763 100644 --- a/src/test/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/application/ConsulAssert.java +++ b/src/test/java/tech/jhipster/lite/generator/server/springboot/springcloud/consul/application/ConsulAssert.java @@ -85,7 +85,7 @@ public static void assertProperties(Project project) { public static void assertDockerConsul(Project project) { assertFileExist(project, "src/main/docker/consul.yml"); - assertFileContent(project, "src/main/docker/consul.yml", getDockerConsulImage()); + assertFileExist(project, "src/main/docker/central-server-config/application.yml"); } }