From 821d46f108d0ddece74cae67e0149b24d308c408 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 - .../docker-compose-certify/certify_init.sql | 92 ---------------- .../config/certify-mock-identity.properties | 103 ------------------ .../certify-sunbird-insurance.properties | 98 ----------------- .../config/certify-csvdp-farmer.properties | 5 +- .../config/farmer_identity_data.csv | 4 +- .../docker-compose.yaml | 11 +- .../docker-compose-injistack/nginx.conf | 22 ++++ 23 files changed, 91 insertions(+), 446 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 delete mode 100644 docker-compose/docker-compose-certify/certify_init.sql delete mode 100644 docker-compose/docker-compose-certify/config/certify-mock-identity.properties delete mode 100644 docker-compose/docker-compose-certify/config/certify-sunbird-insurance.properties 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-certify/certify_init.sql b/docker-compose/docker-compose-certify/certify_init.sql deleted file mode 100644 index 4a2b0ca7..00000000 --- a/docker-compose/docker-compose-certify/certify_init.sql +++ /dev/null @@ -1,92 +0,0 @@ -CREATE DATABASE inji_certify - ENCODING = 'UTF8' - LC_COLLATE = 'en_US.UTF-8' - LC_CTYPE = 'en_US.UTF-8' - TABLESPACE = pg_default - OWNER = postgres - TEMPLATE = template0; - -COMMENT ON DATABASE inji_certify IS 'certify related data is stored in this database'; - -\c inji_certify postgres - -DROP SCHEMA IF EXISTS certify CASCADE; -CREATE SCHEMA certify; -ALTER SCHEMA certify OWNER TO postgres; -ALTER DATABASE inji_certify SET search_path TO certify,pg_catalog,public; - -CREATE TABLE certify.key_alias( - id character varying(36) NOT NULL, - app_id character varying(36) NOT NULL, - ref_id character varying(128), - key_gen_dtimes timestamp, - key_expire_dtimes timestamp, - status_code character varying(36), - lang_code character varying(3), - cr_by character varying(256) NOT NULL, - cr_dtimes timestamp NOT NULL, - upd_by character varying(256), - upd_dtimes timestamp, - is_deleted boolean DEFAULT FALSE, - del_dtimes timestamp, - cert_thumbprint character varying(100), - uni_ident character varying(50), - CONSTRAINT pk_keymals_id PRIMARY KEY (id), - CONSTRAINT uni_ident_const UNIQUE (uni_ident) -); - -CREATE TABLE certify.key_policy_def( - app_id character varying(36) NOT NULL, - key_validity_duration smallint, - is_active boolean NOT NULL, - pre_expire_days smallint, - access_allowed character varying(1024), - cr_by character varying(256) NOT NULL, - cr_dtimes timestamp NOT NULL, - upd_by character varying(256), - upd_dtimes timestamp, - is_deleted boolean DEFAULT FALSE, - del_dtimes timestamp, - CONSTRAINT pk_keypdef_id PRIMARY KEY (app_id) -); - -CREATE TABLE certify.key_store( - id character varying(36) NOT NULL, - master_key character varying(36) NOT NULL, - private_key character varying(2500) NOT NULL, - certificate_data character varying NOT NULL, - cr_by character varying(256) NOT NULL, - cr_dtimes timestamp NOT NULL, - upd_by character varying(256), - upd_dtimes timestamp, - is_deleted boolean DEFAULT FALSE, - del_dtimes timestamp, - CONSTRAINT pk_keystr_id PRIMARY KEY (id) -); - -CREATE TABLE certify.rendering_template ( - id UUID NOT NULL, - template VARCHAR NOT NULL, - cr_dtimes timestamp NOT NULL, - upd_dtimes timestamp, - CONSTRAINT pk_svgtmp_id PRIMARY KEY (id) -); - -CREATE TABLE certify.credential_template( - context character varying(1024) NOT NULL, - credential_type character varying(512) NOT NULL, - template VARCHAR NOT NULL, - cr_dtimes timestamp NOT NULL default now(), - upd_dtimes timestamp, - CONSTRAINT pk_template PRIMARY KEY (context, credential_type) -); - - - -INSERT INTO certify.KEY_POLICY_DEF(APP_ID,KEY_VALIDITY_DURATION,PRE_EXPIRE_DAYS,ACCESS_ALLOWED,IS_ACTIVE,CR_BY,CR_DTIMES) VALUES('ROOT', 2920, 1125, 'NA', true, 'mosipadmin', now()); -INSERT INTO certify.KEY_POLICY_DEF(APP_ID,KEY_VALIDITY_DURATION,PRE_EXPIRE_DAYS,ACCESS_ALLOWED,IS_ACTIVE,CR_BY,CR_DTIMES) VALUES('CERTIFY_SERVICE', 1095, 50, 'NA', true, 'mosipadmin', now()); -INSERT INTO certify.KEY_POLICY_DEF(APP_ID,KEY_VALIDITY_DURATION,PRE_EXPIRE_DAYS,ACCESS_ALLOWED,IS_ACTIVE,CR_BY,CR_DTIMES) VALUES('CERTIFY_PARTNER', 1095, 50, 'NA', true, 'mosipadmin', now()); -INSERT INTO certify.KEY_POLICY_DEF(APP_ID,KEY_VALIDITY_DURATION,PRE_EXPIRE_DAYS,ACCESS_ALLOWED,IS_ACTIVE,CR_BY,CR_DTIMES) VALUES('CERTIFY_RSA', 1095, 50, 'NA', true, 'mosipadmin', now()); -INSERT INTO certify.KEY_POLICY_DEF(APP_ID,KEY_VALIDITY_DURATION,PRE_EXPIRE_DAYS,ACCESS_ALLOWED,IS_ACTIVE,CR_BY,CR_DTIMES) VALUES('CERTIFY_ED25519', 1095, 50, 'NA', true, 'mosipadmin', now()); -INSERT INTO certify.KEY_POLICY_DEF(APP_ID,KEY_VALIDITY_DURATION,PRE_EXPIRE_DAYS,ACCESS_ALLOWED,IS_ACTIVE,CR_BY,CR_DTIMES) VALUES('BASE', 730, 30, 'NA', true, 'mosipadmin', now()); - diff --git a/docker-compose/docker-compose-certify/config/certify-mock-identity.properties b/docker-compose/docker-compose-certify/config/certify-mock-identity.properties deleted file mode 100644 index 57c7a24d..00000000 --- a/docker-compose/docker-compose-certify/config/certify-mock-identity.properties +++ /dev/null @@ -1,103 +0,0 @@ -## ------------------------------------------- Mock ID Integration properties ------------------------------------------------------------ -mosip.certify.integration.scan-base-package=io.mosip.certify.mock.integration -mosip.certify.integration.audit-plugin=LoggerAuditService -mosip.certify.integration.vci-plugin=MockVCIssuancePlugin - -## ------------------------------------------- Mock ID plugin related properties ------------------------------------------------------------ -mosip.certify.mock.vciplugin.verification-method=${mosip.certify.authn.jwk-set-uri} -mosip.certify.mock.authenticator.get-identity-url=http://mock-identity-system:8082/v1/mock-identity-system/identity -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 -mosip.certify.rendering-templates=insurance-svg-template.json -mosip.certify.key-values={\ - 'vd12' : {\ - 'credential_issuer': '${mosip.certify.identifier}', \ - 'authorization_servers': {'${mosip.certify.authorization.url}'}, \ - 'credential_endpoint': '${mosip.certify.identifier}${server.servlet.path}/issuance/vd12/credential', \ - 'display': {{'name': 'Mock Verifiable Credential', 'locale': 'en'}},\ - 'credentials_supported' : { \ - 'MockVerifiableCredential_ldp' : {\ - 'format': 'ldp_vc',\ - 'scope' : 'mock_identity_vc_ldp',\ - 'cryptographic_binding_methods_supported': {'did:jwk'},\ - 'cryptographic_suites_supported': {'RsaSignature2018'},\ - 'proof_types_supported': {'jwt'},\ - 'credential_definition': {\ - 'type': {'VerifiableCredential','MockVerifiableCredential'},\ - 'credentialSubject': {\ - 'fullName': { 'display': {{'name': 'Full Name', 'locale': 'en' }}},\ - 'phone': { 'display': {{'name': 'Phone Number', 'locale': 'en' }}},\ - 'dateOfBirth': { 'display': {{'name': 'DOB', 'locale': 'en' }}},\ - 'gender': { 'display': {{'name': 'Gender', 'locale': 'en' }}},\ - 'email': { 'display': {{'name': 'Email Id', 'locale': 'en' }}},\ - 'region': { 'display': {{'name': 'Region', 'locale': 'en' }}},\ - 'province': { 'display': {{'name': 'Province', 'locale': 'en' }}},\ - 'UIN': { 'display': {{'name': 'UIN', 'locale': 'en' }}},\ - 'VID': { 'display': {{'name': 'VID', 'locale': 'en' }}},\ - 'postalCode': { 'display': {{'name': 'Postal Code', 'locale': 'en' }}}\ - }},\ - 'display': {{'name': 'Mock Verifiable Credential', \ - 'locale': 'en', \ - 'logo': {'url': '${mosipbox.public.url}/logo.png','alt_text': 'a square logo of a MOSIP'},\ - 'background_color': '#12107c',\ - 'text_color': '#FFFFFF'}},\ - 'order' : {'fullName','phone','dateOfBirth','gender','email','region','province','UIN', 'VID', 'postalCode'}\ - }\ - }\ - },\ - 'latest' : {\ - 'credential_issuer': '${mosip.certify.identifier}', \ - 'authorization_servers': {'${mosip.certify.authorization.url}'}, \ - 'credential_endpoint': '${mosip.certify.identifier}${server.servlet.path}/issuance/credential', \ - 'display': {{'name': 'Mock Verifiable Credential', 'locale': 'en'}},\ - 'credential_configurations_supported' : { \ - 'MockVerifiableCredential_ldp' : {\ - 'format': 'ldp_vc',\ - 'scope' : 'mock_identity_vc_ldp',\ - 'cryptographic_binding_methods_supported': {'did:jwk'},\ - 'credential_signing_alg_values_supported': {'RsaSignature2018'},\ - 'proof_types_supported': {'jwt': {'proof_signing_alg_values_supported': {'RS256', 'PS256', 'ES256'}}},\ - 'credential_definition': {\ - 'type': {'VerifiableCredential','MockVerifiableCredential'},\ - 'credentialSubject': {\ - 'fullName': { 'display': {{'name': 'Full Name', 'locale': 'en' }}},\ - 'phone': { 'display': {{'name': 'Phone Number', 'locale': 'en' }}},\ - 'dateOfBirth': { 'display': {{'name': 'DOB', 'locale': 'en' }}},\ - 'gender': { 'display': {{'name': 'Gender', 'locale': 'en' }}},\ - 'email': { 'display': {{'name': 'Email Id', 'locale': 'en' }}},\ - 'region': { 'display': {{'name': 'Region', 'locale': 'en' }}},\ - 'province': { 'display': {{'name': 'Province', 'locale': 'en' }}},\ - 'UIN': { 'display': {{'name': 'UIN', 'locale': 'en' }}},\ - 'VID': { 'display': {{'name': 'VID', 'locale': 'en' }}},\ - 'postalCode': { 'display': {{'name': 'Postal Code', 'locale': 'en' }}}\ - }},\ - 'display': {{'name': 'Mock Verifiable Credential', \ - 'locale': 'en', \ - 'logo': {'url': '${mosipbox.public.url}/logo.png','alt_text': 'a square logo of a MOSIP'},\ - 'background_color': '#12107c',\ - 'background_image': { 'uri': 'https://${mosipbox.public.url}/inji/mosip-logo.png' }, \ - 'text_color': '#FFFFFF'}},\ - 'order' : {'fullName','phone','dateOfBirth','gender','email','region','province','UIN', 'VID', 'postalCode'}\ - },\ - "DrivingLicenseCredential":{\ - 'format': 'mso_mdoc',\ - 'doctype': 'org.iso.18013.5.1.mDL',\ - 'scope' : 'sample_vc_mdoc',\ - 'cryptographic_binding_methods_supported': {'cose_key'},\ - 'credential_signing_alg_values_supported': {'ES256'},\ - 'proof_types_supported': {'jwt': {'proof_signing_alg_values_supported': {'ES256'}}},\ - 'claims': {\ - 'org.iso.18013.5.1': {'given_name': {'display': {{'name': 'Given Name','locale': 'en'}}},'family_name': {'display': {{'name': 'Family Name','locale': 'en'}}},'issue_date': {'display': {{'name': 'Issue Date','locale': 'en'}}},'expiry_date': {'display': {{'name': 'Expiry Date','locale': 'en'}}},'birth_date': {'display': {{'name': 'Birth Date','locale': 'en'}}},'issuing_country': {'display': {{'name': 'Issuing Country','locale': 'en'}}},'document_number': {'display': {{'name': 'Document Number','locale': 'en'}}}}},\ - 'display': {{'name': 'Mobile Driving License Verifiable Credential', \ - 'locale': 'en', \ - 'background_image': { 'uri': 'https://sunbird.org/images/sunbird-logo-new.png' }, \ - 'logo': {'url': 'https://sunbird.org/images/sunbird-logo-new.png','alt_text': 'a square logo of a Sunbird Mobile Driving License'},\ - 'background_color': '#FDFAF9',\ - 'text_color': '#7C4616'}},\ - 'order' : {'org.iso.18013.5.1~family_name','org.iso.18013.5.1~given_name','org.iso.18013.5.1~document_number','org.iso.18013.5.1~issuing_country','org.iso.18013.5.1~issue_date','org.iso.18013.5.1~expiry_date','org.iso.18013.5.1~birth_date'}\ - }\ - }\ - }} \ No newline at end of file diff --git a/docker-compose/docker-compose-certify/config/certify-sunbird-insurance.properties b/docker-compose/docker-compose-certify/config/certify-sunbird-insurance.properties deleted file mode 100644 index 9552ae19..00000000 --- a/docker-compose/docker-compose-certify/config/certify-sunbird-insurance.properties +++ /dev/null @@ -1,98 +0,0 @@ -# ------------------------------------------- Integrations ------------------------------------------------------------ -mosip.certify.integration.scan-base-package=io.mosip.certify.sunbirdrc.integration -mosip.certify.integration.vci-plugin=SunbirdRCVCIssuancePlugin -mosip.certify.integration.audit-plugin=LoggerAuditService - -##--------------------sunbird registry related demo configuration-------------------------## - -mosip.certify.vciplugin.sunbird-rc.issue-credential-url=http://sunbird-registry:80/credential/credentials/issue -mosip.certify.vciplugin.sunbird-rc.supported-credential-types=HealthInsuranceCredential,LifeInsuranceCredential,InsuranceCredential -mosip.certify.vciplugin.sunbird-rc.credential-type.HealthInsuranceCredential.static-value-map.issuerId=did:web:challabeehyv.github.io:DID-Resolve:190d673a-0cfb-45f4-a8f4-5efaaaef0b4b -mosip.certify.vciplugin.sunbird-rc.credential-type.HealthInsuranceCredential.template-url=https://raw.githubusercontent.com/challabeehyv/mimoto-config/main/InsuranceConfig.json -mosip.certify.vciplugin.sunbird-rc.credential-type.HealthInsuranceCredential.registry-get-url=http://sunbird-registry:80/registry/api/v1/Insurance/ -mosip.certify.vciplugin.sunbird-rc.credential-type.HealthInsuranceCredential.cred-schema-id=did:schema:c45e2840-bf2a-440d-b4aa-52ff3e205f18 -mosip.certify.vciplugin.sunbird-rc.credential-type.HealthInsuranceCredential.cred-schema-version=1.0.0 -mosip.certify.vciplugin.sunbird-rc.credential-type.HealthInsuranceCredential.registry-search-url=http://sunbird-registry:80/registry/api/v1/Insurance/search - -mosip.certify.vciplugin.sunbird-rc.credential-type.LifeInsuranceCredential.static-value-map.issuerId=did:web:challabeehyv.github.io:DID-Resolve:190d673a-0cfb-45f4-a8f4-5efaaaef0b4b -mosip.certify.vciplugin.sunbird-rc.credential-type.LifeInsuranceCredential.template-url=https://raw.githubusercontent.com/challabeehyv/mimoto-config/main/InsuranceConfig.json -mosip.certify.vciplugin.sunbird-rc.credential-type.LifeInsuranceCredential.registry-get-url=http://sunbird-registry:80/registry/api/v1/Insurance/ -mosip.certify.vciplugin.sunbird-rc.credential-type.LifeInsuranceCredential.cred-schema-id=did:schema:c45e2840-bf2a-440d-b4aa-52ff3e205f18 -mosip.certify.vciplugin.sunbird-rc.credential-type.LifeInsuranceCredential.cred-schema-version=1.0.0 -mosip.certify.vciplugin.sunbird-rc.credential-type.LifeInsuranceCredential.registry-search-url=http://sunbird-registry:80/registry/api/v1/Insurance/search - - -mosip.certify.vciplugin.sunbird-rc.credential-type.InsuranceCredential.static-value-map.issuerId=did:web:challabeehyv.github.io:DID-Resolve:190d673a-0cfb-45f4-a8f4-5efaaaef0b4b -mosip.certify.vciplugin.sunbird-rc.credential-type.InsuranceCredential.template-url=https://raw.githubusercontent.com/challabeehyv/mimoto-config/main/InsuranceConfig.json -mosip.certify.vciplugin.sunbird-rc.credential-type.InsuranceCredential.registry-get-url=http://sunbird-registry:80/registry/api/v1/Insurance/ -mosip.certify.vciplugin.sunbird-rc.credential-type.InsuranceCredential.cred-schema-id=did:schema:c45e2840-bf2a-440d-b4aa-52ff3e205f18 -mosip.certify.vciplugin.sunbird-rc.credential-type.InsuranceCredential.cred-schema-version=1.0.0 -mosip.certify.vciplugin.sunbird-rc.credential-type.InsuranceCredential.registry-search-url=http://sunbird-registry:80/registry/api/v1/Insurance/search - - -mosip.certify.rendering-templates=insurance-svg-template.json -mosip.certify.key-values={\ - 'latest' : {\ - 'credential_issuer': '${mosipbox.public.url}', \ - 'authorization_servers': {'${mosip.certify.authorization.url}'}, \ - 'credential_endpoint': '${mosipbox.public.url}${server.servlet.path}/issuance/credential', \ - 'display': {{'name': 'Insurance', 'locale': 'en'}},\ - 'credential_configurations_supported' : { \ - "InsuranceCredential" : {\ - 'format': 'ldp_vc',\ - 'scope' : 'sunbird_rc_insurance_vc_ldp',\ - 'cryptographic_binding_methods_supported': {'did:jwk'},\ - 'credential_signing_alg_values_supported': {'Ed25519Signature2020'},\ - 'proof_types_supported': {'jwt': {'proof_signing_alg_values_supported': {'RS256', 'PS256'}}},\ - 'credential_definition': {\ - 'type': {'VerifiableCredential','InsuranceCredential'},\ - 'credentialSubject': {\ - 'fullName': {'display': {{'name': 'Name','locale': 'en'}}}, \ - 'mobile': {'display': {{'name': 'Phone Number','locale': 'en'}}},\ - 'dob': {'display': {{'name': 'Date of Birth','locale': 'en'}}},\ - 'gender': {'display': {{'name': 'Gender','locale': 'en'}}},\ - 'benefits': {'display': {{'name': 'Benefits','locale': 'en'}}},\ - 'email': {'display': {{'name': 'Email Id','locale': 'en'}}},\ - 'policyIssuedOn': {'display': {{'name': 'Policy Issued On','locale': 'en'}}},\ - 'policyExpiresOn': {'display': {{'name': 'Policy Expires On','locale': 'en'}}},\ - 'policyName': {'display': {{'name': 'Policy Name','locale': 'en'}}},\ - 'policyNumber': {'display': {{'name': 'Policy Number','locale': 'en'}}}\ - }},\ - 'display': {{'name': 'Sunbird RC Insurance Verifiable Credential', \ - 'locale': 'en', \ - 'logo': {'url': 'https://sunbird.org/images/sunbird-logo-new.png','alt_text': 'a square logo of a Sunbird'},\ - 'background_color': '#FDFAF9',\ - 'background_image': { 'uri': 'https://sunbird.org/images/sunbird-logo-new.png' }, \ - 'text_color': '#7C4616'}},\ - 'order' : {'fullName','policyName','policyExpiresOn','policyIssuedOn','policyNumber','mobile','dob','gender','benefits','email'}\ - },\ - "LifeInsuranceCredential":{\ - 'format': 'ldp_vc',\ - 'scope' : 'life_insurance_vc_ldp',\ - 'cryptographic_binding_methods_supported': {'did:jwk'},\ - 'credential_signing_alg_values_supported': {'Ed25519Signature2020'},\ - 'proof_types_supported': {'jwt': {'proof_signing_alg_values_supported': {'RS256', 'ES256'}}},\ - 'credential_definition': {\ - 'type': {'VerifiableCredential'},\ - 'credentialSubject': {\ - 'fullName': {'display': {{'name': 'Name','locale': 'en'}}}, \ - 'mobile': {'display': {{'name': 'Phone Number','locale': 'en'}}},\ - 'dob': {'display': {{'name': 'Date of Birth','locale': 'en'}}},\ - 'gender': {'display': {{'name': 'Gender','locale': 'en'}}},\ - 'benefits': {'display': {{'name': 'Benefits','locale': 'en'}}},\ - 'email': {'display': {{'name': 'Email Id','locale': 'en'}}},\ - 'policyIssuedOn': {'display': {{'name': 'Policy Issued On','locale': 'en'}}},\ - 'policyExpiresOn': {'display': {{'name': 'Policy Expires On','locale': 'en'}}},\ - 'policyName': {'display': {{'name': 'Policy Name','locale': 'en'}}},\ - 'policyNumber': {'display': {{'name': 'Policy Number','locale': 'en'}}}\ - }},\ - 'display': {{'name': 'Life Insurance Verifiable Credential', \ - 'locale': 'en', \ - 'logo': {'url': 'https://sunbird.org/images/sunbird-logo-new.png','alt_text': 'a square logo of a Sunbird'},\ - 'background_image': { 'uri': 'https://sunbird.org/images/sunbird-logo-new.png' }, \ - 'background_color': '#FDFAF9',\ - 'background_image': { 'uri': 'https://sunbird.org/images/sunbird-logo-new.png' }, \ - 'text_color': '#7C4616'}},\ - 'order' : {'fullName','policyName','policyExpiresOn','policyIssuedOn','policyNumber','mobile','dob','gender','benefits','email'}\ - }}\ - }} \ 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; + } + } } }