implemented fetch qr code scanned details
This commit is contained in:
11
pom.xml
11
pom.xml
@@ -40,6 +40,11 @@
|
|||||||
<artifactId>lombok</artifactId>
|
<artifactId>lombok</artifactId>
|
||||||
<optional>true</optional>
|
<optional>true</optional>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.vladmihalcea</groupId>
|
||||||
|
<artifactId>hibernate-types-52</artifactId>
|
||||||
|
<version>2.21.1</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-boot-starter-test</artifactId>
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
@@ -57,12 +62,6 @@
|
|||||||
<artifactId>reactor-core</artifactId>
|
<artifactId>reactor-core</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- Reactor Core -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>io.projectreactor</groupId>
|
|
||||||
<artifactId>reactor-core</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Netty DNS resolver for MacOS -->
|
<!-- Netty DNS resolver for MacOS -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>io.netty</groupId>
|
<groupId>io.netty</groupId>
|
||||||
|
|||||||
@@ -11,5 +11,6 @@ public class APIConstants {
|
|||||||
public static final String API_URL_QRCODE_VERIFY_URL = "/qrcodetypes/verifyurl";
|
public static final String API_URL_QRCODE_VERIFY_URL = "/qrcodetypes/verifyurl";
|
||||||
public static final String API_URL_QRCODE_VIRUS_TOTAL_CHECK = "/qrcodetypes/virustotalcheck";
|
public static final String API_URL_QRCODE_VIRUS_TOTAL_CHECK = "/qrcodetypes/virustotalcheck";
|
||||||
public static final String API_URL_QRCODE_REDIRECT_COUNT = "/qrcodetypes/redirectcount";
|
public static final String API_URL_QRCODE_REDIRECT_COUNT = "/qrcodetypes/redirectcount";
|
||||||
|
public static final String API_URL_QRCODE_GET_SCANNED_DETAILS = "/qrcodetypes/getScannedDetails";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
16
src/main/java/com/safeqr/app/exceptions/ErrorResponse.java
Normal file
16
src/main/java/com/safeqr/app/exceptions/ErrorResponse.java
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package com.safeqr.app.exceptions;
|
||||||
|
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Builder
|
||||||
|
@Data
|
||||||
|
public class ErrorResponse {
|
||||||
|
private String error;
|
||||||
|
private int status;
|
||||||
|
|
||||||
|
public ErrorResponse(String message, int status){
|
||||||
|
this.error = message;
|
||||||
|
this.status = status;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
package com.safeqr.app.exceptions;
|
||||||
|
|
||||||
|
import org.springframework.http.HttpStatus;
|
||||||
|
import org.springframework.http.ResponseEntity;
|
||||||
|
import org.springframework.web.bind.annotation.ControllerAdvice;
|
||||||
|
import org.springframework.web.bind.annotation.ExceptionHandler;
|
||||||
|
|
||||||
|
@ControllerAdvice
|
||||||
|
public class GlobalExceptionHandler {
|
||||||
|
|
||||||
|
@ExceptionHandler(QRCodeExceptions.class)
|
||||||
|
public ResponseEntity<ErrorResponse> handleQRCodeNotFoundException(QRCodeExceptions e) {
|
||||||
|
return new ResponseEntity<>(new ErrorResponse(e.getMessage(), HttpStatus.NOT_FOUND.value()), HttpStatus.NOT_FOUND);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.safeqr.app.exceptions;
|
||||||
|
|
||||||
|
public class QRCodeExceptions extends RuntimeException {
|
||||||
|
public QRCodeExceptions(String message){
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -2,7 +2,7 @@ package com.safeqr.app.qrcode.controller;
|
|||||||
|
|
||||||
import static com.safeqr.app.constants.APIConstants.*;
|
import static com.safeqr.app.constants.APIConstants.*;
|
||||||
import static com.safeqr.app.constants.CommonConstants.*;
|
import static com.safeqr.app.constants.CommonConstants.*;
|
||||||
import com.safeqr.app.qrcode.dto.QRCodePayload;
|
import com.safeqr.app.qrcode.dto.request.QRCodePayload;
|
||||||
import com.safeqr.app.qrcode.dto.RedirectCountResponse;
|
import com.safeqr.app.qrcode.dto.RedirectCountResponse;
|
||||||
import com.safeqr.app.qrcode.dto.URLVerificationResponse;
|
import com.safeqr.app.qrcode.dto.URLVerificationResponse;
|
||||||
import com.safeqr.app.qrcode.dto.response.BaseScanResponse;
|
import com.safeqr.app.qrcode.dto.response.BaseScanResponse;
|
||||||
@@ -20,6 +20,7 @@ import org.springframework.web.bind.annotation.*;
|
|||||||
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping(API_VERSION)
|
@RequestMapping(API_VERSION)
|
||||||
@@ -42,6 +43,11 @@ public class QRCodeTypeController {
|
|||||||
public ResponseEntity<List<QRCodeTypeEntity>> getAllTypes() {
|
public ResponseEntity<List<QRCodeTypeEntity>> getAllTypes() {
|
||||||
return ResponseEntity.ok(qrCodeTypeService.getAllTypes());
|
return ResponseEntity.ok(qrCodeTypeService.getAllTypes());
|
||||||
}
|
}
|
||||||
|
@GetMapping(value = API_URL_QRCODE_GET_SCANNED_DETAILS)
|
||||||
|
public ResponseEntity<BaseScanResponse> getScannedQRCodeDetails(@RequestHeader(name="QR-ID") UUID qrCodeId) {
|
||||||
|
logger.info("Invoking GET QRCode details endpoint, qrCodeId: {}", qrCodeId);
|
||||||
|
return ResponseEntity.ok(qrCodeTypeService.getScannedQRCodeDetails(qrCodeId));
|
||||||
|
}
|
||||||
|
|
||||||
@PostMapping(value = API_URL_QRCODE_SCAN, produces = MediaType.APPLICATION_JSON_VALUE)
|
@PostMapping(value = API_URL_QRCODE_SCAN, produces = MediaType.APPLICATION_JSON_VALUE)
|
||||||
public ResponseEntity<BaseScanResponse> scanQRCode(@RequestBody QRCodePayload payload,
|
public ResponseEntity<BaseScanResponse> scanQRCode(@RequestBody QRCodePayload payload,
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
package com.safeqr.app.qrcode.dto;
|
package com.safeqr.app.qrcode.dto.request;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
@@ -7,6 +7,7 @@ import lombok.Data;
|
|||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Builder;
|
import lombok.Builder;
|
||||||
|
import org.hibernate.annotations.Type;
|
||||||
import org.hibernate.annotations.UuidGenerator;
|
import org.hibernate.annotations.UuidGenerator;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -45,12 +46,12 @@ public class URLEntity {
|
|||||||
|
|
||||||
private int redirect = 0;
|
private int redirect = 0;
|
||||||
|
|
||||||
@Column(name = "hsts_header")
|
@Column(name = "hsts_header", columnDefinition = "text[]")
|
||||||
private List<String> hstsHeader;
|
private List<String> hstsHeader;
|
||||||
|
|
||||||
@Column(name = "ssl_stripping")
|
@Column(name = "ssl_stripping", columnDefinition = "boolean[]")
|
||||||
private List<Boolean> sslStripping;
|
private List<Boolean> sslStripping;
|
||||||
|
|
||||||
@Column(name = "redirect_chain")
|
@Column(name = "redirect_chain", columnDefinition = "text[]")
|
||||||
private List<String> redirectChain;
|
private List<String> redirectChain;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package com.safeqr.app.qrcode.model;
|
|||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.EmailEntity;
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.service.EmailVerificationService;
|
import com.safeqr.app.qrcode.service.EmailVerificationService;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
@@ -12,14 +12,12 @@ import org.slf4j.LoggerFactory;
|
|||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class EmailModel extends QRCodeModel {
|
public final class EmailModel extends QRCodeModel<EmailEntity> {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(EmailModel.class);
|
private static final Logger logger = LoggerFactory.getLogger(EmailModel.class);
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
private final EmailVerificationService emailVerificationService;
|
private final EmailVerificationService emailVerificationService;
|
||||||
|
|
||||||
EmailEntity details;
|
|
||||||
|
|
||||||
public EmailModel(QRCodeEntity scannedQRCodeEntity, EmailVerificationService emailVerificationService) {
|
public EmailModel(QRCodeEntity scannedQRCodeEntity, EmailVerificationService emailVerificationService) {
|
||||||
this.scannedQRCode = scannedQRCodeEntity;
|
this.scannedQRCode = scannedQRCodeEntity;
|
||||||
this.emailVerificationService = emailVerificationService;
|
this.emailVerificationService = emailVerificationService;
|
||||||
@@ -32,4 +30,9 @@ public class EmailModel extends QRCodeModel {
|
|||||||
// Insert into email table
|
// Insert into email table
|
||||||
emailVerificationService.insertDB(details);
|
emailVerificationService.insertDB(details);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EmailEntity getDetails () {
|
||||||
|
return new EmailEntity();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.safeqr.app.qrcode.model;
|
package com.safeqr.app.qrcode.model;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.PhoneEntity;
|
import com.safeqr.app.qrcode.entity.PhoneEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.service.PhoneVerificationService;
|
import com.safeqr.app.qrcode.service.PhoneVerificationService;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
@@ -12,14 +12,12 @@ import org.slf4j.LoggerFactory;
|
|||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class PhoneModel extends QRCodeModel {
|
public final class PhoneModel extends QRCodeModel<PhoneEntity> {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(PhoneModel.class);
|
private static final Logger logger = LoggerFactory.getLogger(PhoneModel.class);
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
private final PhoneVerificationService phoneVerificationService;
|
private final PhoneVerificationService phoneVerificationService;
|
||||||
|
|
||||||
PhoneEntity details;
|
|
||||||
|
|
||||||
public PhoneModel(QRCodeEntity scannedQRCodeEntity, PhoneVerificationService phoneVerificationService) {
|
public PhoneModel(QRCodeEntity scannedQRCodeEntity, PhoneVerificationService phoneVerificationService) {
|
||||||
this.scannedQRCode = scannedQRCodeEntity;
|
this.scannedQRCode = scannedQRCodeEntity;
|
||||||
this.phoneVerificationService = phoneVerificationService;
|
this.phoneVerificationService = phoneVerificationService;
|
||||||
@@ -32,4 +30,8 @@ public class PhoneModel extends QRCodeModel {
|
|||||||
// Insert into phone table
|
// Insert into phone table
|
||||||
phoneVerificationService.insertDB(details);
|
phoneVerificationService.insertDB(details);
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
public PhoneEntity getDetails () {
|
||||||
|
return new PhoneEntity();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,11 +1,13 @@
|
|||||||
package com.safeqr.app.qrcode.model;
|
package com.safeqr.app.qrcode.model;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public abstract class QRCodeModel {
|
public abstract class QRCodeModel<T>{
|
||||||
QRCodeEntity scannedQRCode;
|
QRCodeEntity scannedQRCode;
|
||||||
|
T details;
|
||||||
|
|
||||||
public abstract void setDetails();
|
public abstract void setDetails();
|
||||||
|
public abstract T getDetails();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.safeqr.app.qrcode.model;
|
package com.safeqr.app.qrcode.model;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.SMSEntity;
|
import com.safeqr.app.qrcode.entity.SMSEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.service.SMSVerificationService;
|
import com.safeqr.app.qrcode.service.SMSVerificationService;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
@@ -12,14 +12,12 @@ import org.slf4j.LoggerFactory;
|
|||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class SMSModel extends QRCodeModel {
|
public final class SMSModel extends QRCodeModel<SMSEntity> {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(SMSModel.class);
|
private static final Logger logger = LoggerFactory.getLogger(SMSModel.class);
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
private final SMSVerificationService smsVerificationService;
|
private final SMSVerificationService smsVerificationService;
|
||||||
|
|
||||||
SMSEntity details;
|
|
||||||
|
|
||||||
public SMSModel(QRCodeEntity scannedQRCodeEntity, SMSVerificationService smsVerificationService) {
|
public SMSModel(QRCodeEntity scannedQRCodeEntity, SMSVerificationService smsVerificationService) {
|
||||||
this.scannedQRCode = scannedQRCodeEntity;
|
this.scannedQRCode = scannedQRCodeEntity;
|
||||||
this.smsVerificationService = smsVerificationService;
|
this.smsVerificationService = smsVerificationService;
|
||||||
@@ -32,4 +30,8 @@ public class SMSModel extends QRCodeModel {
|
|||||||
// Insert into sms table
|
// Insert into sms table
|
||||||
smsVerificationService.insertDB(details);
|
smsVerificationService.insertDB(details);
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
public SMSEntity getDetails () {
|
||||||
|
return new SMSEntity();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.safeqr.app.qrcode.model;
|
package com.safeqr.app.qrcode.model;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.TextEntity;
|
import com.safeqr.app.qrcode.entity.TextEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.service.TextVerificationService;
|
import com.safeqr.app.qrcode.service.TextVerificationService;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
@@ -12,14 +12,12 @@ import org.slf4j.LoggerFactory;
|
|||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class TextModel extends QRCodeModel {
|
public final class TextModel extends QRCodeModel<TextEntity> {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(TextModel.class);
|
private static final Logger logger = LoggerFactory.getLogger(TextModel.class);
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
private final TextVerificationService textVerificationService;
|
private final TextVerificationService textVerificationService;
|
||||||
|
|
||||||
TextEntity details;
|
|
||||||
|
|
||||||
public TextModel(QRCodeEntity scannedQRCodeEntity, TextVerificationService textVerificationService) {
|
public TextModel(QRCodeEntity scannedQRCodeEntity, TextVerificationService textVerificationService) {
|
||||||
this.scannedQRCode = scannedQRCodeEntity;
|
this.scannedQRCode = scannedQRCodeEntity;
|
||||||
this.textVerificationService = textVerificationService;
|
this.textVerificationService = textVerificationService;
|
||||||
@@ -32,4 +30,8 @@ public class TextModel extends QRCodeModel {
|
|||||||
// Insert into text table
|
// Insert into text table
|
||||||
textVerificationService.insertDB(details);
|
textVerificationService.insertDB(details);
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
public TextEntity getDetails () {
|
||||||
|
return new TextEntity();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
package com.safeqr.app.qrcode.model;
|
package com.safeqr.app.qrcode.model;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.entity.URLEntity;
|
import com.safeqr.app.qrcode.entity.URLEntity;
|
||||||
import com.safeqr.app.qrcode.service.URLVerificationService;
|
import com.safeqr.app.qrcode.service.URLVerificationService;
|
||||||
import lombok.*;
|
import lombok.*;
|
||||||
@@ -15,17 +15,16 @@ import java.net.URISyntaxException;
|
|||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class URLModel extends QRCodeModel {
|
public final class URLModel extends QRCodeModel<URLEntity> {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(URLModel.class);
|
private static final Logger logger = LoggerFactory.getLogger(URLModel.class);
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
private final URLVerificationService urlVerificationService;
|
private final URLVerificationService urlVerificationService;
|
||||||
|
|
||||||
URLEntity details;
|
|
||||||
@Autowired
|
@Autowired
|
||||||
public URLModel(QRCodeEntity scannedQRCodeEntity, URLVerificationService urlVerificationService) {
|
public URLModel(QRCodeEntity scannedQRCodeEntity, URLVerificationService urlVerificationService) {
|
||||||
this.scannedQRCode = scannedQRCodeEntity;
|
this.scannedQRCode = scannedQRCodeEntity;
|
||||||
this.urlVerificationService = urlVerificationService;
|
this.urlVerificationService = urlVerificationService;
|
||||||
this.details = null;
|
details = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -44,4 +43,8 @@ public class URLModel extends QRCodeModel {
|
|||||||
logger.error("Error: ", e);
|
logger.error("Error: ", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
public URLEntity getDetails () {
|
||||||
|
return urlVerificationService.getURLEntityByQRCodeId(scannedQRCode.getId());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
package com.safeqr.app.qrcode.model;
|
package com.safeqr.app.qrcode.model;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.WifiEntity;
|
import com.safeqr.app.qrcode.entity.WifiEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.service.WifiVerificationService;
|
import com.safeqr.app.qrcode.service.WifiVerificationService;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
@@ -12,14 +12,12 @@ import org.slf4j.LoggerFactory;
|
|||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class WifiModel extends QRCodeModel {
|
public final class WifiModel extends QRCodeModel<WifiEntity> {
|
||||||
private static final Logger logger = LoggerFactory.getLogger(WifiModel.class);
|
private static final Logger logger = LoggerFactory.getLogger(WifiModel.class);
|
||||||
|
|
||||||
@JsonIgnore
|
@JsonIgnore
|
||||||
private final WifiVerificationService wifiVerificationService;
|
private final WifiVerificationService wifiVerificationService;
|
||||||
|
|
||||||
WifiEntity details;
|
|
||||||
|
|
||||||
public WifiModel(QRCodeEntity scannedQRCodeEntity, WifiVerificationService wifiVerificationService) {
|
public WifiModel(QRCodeEntity scannedQRCodeEntity, WifiVerificationService wifiVerificationService) {
|
||||||
this.scannedQRCode = scannedQRCodeEntity;
|
this.scannedQRCode = scannedQRCodeEntity;
|
||||||
this.wifiVerificationService = wifiVerificationService;
|
this.wifiVerificationService = wifiVerificationService;
|
||||||
@@ -32,4 +30,8 @@ public class WifiModel extends QRCodeModel {
|
|||||||
// Insert into wifi table
|
// Insert into wifi table
|
||||||
wifiVerificationService.insertDB(details);
|
wifiVerificationService.insertDB(details);
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
public WifiEntity getDetails () {
|
||||||
|
return new WifiEntity();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.EmailModel;
|
import com.safeqr.app.qrcode.model.EmailModel;
|
||||||
import com.safeqr.app.qrcode.service.EmailVerificationService;
|
import com.safeqr.app.qrcode.service.EmailVerificationService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.PhoneModel;
|
import com.safeqr.app.qrcode.model.PhoneModel;
|
||||||
import com.safeqr.app.qrcode.service.PhoneVerificationService;
|
import com.safeqr.app.qrcode.service.PhoneVerificationService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|||||||
@@ -1,10 +1,9 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.QRCodeModel;
|
import com.safeqr.app.qrcode.model.QRCodeModel;
|
||||||
|
|
||||||
@FunctionalInterface
|
@FunctionalInterface
|
||||||
public interface QRCodeFactory<T extends QRCodeModel> {
|
public interface QRCodeFactory<T extends QRCodeModel<?>> {
|
||||||
T create(QRCodeEntity scannedQRCodeEntity);
|
T create(QRCodeEntity scannedQRCodeEntity);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.QRCodeModel;
|
import com.safeqr.app.qrcode.model.QRCodeModel;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.SMSModel;
|
import com.safeqr.app.qrcode.model.SMSModel;
|
||||||
import com.safeqr.app.qrcode.service.SMSVerificationService;
|
import com.safeqr.app.qrcode.service.SMSVerificationService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.TextModel;
|
import com.safeqr.app.qrcode.model.TextModel;
|
||||||
import com.safeqr.app.qrcode.service.TextVerificationService;
|
import com.safeqr.app.qrcode.service.TextVerificationService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.URLModel;
|
import com.safeqr.app.qrcode.model.URLModel;
|
||||||
import com.safeqr.app.qrcode.service.URLVerificationService;
|
import com.safeqr.app.qrcode.service.URLVerificationService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.model.factory;
|
package com.safeqr.app.qrcode.model.factory;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
|
||||||
import com.safeqr.app.qrcode.model.WifiModel;
|
import com.safeqr.app.qrcode.model.WifiModel;
|
||||||
import com.safeqr.app.qrcode.service.WifiVerificationService;
|
import com.safeqr.app.qrcode.service.WifiVerificationService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|||||||
@@ -1,8 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.EmailEntity;
|
import com.safeqr.app.qrcode.entity.EmailEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public interface EmailRepository extends JpaRepository<EmailEntity, UUID> {
|
public interface EmailRepository extends GenericRepository<EmailEntity> {
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,10 @@
|
|||||||
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.data.repository.NoRepositoryBean;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@NoRepositoryBean
|
||||||
|
public interface GenericRepository<T> extends JpaRepository<T, UUID> {
|
||||||
|
}
|
||||||
@@ -1,8 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.PhoneEntity;
|
import com.safeqr.app.qrcode.entity.PhoneEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public interface PhoneRepository extends JpaRepository<PhoneEntity, UUID> {
|
public interface PhoneRepository extends GenericRepository<PhoneEntity> {
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public interface QRCodeRepository extends JpaRepository<QRCodeEntity, UUID> {
|
public interface QRCodeRepository extends GenericRepository<QRCodeEntity> {
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.SMSEntity;
|
import com.safeqr.app.qrcode.entity.SMSEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public interface SMSRepository extends JpaRepository<SMSEntity, UUID> {
|
public interface SMSRepository extends GenericRepository<SMSEntity> {
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.TextEntity;
|
import com.safeqr.app.qrcode.entity.TextEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public interface TextRepository extends JpaRepository<TextEntity, UUID> {
|
public interface TextRepository extends GenericRepository<TextEntity> {
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,10 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.URLEntity;
|
import com.safeqr.app.qrcode.entity.URLEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
public interface URLRepository extends JpaRepository<URLEntity, UUID> {
|
public interface URLRepository extends GenericRepository<URLEntity> {
|
||||||
|
Optional<URLEntity> findByQrCodeId(UUID qrCodeId);
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,6 @@
|
|||||||
package com.safeqr.app.qrcode.repository;
|
package com.safeqr.app.qrcode.repository;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.entity.WifiEntity;
|
import com.safeqr.app.qrcode.entity.WifiEntity;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public interface WifiRepository extends JpaRepository<WifiEntity, UUID> {
|
public interface WifiRepository extends GenericRepository<WifiEntity> {
|
||||||
}
|
}
|
||||||
@@ -2,7 +2,9 @@
|
|||||||
package com.safeqr.app.qrcode.service;
|
package com.safeqr.app.qrcode.service;
|
||||||
|
|
||||||
import static com.safeqr.app.constants.CommonConstants.*;
|
import static com.safeqr.app.constants.CommonConstants.*;
|
||||||
import com.safeqr.app.qrcode.dto.QRCodePayload;
|
|
||||||
|
import com.safeqr.app.exceptions.QRCodeExceptions;
|
||||||
|
import com.safeqr.app.qrcode.dto.request.QRCodePayload;
|
||||||
import com.safeqr.app.qrcode.dto.response.BaseScanResponse;
|
import com.safeqr.app.qrcode.dto.response.BaseScanResponse;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeEntity;
|
||||||
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
import com.safeqr.app.qrcode.entity.QRCodeTypeEntity;
|
||||||
@@ -23,6 +25,8 @@ import java.security.NoSuchAlgorithmException;
|
|||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.UUID;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@@ -48,11 +52,8 @@ public class QRCodeTypeService {
|
|||||||
this.qrCodeRepository = qrCodeRepository;
|
this.qrCodeRepository = qrCodeRepository;
|
||||||
this.safeBrowsingService = safeBrowsingService;
|
this.safeBrowsingService = safeBrowsingService;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private List<QRCodeTypeEntity> configs;
|
private List<QRCodeTypeEntity> configs;
|
||||||
private QRCodeTypeEntity defaultQRCodeTypeEntity;
|
private QRCodeTypeEntity defaultQRCodeTypeEntity;
|
||||||
private Map<Long, QRCodeTypeEntity> qrCodeTypeMap;
|
|
||||||
|
|
||||||
@PostConstruct
|
@PostConstruct
|
||||||
public void loadQRCodeTypes() {
|
public void loadQRCodeTypes() {
|
||||||
@@ -63,15 +64,23 @@ public class QRCodeTypeService {
|
|||||||
.filter(config -> config.getType().equals(DEFAULT_QR_CODE_TYPE))
|
.filter(config -> config.getType().equals(DEFAULT_QR_CODE_TYPE))
|
||||||
.findFirst()
|
.findFirst()
|
||||||
.orElse(null);
|
.orElse(null);
|
||||||
// Construct the tableMap with key = qrCodeTypeId, value = tableName
|
|
||||||
qrCodeTypeMap = configs.stream().collect(Collectors.toMap(QRCodeTypeEntity::getId, Function.identity()));
|
|
||||||
logger.info("QRCodeType map: {}", qrCodeTypeMap);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<QRCodeTypeEntity> getAllTypes() {
|
public List<QRCodeTypeEntity> getAllTypes() {
|
||||||
return configs;
|
return configs;
|
||||||
}
|
}
|
||||||
|
// Get scanned qrcode details
|
||||||
|
public BaseScanResponse getScannedQRCodeDetails(UUID qrCodeId){
|
||||||
|
// Find scanned qr code in qr code table
|
||||||
|
QRCodeEntity qrCodeEntity = qrCodeRepository.findById(qrCodeId)
|
||||||
|
.orElseThrow(() -> new QRCodeExceptions("QR Code not found with id: " + qrCodeId));
|
||||||
|
logger.info("qrCodeEntity: {}", qrCodeEntity);
|
||||||
|
QRCodeModel<?> qrCodeModel = qrCodeFactoryProvider.createQRCodeInstance(qrCodeEntity);
|
||||||
|
logger.info("Retrieved details: {}", qrCodeModel.getDetails());
|
||||||
|
return BaseScanResponse.builder().qrcode(qrCodeModel).build();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Process Scanned QR Code
|
||||||
public BaseScanResponse scanQRCode(String userId, QRCodePayload payload) {
|
public BaseScanResponse scanQRCode(String userId, QRCodePayload payload) {
|
||||||
String data = payload.getData();
|
String data = payload.getData();
|
||||||
logger.info("scanQRCode: userId={}, data={}", userId, data);
|
logger.info("scanQRCode: userId={}, data={}", userId, data);
|
||||||
@@ -97,7 +106,7 @@ public class QRCodeTypeService {
|
|||||||
.build());
|
.build());
|
||||||
}
|
}
|
||||||
// Create the QR Code Instance based on the QR Code Type & insert into the respective table
|
// Create the QR Code Instance based on the QR Code Type & insert into the respective table
|
||||||
QRCodeModel qrCodeModel = qrCodeFactoryProvider.createQRCodeInstance(scannedQR);
|
QRCodeModel<?> qrCodeModel = qrCodeFactoryProvider.createQRCodeInstance(scannedQR);
|
||||||
qrCodeModel.setDetails();
|
qrCodeModel.setDetails();
|
||||||
|
|
||||||
return BaseScanResponse.builder().qrcode(qrCodeModel).build();
|
return BaseScanResponse.builder().qrcode(qrCodeModel).build();
|
||||||
@@ -109,10 +118,6 @@ public class QRCodeTypeService {
|
|||||||
.findFirst()
|
.findFirst()
|
||||||
.orElse(defaultQRCodeTypeEntity);
|
.orElse(defaultQRCodeTypeEntity);
|
||||||
}
|
}
|
||||||
// Returns name of table given type
|
|
||||||
public QRCodeTypeEntity getQRCodeMap(Long qrTypeId) {
|
|
||||||
return qrCodeTypeMap.get(qrTypeId);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Mono<String> detectType(QRCodePayload payload) {
|
public Mono<String> detectType(QRCodePayload payload) {
|
||||||
String data = payload.getData();
|
String data = payload.getData();
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
package com.safeqr.app.qrcode.service;
|
package com.safeqr.app.qrcode.service;
|
||||||
|
|
||||||
import com.safeqr.app.qrcode.dto.QRCodePayload;
|
import com.safeqr.app.qrcode.dto.request.QRCodePayload;
|
||||||
import com.safeqr.app.qrcode.dto.RedirectCountResponse;
|
import com.safeqr.app.qrcode.dto.RedirectCountResponse;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.web.reactive.function.client.WebClient;
|
import org.springframework.web.reactive.function.client.WebClient;
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
package com.safeqr.app.qrcode.service;
|
package com.safeqr.app.qrcode.service;
|
||||||
|
|
||||||
import static com.safeqr.app.constants.CommonConstants.*;
|
import static com.safeqr.app.constants.CommonConstants.*;
|
||||||
import com.safeqr.app.qrcode.dto.QRCodePayload;
|
|
||||||
|
import com.safeqr.app.exceptions.QRCodeExceptions;
|
||||||
|
import com.safeqr.app.qrcode.dto.request.QRCodePayload;
|
||||||
import com.safeqr.app.qrcode.dto.URLVerificationResponse;
|
import com.safeqr.app.qrcode.dto.URLVerificationResponse;
|
||||||
import com.safeqr.app.qrcode.entity.URLEntity;
|
import com.safeqr.app.qrcode.entity.URLEntity;
|
||||||
import com.safeqr.app.qrcode.repository.URLRepository;
|
import com.safeqr.app.qrcode.repository.URLRepository;
|
||||||
@@ -25,6 +27,12 @@ public class URLVerificationService {
|
|||||||
this.urlRepository = urlRepository;
|
this.urlRepository = urlRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public URLEntity getURLEntityByQRCodeId(UUID qrCodeId) {
|
||||||
|
logger.info("qrCodeId retrieving: {}", qrCodeId);
|
||||||
|
return urlRepository.findByQrCodeId(qrCodeId)
|
||||||
|
.orElseThrow(() -> new QRCodeExceptions("URL not found for QR Code id: " + qrCodeId));
|
||||||
|
}
|
||||||
|
|
||||||
public void insertDB(URLEntity urlEntity) {
|
public void insertDB(URLEntity urlEntity) {
|
||||||
urlRepository.save(urlEntity);
|
urlRepository.save(urlEntity);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
package com.safeqr.app.qrcode.service;
|
package com.safeqr.app.qrcode.service;
|
||||||
|
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import com.safeqr.app.qrcode.dto.QRCodePayload;
|
import com.safeqr.app.qrcode.dto.request.QRCodePayload;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ spring.datasource.url=${SERVER_DB_URL}
|
|||||||
spring.datasource.username=${SERVER_DB_USERNAME}
|
spring.datasource.username=${SERVER_DB_USERNAME}
|
||||||
spring.datasource.password=${SERVER_DB_PASSWORD}
|
spring.datasource.password=${SERVER_DB_PASSWORD}
|
||||||
spring.datasource.driver-class-name=${SERVER_DB_DRIVER_CLASS_NAME}
|
spring.datasource.driver-class-name=${SERVER_DB_DRIVER_CLASS_NAME}
|
||||||
#spring.jpa.database-platform=${SERVER_DB_DIALECT}
|
spring.jpa.database-platform=${SERVER_DB_DIALECT}
|
||||||
spring.jpa.hibernate.ddl-auto=none
|
spring.jpa.hibernate.ddl-auto=none
|
||||||
spring.jpa.show-sql=true
|
spring.jpa.show-sql=true
|
||||||
spring.jpa.properties.hibernate.format_sql=true
|
spring.jpa.properties.hibernate.format_sql=true
|
||||||
|
|||||||
Reference in New Issue
Block a user