From c38b96c36a373e69faa291e4f225109b7966575f Mon Sep 17 00:00:00 2001 From: Piyush7034 Date: Tue, 17 Dec 2024 19:29:57 +0530 Subject: [PATCH] [INJICERT-657] Added review changed related to rendering template names and docker Signed-off-by: Piyush7034 --- ...n.java => RenderingTemplateException.java} | 6 +- .../certify/api/dto/RenderingTemplateDTO.java | 13 +++ .../advice/ExceptionHandlerAdvice.java | 4 +- .../mosip/certify/config/TemplatesLoader.java | 93 ------------------- .../RenderingTemplateController.java | 9 +- .../services/CertifyIssuanceServiceImpl.java | 6 +- ...{RenderUtils.java => CredentialUtils.java} | 2 +- .../RenderingTemplateServiceImpl.java | 14 ++- .../spi/RenderingTemplateService.java | 4 +- .../VelocityTemplatingEngineImpl.java | 10 +- .../src/main/resources/svg-template.json | 6 -- .../RenderingTemplateControllerTest.java | 19 ++-- .../certify/services/RenderUtilsTest.java | 2 +- .../RenderingTemplateServiceImplTest.java | 7 +- .../resources/application-test.properties | 1 - .../src/test/resources/svg-template.json | 6 -- .../config/certify-csvdp-farmer.properties | 5 +- .../config/farmer_identity_data.csv | 4 +- .../docker-compose.yaml | 11 ++- .../docker-compose-injistack/nginx.conf | 22 +++++ 20 files changed, 91 insertions(+), 153 deletions(-) rename certify-core/src/main/java/io/mosip/certify/core/exception/{TemplateException.java => RenderingTemplateException.java} (69%) create mode 100644 certify-integration-api/src/main/java/io/mosip/certify/api/dto/RenderingTemplateDTO.java delete mode 100644 certify-service/src/main/java/io/mosip/certify/config/TemplatesLoader.java rename certify-service/src/main/java/io/mosip/certify/services/{RenderUtils.java => CredentialUtils.java} (97%) delete mode 100644 certify-service/src/main/resources/svg-template.json delete mode 100644 certify-service/src/test/resources/svg-template.json diff --git a/certify-core/src/main/java/io/mosip/certify/core/exception/TemplateException.java b/certify-core/src/main/java/io/mosip/certify/core/exception/RenderingTemplateException.java similarity index 69% rename from certify-core/src/main/java/io/mosip/certify/core/exception/TemplateException.java rename to certify-core/src/main/java/io/mosip/certify/core/exception/RenderingTemplateException.java index cf3e9939..f04579b7 100644 --- a/certify-core/src/main/java/io/mosip/certify/core/exception/TemplateException.java +++ b/certify-core/src/main/java/io/mosip/certify/core/exception/RenderingTemplateException.java @@ -2,15 +2,15 @@ import io.mosip.certify.core.constants.ErrorConstants; -public class TemplateException extends RuntimeException { +public class RenderingTemplateException extends RuntimeException { private String errorCode; - public TemplateException() { + public RenderingTemplateException() { super(ErrorConstants.UNKNOWN_ERROR); this.errorCode = ErrorConstants.UNKNOWN_ERROR; } - public TemplateException(String errorCode) { + public RenderingTemplateException(String errorCode) { super(errorCode); this.errorCode = errorCode; } diff --git a/certify-integration-api/src/main/java/io/mosip/certify/api/dto/RenderingTemplateDTO.java b/certify-integration-api/src/main/java/io/mosip/certify/api/dto/RenderingTemplateDTO.java new file mode 100644 index 00000000..4b720e10 --- /dev/null +++ b/certify-integration-api/src/main/java/io/mosip/certify/api/dto/RenderingTemplateDTO.java @@ -0,0 +1,13 @@ +package io.mosip.certify.api.dto; + +import lombok.Data; + +import java.time.LocalDateTime; + +@Data +public class RenderingTemplateDTO { + private String id; + private String template; + private LocalDateTime createdTimes; + private LocalDateTime updatedTimes; +} diff --git a/certify-service/src/main/java/io/mosip/certify/advice/ExceptionHandlerAdvice.java b/certify-service/src/main/java/io/mosip/certify/advice/ExceptionHandlerAdvice.java index 6d0cdfca..e7ca7539 100644 --- a/certify-service/src/main/java/io/mosip/certify/advice/ExceptionHandlerAdvice.java +++ b/certify-service/src/main/java/io/mosip/certify/advice/ExceptionHandlerAdvice.java @@ -11,7 +11,7 @@ import io.mosip.certify.core.exception.CertifyException; import io.mosip.certify.core.exception.InvalidRequestException; import io.mosip.certify.core.exception.NotAuthenticatedException; -import io.mosip.certify.core.exception.TemplateException; +import io.mosip.certify.core.exception.RenderingTemplateException; import io.mosip.certify.core.util.CommonUtil; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.TypeMismatchException; @@ -131,7 +131,7 @@ private ResponseEntity handleInternalControllerException(Except String errorCode = ((CertifyException) ex).getErrorCode(); return new ResponseEntity(getResponseWrapper(errorCode, getMessage(errorCode)), HttpStatus.OK); } - if(ex instanceof TemplateException) { + if(ex instanceof RenderingTemplateException) { return new ResponseEntity<>(getResponseWrapper(INVALID_REQUEST, ex.getMessage()) ,HttpStatus.NOT_FOUND); } if(ex instanceof AuthenticationCredentialsNotFoundException) { diff --git a/certify-service/src/main/java/io/mosip/certify/config/TemplatesLoader.java b/certify-service/src/main/java/io/mosip/certify/config/TemplatesLoader.java deleted file mode 100644 index ea3f5b18..00000000 --- a/certify-service/src/main/java/io/mosip/certify/config/TemplatesLoader.java +++ /dev/null @@ -1,93 +0,0 @@ -/* - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at https://mozilla.org/MPL/2.0/. - */ - -/* This is for temporary purpose till an API isn’t added to simplify Issuer onboarding. */ - -package io.mosip.certify.config; - -import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import io.mosip.certify.services.entity.RenderingTemplate; -import io.mosip.certify.services.repository.RenderingTemplateRepository; -import lombok.extern.slf4j.Slf4j; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.boot.CommandLineRunner; -import org.springframework.context.annotation.Configuration; -import org.springframework.core.io.ClassPathResource; -import org.springframework.core.io.Resource; -import org.springframework.web.client.RestTemplate; - -import java.io.IOException; -import java.nio.file.Files; -import java.time.LocalDateTime; -import java.util.*; - - -@Configuration -@Slf4j -public class TemplatesLoader implements CommandLineRunner { - @Autowired - RenderingTemplateRepository svgRenderTemplateRepository; - - @Value("${mosip.certify.rendering-templates:}") - private String svgTemplateJson; - - @Autowired - private ObjectMapper objectMapper; - - @Autowired - private RestTemplate restTemplate; - - @Override - public void run(String... args) throws Exception { - Long count = svgRenderTemplateRepository.count(); - if (count != 0) { - return; - } - String svgTemplateContent = ""; - - if(svgTemplateJson.startsWith("http")) { - svgTemplateContent = restTemplate.getForObject(svgTemplateJson, String.class); - } else { - Resource resource = new ClassPathResource(svgTemplateJson); - // TODO: Verify this w.r.t local path - try { - svgTemplateContent = (Files.readString(resource.getFile().toPath())); - } catch (IOException e) { - log.error("Missing local json file for referring svg templates", e); - } - } - - if(!svgTemplateContent.isEmpty()) { - try { - List svgTemplateMap = objectMapper.readValue(svgTemplateContent, List.class); - svgTemplateMap.forEach((value) -> { - RenderingTemplate svgRenderTemplate = new RenderingTemplate(); - LinkedHashMap valueMap = (LinkedHashMap) value; - String id = valueMap.get("id").toString(); - svgRenderTemplate.setId(id); - String templateURI = valueMap.get("content").toString(); - if(templateURI.startsWith("http")) { - String templateFromUrl = restTemplate.getForObject(templateURI, String.class); - svgRenderTemplate.setTemplate(templateFromUrl); - } else { - svgRenderTemplate.setTemplate(templateURI); - } - LocalDateTime localDateTime = LocalDateTime.now(); - svgRenderTemplate.setCreatedtimes(localDateTime); - svgRenderTemplate.setUpdatedtimes(localDateTime); - log.info("Template inserted in svg template table."); - svgRenderTemplateRepository.save(svgRenderTemplate); - }); - } catch (JsonProcessingException e) { - log.error("Missing configuration for svg template content " + e.getMessage()); - } - - } - log.info("=============== CERTIFY TEMPLATE SETUP COMPLETED ==============="); - } -} diff --git a/certify-service/src/main/java/io/mosip/certify/controller/RenderingTemplateController.java b/certify-service/src/main/java/io/mosip/certify/controller/RenderingTemplateController.java index c709439e..41178d55 100644 --- a/certify-service/src/main/java/io/mosip/certify/controller/RenderingTemplateController.java +++ b/certify-service/src/main/java/io/mosip/certify/controller/RenderingTemplateController.java @@ -5,8 +5,9 @@ */ package io.mosip.certify.controller; +import io.mosip.certify.api.dto.RenderingTemplateDTO; import io.mosip.certify.services.entity.RenderingTemplate; -import io.mosip.certify.core.exception.TemplateException; +import io.mosip.certify.core.exception.RenderingTemplateException; import io.mosip.certify.services.spi.RenderingTemplateService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; @@ -32,12 +33,12 @@ public class RenderingTemplateController { RenderingTemplateService renderingTemplateService; @GetMapping("/rendering-template/{id}") - public ResponseEntity serveSvgTemplate(@PathVariable String id) throws TemplateException { - RenderingTemplate template = renderingTemplateService.getSvgTemplate(id); + public ResponseEntity serveSvgTemplate(@PathVariable String id) throws RenderingTemplateException { + RenderingTemplateDTO template = renderingTemplateService.getSvgTemplate(id); return ResponseEntity.ok() .header(HttpHeaders.CONTENT_TYPE, "image/svg+xml") .cacheControl(CacheControl.maxAge(maxAgeDays, TimeUnit.DAYS).cachePublic()) - .lastModified(template.getUpdatedtimes().atZone(ZoneId.systemDefault()).toInstant()) + .lastModified(template.getUpdatedTimes().atZone(ZoneId.systemDefault()).toInstant()) .body(template.getTemplate()); } } diff --git a/certify-service/src/main/java/io/mosip/certify/services/CertifyIssuanceServiceImpl.java b/certify-service/src/main/java/io/mosip/certify/services/CertifyIssuanceServiceImpl.java index 203d1fe1..0ae39af1 100644 --- a/certify-service/src/main/java/io/mosip/certify/services/CertifyIssuanceServiceImpl.java +++ b/certify-service/src/main/java/io/mosip/certify/services/CertifyIssuanceServiceImpl.java @@ -75,7 +75,7 @@ public class CertifyIssuanceServiceImpl implements VCIssuanceService { private String issuerURI; @Value("${mosip.certify.data-provider-plugin.rendering-template-id:}") - private String svgTemplateId; + private String renderTemplateId; @Autowired private ProofValidatorFactory proofValidatorFactory; @@ -285,8 +285,8 @@ private VCResult getVerifiableCredential(CredentialRequest credentialRequest, Map templateParams = new HashMap<>(); templateParams.put(VelocityTemplatingConstants.TEMPLATE_NAME, CredentialUtils.getTemplateName(vcRequestDto)); templateParams.put(VelocityTemplatingConstants.ISSUER_URI, issuerURI); - if (!StringUtils.isEmpty(svgTemplateId)) { - templateParams.put(VelocityTemplatingConstants.SVG_TEMPLATE, svgTemplateId); + if (!StringUtils.isEmpty(renderTemplateId)) { + templateParams.put(VelocityTemplatingConstants.SVG_TEMPLATE, renderTemplateId); } String unSignedVC = vcFormatter.format(jsonObject, templateParams); vcResult = vcSigner.attachSignature(unSignedVC); diff --git a/certify-service/src/main/java/io/mosip/certify/services/RenderUtils.java b/certify-service/src/main/java/io/mosip/certify/services/CredentialUtils.java similarity index 97% rename from certify-service/src/main/java/io/mosip/certify/services/RenderUtils.java rename to certify-service/src/main/java/io/mosip/certify/services/CredentialUtils.java index 9e885e34..2234a1ad 100644 --- a/certify-service/src/main/java/io/mosip/certify/services/RenderUtils.java +++ b/certify-service/src/main/java/io/mosip/certify/services/CredentialUtils.java @@ -6,7 +6,7 @@ import io.ipfs.multibase.Multibase; -public class RenderUtils { +public class CredentialUtils { /** * Generate SVG digest for @param svg image as per spec. * ref: https://w3c-ccg.github.io/vc-render-method/#svgrenderingtemplate diff --git a/certify-service/src/main/java/io/mosip/certify/services/RenderingTemplateServiceImpl.java b/certify-service/src/main/java/io/mosip/certify/services/RenderingTemplateServiceImpl.java index bf94e977..edc7c6f5 100644 --- a/certify-service/src/main/java/io/mosip/certify/services/RenderingTemplateServiceImpl.java +++ b/certify-service/src/main/java/io/mosip/certify/services/RenderingTemplateServiceImpl.java @@ -5,9 +5,10 @@ */ package io.mosip.certify.services; +import io.mosip.certify.api.dto.RenderingTemplateDTO; import io.mosip.certify.core.constants.ErrorConstants; import io.mosip.certify.services.entity.RenderingTemplate; -import io.mosip.certify.core.exception.TemplateException; +import io.mosip.certify.core.exception.RenderingTemplateException; import io.mosip.certify.services.repository.RenderingTemplateRepository; import io.mosip.certify.services.spi.RenderingTemplateService; import lombok.extern.slf4j.Slf4j; @@ -24,11 +25,16 @@ public class RenderingTemplateServiceImpl implements RenderingTemplateService { @Override - public RenderingTemplate getSvgTemplate(String id) { + public RenderingTemplateDTO getSvgTemplate(String id) { Optional optional = svgRenderTemplateRepository.findById(id); - RenderingTemplate svgRenderTemplate = optional.orElseThrow(() -> new TemplateException(ErrorConstants.INVALID_TEMPLATE_ID)); + RenderingTemplate renderingTemplate = optional.orElseThrow(() -> new RenderingTemplateException(ErrorConstants.INVALID_TEMPLATE_ID)); + RenderingTemplateDTO renderingTemplateDTO = new RenderingTemplateDTO(); + renderingTemplateDTO.setId(renderingTemplate.getId()); + renderingTemplateDTO.setTemplate(renderingTemplate.getTemplate()); + renderingTemplateDTO.setCreatedTimes(renderingTemplate.getCreatedtimes()); + renderingTemplateDTO.setUpdatedTimes(renderingTemplate.getUpdatedtimes()); - return svgRenderTemplate; + return renderingTemplateDTO; } } diff --git a/certify-service/src/main/java/io/mosip/certify/services/spi/RenderingTemplateService.java b/certify-service/src/main/java/io/mosip/certify/services/spi/RenderingTemplateService.java index da701c01..f2b487c0 100644 --- a/certify-service/src/main/java/io/mosip/certify/services/spi/RenderingTemplateService.java +++ b/certify-service/src/main/java/io/mosip/certify/services/spi/RenderingTemplateService.java @@ -5,9 +5,9 @@ */ package io.mosip.certify.services.spi; -import io.mosip.certify.services.entity.RenderingTemplate; +import io.mosip.certify.api.dto.RenderingTemplateDTO; public interface RenderingTemplateService { - RenderingTemplate getSvgTemplate(String id); + RenderingTemplateDTO getSvgTemplate(String id); } diff --git a/certify-service/src/main/java/io/mosip/certify/services/templating/VelocityTemplatingEngineImpl.java b/certify-service/src/main/java/io/mosip/certify/services/templating/VelocityTemplatingEngineImpl.java index 3127831b..5cc0684f 100644 --- a/certify-service/src/main/java/io/mosip/certify/services/templating/VelocityTemplatingEngineImpl.java +++ b/certify-service/src/main/java/io/mosip/certify/services/templating/VelocityTemplatingEngineImpl.java @@ -16,10 +16,10 @@ import io.mosip.certify.core.constants.Constants; import io.mosip.certify.core.constants.VCDM2Constants; import io.mosip.certify.core.constants.VCDMConstants; -import io.mosip.certify.core.exception.TemplateException; +import io.mosip.certify.core.exception.RenderingTemplateException; import io.mosip.certify.services.repository.TemplateRepository; import io.mosip.certify.services.spi.RenderingTemplateService; -import io.mosip.certify.services.RenderUtils; +import io.mosip.certify.services.CredentialUtils; import jakarta.annotation.PostConstruct; import lombok.SneakyThrows; import lombok.extern.slf4j.Slf4j; @@ -83,7 +83,7 @@ public String format(JSONObject valueMap, Map templateSettings) String template = getTemplate(templateName); if (template == null) { log.error("Template {} not found", templateName); - throw new TemplateException("Expected template not found"); + throw new RenderingTemplateException("Expected template not found"); } String issuer = templateSettings.get(ISSUER_URI).toString(); StringWriter writer = new StringWriter(); @@ -117,9 +117,9 @@ public String format(JSONObject valueMap, Map templateSettings) if (templateSettings.containsKey(SVG_TEMPLATE) && templateName.contains(VCDM2Constants.URL)) { try { finalTemplate.put("_renderMethodSVGdigest", - RenderUtils.getDigestMultibase(renderingTemplateService.getSvgTemplate( + CredentialUtils.getDigestMultibase(renderingTemplateService.getSvgTemplate( (String) templateSettings.get(SVG_TEMPLATE)).getTemplate())); - } catch (TemplateException e) { + } catch (RenderingTemplateException e) { log.error("SVG Template: " + templateSettings.get(SVG_TEMPLATE) + " not available in DB", e); } } diff --git a/certify-service/src/main/resources/svg-template.json b/certify-service/src/main/resources/svg-template.json deleted file mode 100644 index 26d50c03..00000000 --- a/certify-service/src/main/resources/svg-template.json +++ /dev/null @@ -1,6 +0,0 @@ -[ - { - "id": "5b9c2a12-810a-7388-2dc8-13ee7ad88bac", - "content": "\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n {{credentialSubject/policyName}}\n {{credentialSubject/policyNumber}}\n {{credentialSubject/fullName}}\n {{credentialSubject/gender}}\n {{credentialSubject/email}}\n {{credentialSubject/mobile}}\n\n Policy Issued On\n {{credentialSubject/policyIssuedOn}}\n\n Policy Expires On\n {{credentialSubject/policyExpiresOn}}\n\n Issuance Date On\n {{issuanceDate}}\n\n Expiration Date On\n {{expirationDate}}\n" - } -] \ No newline at end of file diff --git a/certify-service/src/test/java/io/mosip/certify/controller/RenderingTemplateControllerTest.java b/certify-service/src/test/java/io/mosip/certify/controller/RenderingTemplateControllerTest.java index 8fe8b87f..af4457f7 100644 --- a/certify-service/src/test/java/io/mosip/certify/controller/RenderingTemplateControllerTest.java +++ b/certify-service/src/test/java/io/mosip/certify/controller/RenderingTemplateControllerTest.java @@ -1,9 +1,10 @@ package io.mosip.certify.controller; +import io.mosip.certify.api.dto.RenderingTemplateDTO; import io.mosip.certify.core.constants.ErrorConstants; import io.mosip.certify.core.dto.ParsedAccessToken; import io.mosip.certify.services.entity.RenderingTemplate; -import io.mosip.certify.core.exception.TemplateException; +import io.mosip.certify.core.exception.RenderingTemplateException; import io.mosip.certify.services.spi.RenderingTemplateService; import org.junit.Test; import org.junit.runner.RunWith; @@ -32,8 +33,8 @@ public class RenderingTemplateControllerTest { @Test public void getSvgTemplate_withValidId_thenPass() throws Exception { - RenderingTemplate renderingTemplate = new RenderingTemplate(); - renderingTemplate.setId("fake-id"); + RenderingTemplateDTO renderingTemplateDTO = new RenderingTemplateDTO(); + renderingTemplateDTO.setId("fake-id"); String template = """ @@ -41,23 +42,23 @@ public void getSvgTemplate_withValidId_thenPass() throws Exception { Hello, SVG! """; - renderingTemplate.setTemplate(template); + renderingTemplateDTO.setTemplate(template); LocalDateTime date = LocalDateTime.now(); - renderingTemplate.setCreatedtimes(date); - renderingTemplate.setUpdatedtimes(date); + renderingTemplateDTO.setCreatedTimes(date); + renderingTemplateDTO.setUpdatedTimes(date); - Mockito.when(renderingTemplateService.getSvgTemplate(Mockito.any())).thenReturn(renderingTemplate); + Mockito.when(renderingTemplateService.getSvgTemplate(Mockito.any())).thenReturn(renderingTemplateDTO); mockMvc.perform(get("/public/rendering-template/fake-id")) .andExpect(status().isOk()) - .andExpect(content().string(renderingTemplate.getTemplate())) + .andExpect(content().string(renderingTemplateDTO.getTemplate())) .andExpect(content().contentType("image/svg+xml")) .andExpect(header().string("Cache-Control", "max-age=86400, public")); } @Test public void getSvgTemplate_withInValidId_thenFail() throws Exception { - TemplateException templateException = new TemplateException(ErrorConstants.INVALID_TEMPLATE_ID); + RenderingTemplateException templateException = new RenderingTemplateException(ErrorConstants.INVALID_TEMPLATE_ID); Mockito.when(renderingTemplateService.getSvgTemplate("fake-id")).thenThrow(templateException); mockMvc.perform(get("/public/rendering-template/fake-id")) diff --git a/certify-service/src/test/java/io/mosip/certify/services/RenderUtilsTest.java b/certify-service/src/test/java/io/mosip/certify/services/RenderUtilsTest.java index 9ed3aa24..2e89369d 100644 --- a/certify-service/src/test/java/io/mosip/certify/services/RenderUtilsTest.java +++ b/certify-service/src/test/java/io/mosip/certify/services/RenderUtilsTest.java @@ -11,7 +11,7 @@ void getDigestMultibase() { String svg = """ """; - String actual = RenderUtils.getDigestMultibase(svg); + String actual = CredentialUtils.getDigestMultibase(svg); String expected = "z4po9QkJj1fhMt6cxHSnDnAUat4PEVrerUGGsPHLxJnK5"; assertEquals(expected, actual); } diff --git a/certify-service/src/test/java/io/mosip/certify/services/RenderingTemplateServiceImplTest.java b/certify-service/src/test/java/io/mosip/certify/services/RenderingTemplateServiceImplTest.java index 6c5380ea..83f3f3cc 100644 --- a/certify-service/src/test/java/io/mosip/certify/services/RenderingTemplateServiceImplTest.java +++ b/certify-service/src/test/java/io/mosip/certify/services/RenderingTemplateServiceImplTest.java @@ -1,8 +1,9 @@ package io.mosip.certify.services; +import io.mosip.certify.api.dto.RenderingTemplateDTO; import io.mosip.certify.core.constants.ErrorConstants; import io.mosip.certify.services.entity.RenderingTemplate; -import io.mosip.certify.core.exception.TemplateException; +import io.mosip.certify.core.exception.RenderingTemplateException; import io.mosip.certify.services.repository.RenderingTemplateRepository; import lombok.extern.slf4j.Slf4j; import org.junit.Assert; @@ -40,7 +41,7 @@ public void getSvgTemplate_withValidDetail_thenPass() { svgRenderTemplate.setCreatedtimes(LocalDateTime.now()); Optional optional = Optional.of(svgRenderTemplate); Mockito.when(svgRenderTemplateRepository.findById(Mockito.any())).thenReturn(optional); - RenderingTemplate svgRenderTemplateResponse = renderingTemplateService.getSvgTemplate("fake-id"); + RenderingTemplateDTO svgRenderTemplateResponse = renderingTemplateService.getSvgTemplate("fake-id"); Assert.assertNotNull(svgRenderTemplateResponse); Assert.assertEquals(svgRenderTemplate.getId(), svgRenderTemplateResponse.getId()); Assert.assertEquals(svgTemplate, optional.get().getTemplate()); @@ -49,7 +50,7 @@ public void getSvgTemplate_withValidDetail_thenPass() { @Test public void getSvgTemplate_withInvalidId_thenFail() { Mockito.when(svgRenderTemplateRepository.findById(Mockito.any())).thenReturn(Optional.empty()); - TemplateException templateException = Assert.assertThrows(TemplateException.class, () -> { + RenderingTemplateException templateException = Assert.assertThrows(RenderingTemplateException.class, () -> { renderingTemplateService.getSvgTemplate("fake-id"); }); Assert.assertEquals(ErrorConstants.INVALID_TEMPLATE_ID, templateException.getErrorCode()); diff --git a/certify-service/src/test/resources/application-test.properties b/certify-service/src/test/resources/application-test.properties index 35da2453..19a64724 100644 --- a/certify-service/src/test/resources/application-test.properties +++ b/certify-service/src/test/resources/application-test.properties @@ -219,7 +219,6 @@ mosip.certify.key-values={\ }}\ }\ } -mosip.certify.svg-templates=svg-template.json #------------------------------------ Key-manager specific properties -------------------------------------------------- diff --git a/certify-service/src/test/resources/svg-template.json b/certify-service/src/test/resources/svg-template.json deleted file mode 100644 index 26d50c03..00000000 --- a/certify-service/src/test/resources/svg-template.json +++ /dev/null @@ -1,6 +0,0 @@ -[ - { - "id": "5b9c2a12-810a-7388-2dc8-13ee7ad88bac", - "content": "\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n {{credentialSubject/policyName}}\n {{credentialSubject/policyNumber}}\n {{credentialSubject/fullName}}\n {{credentialSubject/gender}}\n {{credentialSubject/email}}\n {{credentialSubject/mobile}}\n\n Policy Issued On\n {{credentialSubject/policyIssuedOn}}\n\n Policy Expires On\n {{credentialSubject/policyExpiresOn}}\n\n Issuance Date On\n {{issuanceDate}}\n\n Expiration Date On\n {{expirationDate}}\n" - } -] \ No newline at end of file diff --git a/docker-compose/docker-compose-injistack/config/certify-csvdp-farmer.properties b/docker-compose/docker-compose-injistack/config/certify-csvdp-farmer.properties index 2ae8e901..6fee5b35 100644 --- a/docker-compose/docker-compose-injistack/config/certify-csvdp-farmer.properties +++ b/docker-compose/docker-compose-injistack/config/certify-csvdp-farmer.properties @@ -9,9 +9,6 @@ mosip.certify.mock.authenticator.get-identity-url=http://mock-identity-system:80 mosip.certify.cache.security.algorithm-name=AES/ECB/PKCS5Padding mosip.certify.cache.secure.individual-id=false mosip.certify.cache.store.individual-id=true -# TODO: Onboard secrets for local build -mosip.certify.mock.vciplugin.issuer.key-cert="dummy-issuer-cert" -mosip.certify.mock.vciplugin.ca.key-cert=dummy mosip.certify.rendering-templates=insurance-svg-template.json mosip.certify.identifier=http://localhost:8090 @@ -26,7 +23,7 @@ mosip.certify.data-provider-plugin.issuer.vc-sign-algo=Ed25519Signature2020 mosip.certify.mock.data-provider.csv.identifier-column=id mosip.certify.mock.data-provider.csv.data-columns=id,fullName,mobileNumber,dateOfBirth,gender,state,district,villageOrTown,postalCode,landArea,landOwnershipType,primaryCropType,secondaryCropType,face,farmerID mosip.certify.mock.data-provider.csv-registry-uri=https://raw.githubusercontent.com/mosip/inji-config/refs/heads/develop/farmer_registry.csv -mosip.certify.data-provider-plugin.svg-template-id= +mosip.certify.data-provider-plugin.rendering-template-id= mosip.certify.key-values={\ 'vd12' : {\ 'credential_issuer': '${mosip.certify.identifier}',\ diff --git a/docker-compose/docker-compose-injistack/config/farmer_identity_data.csv b/docker-compose/docker-compose-injistack/config/farmer_identity_data.csv index 3bb6ac36..9a3f2010 100644 --- a/docker-compose/docker-compose-injistack/config/farmer_identity_data.csv +++ b/docker-compose/docker-compose-injistack/config/farmer_identity_data.csv @@ -1,6 +1,6 @@ id,fullName,mobileNumber,dateOfBirth,gender,state,district,villageOrTown,postalCode,landArea,landOwnershipType,primaryCropType,secondaryCropType,face,farmerID -1234,John Doe,9876543210,25-05-1990,Male,Karnataka,Bangalore,Koramangala,453000,3 hectares,Owner,Maize,Rice,"",987654321 +1234,John Doe,9876543210,25-05-1990,Male,Karnataka,Bangalore,Koramangala,453000,3 hectares,Owner,Maize,Rice,"",987654321 876543210,Mary Smith,8765432109,12-11-1985,Female,Uttar Pradesh,Lucknow,Gomti Nagar,226010,2.5 acres,Tenant,Rice,Wheat,"a",123456789 -7550166913,Raj Patel,7550166914,24-01-1998,Male,Karnataka,Bangalore,Koramangala,560068,5 acres,Self-owned,Cotton,Barley,"",4567538771 +7550166913,Raj Patel,7550166914,24-01-1998,Male,Karnataka,Bangalore,Koramangala,560068,5 acres,Self-owned,Cotton,Barley,"",4567538771 654321098,Sarah Johnson,6543210987,15-02-1988,Male,Tamil Nadu,Madurai,Melur,625106,1 hectare,Owner,Banana,Mango,"a",4567538772 543210987,Arun Kumar,5432109876,22-09-1995,Male,Karnataka,Bangalore,Koramangala,560034,2 acres,Tenant,Tomato,Peppers,"a",345678910 \ No newline at end of file diff --git a/docker-compose/docker-compose-injistack/docker-compose.yaml b/docker-compose/docker-compose-injistack/docker-compose.yaml index 0ac55d8b..92575af0 100644 --- a/docker-compose/docker-compose-injistack/docker-compose.yaml +++ b/docker-compose/docker-compose-injistack/docker-compose.yaml @@ -39,14 +39,17 @@ services: container_name: nginx image: nginx:alpine ports: - - '8099:80' + - '8080:80' volumes: - ./config/mimoto-issuers-config.json:/config/server/mimoto-issuers-config.json - ./config/mimoto-trusted-verifiers.json:/config/server/mimoto-trusted-verifiers.json - ./config/credential-template.html:/config/server/credential-template.html - ./nginx.conf:/etc/nginx/nginx.conf + depends_on: + - mimoto-service networks: - network + mimoto-service: container_name: 'Mimoto-Service' image: 'mosipid/mimoto:0.14.0' @@ -65,8 +68,6 @@ services: - ./config/mimoto-issuers-config.json:/home/mosip/mimoto-issuers-config.json - ./config/mimoto-trusted-verifiers.json:/home/mosip/mimoto-trusted-verifiers.json - ./certs/oidckeystore.p12:/home/mosip/certs/oidckeystore.p12 - depends_on: - - nginx inji-web: container_name: 'inji-web' @@ -74,8 +75,10 @@ services: ports: - '3001:3004' environment: - - MIMOTO_HOST=http://localhost:3010 + - MIMOTO_HOST=http://localhost:8080/v1/mimoto # Pointing to the Nginx service - DEFAULT_LANG=en + depends_on: + - nginx networks: - network diff --git a/docker-compose/docker-compose-injistack/nginx.conf b/docker-compose/docker-compose-injistack/nginx.conf index 03a3e1d7..a11042b8 100644 --- a/docker-compose/docker-compose-injistack/nginx.conf +++ b/docker-compose/docker-compose-injistack/nginx.conf @@ -4,9 +4,31 @@ http { server { listen 80; + # Serve static files, if any location / { root /config/server; autoindex on; } + + # Proxy API requests to mimoto-service + location /v1/mimoto/ { + proxy_pass http://mimoto-service:8099/v1/mimoto/; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + proxy_http_version 1.1; + proxy_set_header Connection ""; + + # Add CORS headers + add_header 'Access-Control-Allow-Origin' '*' always; + add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS' always; + add_header 'Access-Control-Allow-Headers' 'Content-Type, Authorization, Cache-Control' always; + + # Handle OPTIONS requests (for pre-flight checks) + if ($request_method = 'OPTIONS') { + return 204; + } + } } }