Commit eb6e114f by Daniel Avila Cardenas

subiendo cron validador resoluciones activas fe

parents
HELP.md
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.2/apache-maven-3.9.2-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar
server:
port: 8097
servlet:
contex-path: /api/v1.0/
spring:
datasource:
url : "jdbc:oracle:thin:@192.168.100.108:1521/TLC"
username: "TLC"
password : "tlc"
driver:
class-name: Oracle.jdbc.OracleDriver
application:
name: cronDisparadorEventosFE
version: develop # production
name-log: "logCronfeEventos.log"
apigee:
url: https://colsubsidio-prod.apigee.net
path:
auth: /oauth/client_credential/accesstoken
logger: /api/v1/tecnologia/logger
token:
url: /oauth/client_credential/accesstoken
clienteId: 6LaRJinvCnyv5CRmyyu4CU4wR5L2g6wH
clienteSecreto: V2qPQ0xB2gqWXtRX
maxTimeInMillis: 300000 #300000 millis = 5 minutes
facturas:
url: /api/v1/tecnologia/local/facturas
email:
send:
path: /api/v2/tecnologia/notificaciones/correos
remitente:
correo: infofacturaelectronica@colsubsidio.com
responder: infofacturaelectronica@colsubsidio.com
dev: daniel.avila@bitsamericas.com
copia: jjonatan.rojas@colsubsidio.com
copia2: nestor.martinez@colsubsidio.com
copia3: pedro.jimenezca@colsubsidio.com
subject: Notificación Analisis Resoluciones FE(Facturación electrónica)
apigeeFacturas:
url: https://colsubsidio-prod.apigee.net
token:
url: /oauth/client_credential/accesstoken
clienteId: 6LaRJinvCnyv5CRmyyu4CU4wR5L2g6wH
clienteSecreto: V2qPQ0xB2gqWXtRX
maxTimeInMillis: 300000 #300000 millis = 5 minutes
invoice-manager:
url: /api/v1/tecnologia/local/clientes/facturas
facturas:
url: /api/v1/tecnologia/local/facturas
xmlservive:
facturas:
url: http://192.168.100.103:8080/invoicemanager/billing/invoicemanager/vouchers
comprobante:
tipo: 5
api:
#cada minuto
#-0 5 * * * (Todos los dias 5AM)
cron: 0 */2 * ? * * #Media Noche 0 0,6 * * * (A las 12 AM y a las 6 AM)
constant:
resoluciones:
up: 1@Porciento
cp: 5
dp: 10
qp: 15
base: 50000
maximo: 1000000
query:
selectResoluciones: "SELECT CENTRO, NOMBRE_BASE, RESOLUCION, FECHA_INICIO, FECHA_VENCIMIENTO, PREFIJO, NUMERO_INICIAL, NUMERO_FINAL, TIPO, DIRECCION, MESES, SECUENCIA_SIGUIENTE, ESTADO, FECHA_REGISTRO , TERMINAL_RES, TIENDA_RES FROM TS_RESOLUCIONES tr WHERE ESTADO = 1 ORDER BY FECHA_VENCIMIENTO DESC"
selectByTerminalAndResolucion: "SELECT tr.PREFIJO,tr.TERMINAL_RES,tr.TIENDA_RES FROM TS_RESOLUCIONES tr WHERE tr.ESTADO = 1 AND tr.TERMINAL_RES = ? AND tr.RESOLUCION = ?"
logging:
file:
name: "log/app.log"
level:
com:
colsubsidio:
api.fe.cronfeeventos: INFO
This diff is collapsed. Click to expand it.
This diff is collapsed. Click to expand it.
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM https://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Apache Maven Wrapper startup batch script, version 3.2.0
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %*
if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %*
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set WRAPPER_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"
FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET WRAPPER_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET WRAPPER_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %WRAPPER_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%WRAPPER_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM If specified, validate the SHA-256 sum of the Maven wrapper jar file
SET WRAPPER_SHA_256_SUM=""
FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperSha256Sum" SET WRAPPER_SHA_256_SUM=%%B
)
IF NOT %WRAPPER_SHA_256_SUM%=="" (
powershell -Command "&{"^
"$hash = (Get-FileHash \"%WRAPPER_JAR%\" -Algorithm SHA256).Hash.ToLower();"^
"If('%WRAPPER_SHA_256_SUM%' -ne $hash){"^
" Write-Output 'Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised.';"^
" Write-Output 'Investigate or delete %WRAPPER_JAR% to attempt a clean download.';"^
" Write-Output 'If you updated your Maven version, you need to update the specified wrapperSha256Sum property.';"^
" exit 1;"^
"}"^
"}"
if ERRORLEVEL 1 goto error
)
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% ^
%JVM_CONFIG_MAVEN_PROPS% ^
%MAVEN_OPTS% ^
%MAVEN_DEBUG_OPTS% ^
-classpath %WRAPPER_JAR% ^
"-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^
%WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat"
if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%"=="on" pause
if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE%
cmd /C exit /B %ERROR_CODE%
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.1.RELEASE</version>
<relativePath/>
</parent>
<groupId>com.colsubsidio.api.fe</groupId>
<artifactId>cronfeeventos</artifactId>
<version>0.0.1</version>
<name>cronDisparadorEventosFE</name>
<description>Proyecto para generar eventos FE</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-rest</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.3.4</version><!--$NO-MVN-MAN-VER$-->
</dependency>
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20210307</version>
</dependency>
<dependency>
<groupId>com.oracle.database.jdbc</groupId>
<artifactId>ojdbc8</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.22</version><!--$NO-MVN-MAN-VER$-->
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
package com.colsubsidio.api.fe.cronfeeventos;
import com.colsubsidio.api.fe.cronfeeventos.bussiness.CronEventosFeBussinessImpl;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;
@SpringBootApplication
@EnableScheduling
@Slf4j
public class CronDisparadorEventosFeApplication {
public static void main(String[] args) {
SpringApplication.run(CronDisparadorEventosFeApplication.class, args);
}
@Autowired
CronEventosFeBussinessImpl cronEventos;
@Scheduled(cron = "${api.cron}")
public void run() {
log.info("Iniciando proceso [Validacion de resoluciones] [run] --> CronDisparadorEventosFeApplication()");
cronEventos.cronEventoResolution();
log.info("Finaliza proceso validacion de resoluciones");
}
}
package com.colsubsidio.api.fe.cronfeeventos.api;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("resolucion")
public class api {
}
package com.colsubsidio.api.fe.cronfeeventos.bussiness;
import com.colsubsidio.api.fe.cronfeeventos.services.ResolutionServiceImpl;
import com.colsubsidio.api.fe.cronfeeventos.util.LoggerFactory;
import org.springframework.stereotype.Component;
import java.time.Instant;
import java.time.LocalDateTime;
import java.util.Date;
@Component
public class CronEventosFeBussinessImpl {
private LoggerFactory loggerFactory;
private ResolutionServiceImpl service;
public CronEventosFeBussinessImpl(LoggerFactory loggerFactory, ResolutionServiceImpl service){
this.loggerFactory = loggerFactory;
this.service = service;
}
public void cronEventoResolution(){
loggerFactory.loggerInfo("Llamando proceso service --> resolutionProcesoActivo() []" + LocalDateTime.now());
this.service.resolutionProcesoActivo();
}
}
package com.colsubsidio.api.fe.cronfeeventos.config;
import lombok.Data;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
@Data
@Configuration
public class ConfigProperties {
@Value("${apigee.email.send.path}")
private String pathCorreo;
@Value("${apigee.email.send.remitente.correo}")
private String remitente;
@Value("${apigee.email.send.remitente.correo}")
private String remitente_responde;
@Value("${apigee.email.send.subject}")
private String email_subject;
@Value("${apigee.url}")
private String urlApigee;
@Value("${apigee.email.send.copia}")
private String copia;
@Value("${apigee.email.send.copia2}")
private String copia2;
@Value("${apigee.email.send.copia3}")
private String copia3;
@Value("${apigee.email.send.dev}")
private String dev;
@Value("${api.constant.base}")
private Integer porcentajeLimit;
@Value("${api.constant.resoluciones.cp}")
private Integer valor5;
@Value("${api.constant.resoluciones.dp}")
private Integer valor10;
@Value("${api.constant.resoluciones.qp}")
private Integer valor15;
@Value("${api.constant.maximo}")
private Integer resolucionesLimit;
}
package com.colsubsidio.api.fe.cronfeeventos.config;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
@Configuration
@ConfigurationProperties(prefix = "query")
public class QuerysProperties {
private String selectResoluciones;
private String selectByTerminalAndResolucion;
public QuerysProperties() {
}
public String getSelectResoluciones() {
return selectResoluciones;
}
public void setSelectResoluciones(String selectResoluciones) {
this.selectResoluciones = selectResoluciones;
}
public String getSelectByTerminalAndResolucion() {
return selectByTerminalAndResolucion;
}
public void setSelectByTerminalAndResolucion(String selectByTerminalAndResolucion) {
this.selectByTerminalAndResolucion = selectByTerminalAndResolucion;
}
}
package com.colsubsidio.api.fe.cronfeeventos.config;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
@EnableWebSecurity
public class WebSecurityConfig {
}
\ No newline at end of file
package com.colsubsidio.api.fe.cronfeeventos.dao;
import com.colsubsidio.api.fe.cronfeeventos.config.QuerysProperties;
import com.colsubsidio.api.fe.cronfeeventos.dto.ResolucionDTO;
import com.colsubsidio.api.fe.cronfeeventos.util.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
@Repository
@Transactional
public class ResolucionDao {
@Autowired
LoggerFactory loggerFactory;
@Autowired
JdbcTemplate jdbcTemplate;
@Autowired
QuerysProperties querysProperties;
/**
* Metodo que permite consultar todas las resoluciones que se manejan en el proceso de facturacion
* Tablas TS_RESOLUCIONES
* @return una lista de objetos ResolucionDTO con la información de las resoluciones y sus secuencias
*/
public List<ResolucionDTO> consultarResolucionesTLC(){
String sql = querysProperties.getSelectResoluciones();
return jdbcTemplate.query(sql, (rs, rowNum) -> {
ResolucionDTO resolution = new ResolucionDTO();
resolution.setCentro(rs.getString("CENTRO"));
resolution.setNombre_base(rs.getString("NOMBRE_BASE"));
resolution.setResolucion(rs.getString("RESOLUCION"));
resolution.setFecha_inicio(rs.getDate("FECHA_INICIO"));
resolution.setFecha_vencimiento(rs.getDate("FECHA_VENCIMIENTO"));
resolution.setPrefijo(rs.getString("PREFIJO"));
resolution.setNumero_inicial(rs.getInt("NUMERO_INICIAL"));
resolution.setNumero_final(rs.getLong("NUMERO_FINAL"));
resolution.setTipo(rs.getString("TIPO"));
resolution.setDireccion(rs.getString("DIRECCION"));
resolution.setMeses(rs.getInt("MESES"));
resolution.setSecuencia_siguiente(rs.getLong("SECUENCIA_SIGUIENTE"));
resolution.setEstado(rs.getInt("ESTADO"));
resolution.setFecha_registro(rs.getDate("FECHA_REGISTRO"));
resolution.setTerminal_res(rs.getInt("TERMINAL_RES"));
resolution.setTienda_res(rs.getInt("TIENDA_RES"));
return resolution;
});
}
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import javax.xml.ws.Response;
public class ApiResponse<T> {
private boolean success;
private String status;
private String message;
private T date;
public ApiResponse(boolean success, String status, String message, T date) {
this.success = success;
this.status = status;
this.message = message;
this.date = date;
}
public static <T> ResponseEntity<ApiResponse<T>> success(T data){
ApiResponse<T> response = new ApiResponse<>(true, "200","Exito! Resultados Obtenidos", data);
return new ResponseEntity<>(response , HttpStatus.OK);
}
public static <T> ResponseEntity<ApiResponse<T>> sucess(String message,T data){
ApiResponse<T> response = new ApiResponse<>(true, "200",message, data);
return new ResponseEntity<>(response , HttpStatus.OK);
}
public static <T> ResponseEntity<ApiResponse<T>> error(String message){
ApiResponse<T> response = new ApiResponse<>(false, "400",message, null);
return new ResponseEntity<>(response , HttpStatus.BAD_REQUEST);
}
public boolean isSuccess() {
return success;
}
public String getStatus() {
return status;
}
public String getMessage() {
return message;
}
public T getDate() {
return date;
}
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.http.HttpStatus;
import lombok.*;
@Data
@Builder
public class ApigeeLogDTO {
private String url;
private Object body;
private Object bodyResponse;
private HttpMethod method;
private HttpStatus status;
private long timeConn;
private HttpHeaders headers;
private String error;
private String tag;
}
\ No newline at end of file
package com.colsubsidio.api.fe.cronfeeventos.dto;
import lombok.*;
@AllArgsConstructor
@NoArgsConstructor
@ToString
@Builder
@Data
public class ApigeeTokenReqDTO {
private String clienteId;
private String clienteSecreto;
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.*;
import java.util.List;
@AllArgsConstructor
@NoArgsConstructor
@ToString
@Builder
@Data
public class ApigeeTokenResDTO {
private String refresh_token_expires_in;
private String api_product_list;
private List<String> api_product_list_json;
private String organization_name;
@JsonProperty("developer.email")
private String developer_email;
private String token_type;
private String issued_at;
private String client_id;
private String access_token;
private String application_name;
private String scope;
private String expires_in;
private String refresh_count;
private String status;
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import lombok.*;
import java.util.List;
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class EmailRequestDTO {
public Remitente remitente;
public String asunto;
public String fechaEnvio;
public Plantilla plantilla;
public List<Parametro> parametro;
public List<ArchivoAdjunto> archivoAdjunto;
public List<Destinatario> destinatario;
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public static class ArchivoAdjunto {
private String ruta;
private String contrasenia;
private String nombre;
private String accion;
}
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public static class Remitente {
public String correo;
public String responder;
public String enviado;
}
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public static class Plantilla {
public String tipo;
public String contenido;
}
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public static class Parametro {
public String server;
public String percent;
public String detalle;
}
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public static class Destinatario {
public String para;
public Remitente remitente;
public String asunto;
public String fechaEnvio;
public List<Parametro> parametro;
public List<ArchivoAdjunto> archivoAdjunto;
}
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import lombok.*;
import java.util.List;
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class EmailResponseDTO {
private List<Resultado> resultado;
private List<EnvioCorreo> envioCorreo;
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public static class Resultado {
private String codigo;
private String descripcion;
}
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ToString
public static class EnvioCorreo {
private String codigo;
}
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.sql.Date;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class ResolucionDTO {
private String centro;
private String nombre_base;
private String resolucion;
private Date fecha_inicio;
private Date fecha_vencimiento;
private String prefijo;
private Integer numero_inicial;
private Long numero_final;
private String tipo;
private String direccion;
private Integer meses;
private Long secuencia_siguiente;
private Integer estado;
private Date fecha_registro;
private Integer terminal_res;
private Integer tienda_res;
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class ResolutionTemplate {
private String numeroResolucion;
private String tienda;
private String terminal;
private String nombreBase;
private String fechaVencimiento;
private String secuenciaSiguiente;
private String diasCaducidad;
private String detalle;
private String criterio;
}
package com.colsubsidio.api.fe.cronfeeventos.dto;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class ResponseDTO {
private String statusCode;
private String message;
private String response;
}
package com.colsubsidio.api.fe.cronfeeventos.services;
import com.colsubsidio.api.fe.cronfeeventos.dto.ApigeeTokenReqDTO;
import com.colsubsidio.api.fe.cronfeeventos.dto.ApigeeTokenResDTO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.http.*;
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.client.RestTemplate;
import org.springframework.web.util.UriComponentsBuilder;
import java.time.LocalDateTime;
import java.time.ZoneId;
@Component
@Slf4j
public class ApigeeService {
@Value("${apigee.url}")
private String urlApi;
@Value("${apigee.token.clienteId}")
private String clienteId;
@Value("${apigee.token.clienteSecreto}")
private String clienteSecreto;
@Value("${apigee.token.maxTimeInMillis}")
private Long maxTimeInMillis;
@Value("${apigee.token.url}")
private String auth;
@Value("${apigee.path.logger}")
private String logger;
private String token;
private LocalDateTime tokenDate;
public String getToken() {
if (token == null) {
generateToken();
} else {
long tokenMillis = tokenDate.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
long currMillis = LocalDateTime.now().atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
long timeLive = currMillis - tokenMillis;
if (timeLive > maxTimeInMillis) {
generateToken();
}
}
return token;
}
private void generateToken() {
ApigeeTokenReqDTO request = new ApigeeTokenReqDTO();
request.setClienteId(clienteId);
request.setClienteSecreto(clienteSecreto);
token = postAccessToken(request).getAccess_token();
tokenDate = LocalDateTime.now();
}
public ApigeeTokenResDTO postAccessToken(ApigeeTokenReqDTO request) {
RestTemplate restTemplate = new RestTemplate();
UriComponentsBuilder uri = UriComponentsBuilder.fromHttpUrl(urlApi + auth);
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_JSON);
HttpEntity<ApigeeTokenReqDTO> entity = new HttpEntity<>(request, headers);
ResponseEntity<ApigeeTokenResDTO> result
= restTemplate.exchange(uri.toUriString(), HttpMethod.POST, entity, ApigeeTokenResDTO.class);
return result.getBody();
}
}
package com.colsubsidio.api.fe.cronfeeventos.services;
import com.colsubsidio.api.fe.cronfeeventos.config.ConfigProperties;
import com.colsubsidio.api.fe.cronfeeventos.dto.EmailRequestDTO;
import com.colsubsidio.api.fe.cronfeeventos.dto.EmailResponseDTO;
import com.colsubsidio.api.fe.cronfeeventos.dto.ResponseDTO;
import com.colsubsidio.api.fe.cronfeeventos.util.HandleDate;
import com.colsubsidio.api.fe.cronfeeventos.util.RestTemplateUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.http.HttpMethod;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Component;
import org.springframework.web.util.UriComponentsBuilder;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
@Component
@Slf4j
public class EmailService {
@Autowired
private RestTemplateUtil restTemplateUtil;
@Autowired
private HandleDate handleDate;
@Autowired
ConfigProperties configProperties;
/**
* clase encargada de crear el cuerpo y datos del email
* @throws IOException
*/
public EmailRequestDTO setTemplateEmailMessageContent(String template) throws IOException {
try{
log.info("Modelando datos [setTemplateEmailMessageContent] [EmailService] -> ");
EmailRequestDTO emailRequestDTO = new EmailRequestDTO();
List<EmailRequestDTO.Parametro> listaParametros = new ArrayList<>();
EmailRequestDTO.Remitente remitente = new EmailRequestDTO.Remitente(configProperties.getRemitente(), configProperties.getRemitente_responde(), "");
emailRequestDTO.setRemitente(remitente);
emailRequestDTO.setPlantilla(new EmailRequestDTO.Plantilla("text/html", template));
emailRequestDTO.setAsunto(configProperties.getEmail_subject());
emailRequestDTO.setDestinatario(new ArrayList<>());
EmailRequestDTO.Destinatario destinatario = new EmailRequestDTO.Destinatario();
destinatario.setAsunto(configProperties.getEmail_subject());
destinatario.setPara(configProperties.getDev());
destinatario.setParametro(listaParametros);
emailRequestDTO.getDestinatario().add(destinatario);
emailRequestDTO.setParametro(listaParametros);
destinatario = new EmailRequestDTO.Destinatario();
destinatario.setAsunto(configProperties.getEmail_subject());
destinatario.setPara(configProperties.getCopia());
destinatario.setParametro(listaParametros);
emailRequestDTO.getDestinatario().add(destinatario);
destinatario = new EmailRequestDTO.Destinatario();
destinatario.setAsunto(configProperties.getEmail_subject());
destinatario.setPara(configProperties.getCopia2());
destinatario.setParametro(listaParametros);
emailRequestDTO.getDestinatario().add(destinatario);
destinatario = new EmailRequestDTO.Destinatario();
destinatario.setAsunto(configProperties.getEmail_subject());
destinatario.setPara(configProperties.getCopia3());
destinatario.setParametro(listaParametros);
emailRequestDTO.getDestinatario().add(destinatario);
return emailRequestDTO;
}catch (Exception e){
log.error("Error modelando el DTO para envio del email:" + e);
}
return null;
}
/**
* metodo encargado de enviar un email
*
* @param emailRequestDTO
*/
public ResponseDTO send(EmailRequestDTO emailRequestDTO) {
ResponseDTO responseDTO = new ResponseDTO();
UriComponentsBuilder uriMail = UriComponentsBuilder.fromHttpUrl(configProperties.getUrlApigee() + configProperties.getPathCorreo());
ResponseEntity<EmailResponseDTO> res = restTemplateUtil.sendRequest(uriMail, HttpMethod.POST, emailRequestDTO, EmailResponseDTO.class, null, true, "Envio email");
if (res.getStatusCode().is2xxSuccessful()) {
log.info("email enviado de forma exitosa emailRequestDTO:" + emailRequestDTO);
log.info("email enviado de forma exitosa");
responseDTO.setMessage("email enviado de forma exitosa emailRequestDTO:" + emailRequestDTO);
responseDTO.setResponse(Objects.requireNonNull(res.getBody()).toString());
responseDTO.setStatusCode(res.getStatusCode().toString());
} else {
log.error("Error enviando el email emailRequestDTO: "+ emailRequestDTO);
log.error("Error enviando el email response:" + res );
responseDTO.setMessage("Error enviando el email emailRequestDTO:" + emailRequestDTO);
responseDTO.setResponse(Objects.requireNonNull(res.getBody()).toString());
responseDTO.setStatusCode(res.getStatusCode().toString());
}
return responseDTO;
}
}
\ No newline at end of file
package com.colsubsidio.api.fe.cronfeeventos.util;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class FormatDate {
//2021-10-28
public static String getDateSimple(String fecha){
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd");
Date date = null ;
try {
date = dateFormatter.parse(fecha);
} catch (ParseException e) {
e.printStackTrace();
}
//System.out.println("Format 1: " + dateFormatter.format( date ));
return dateFormatter.format( date );
}
//2021-10-28T14:22:25.670Z
public static String getDateEspecialFormato(String fecha){
//SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'hh:mm:ss.SSSZ");
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'hh:mm:ss.0Z");
Date date = null ;
try {
date = new SimpleDateFormat("yyyy-MM-dd").parse(fecha);
} catch (ParseException e) {
e.printStackTrace();
}
//System.out.println("Format 2: " + dateFormatter.format( date ));
return dateFormatter.format( date );
}
public static String convertFecha(String fechaLlegada){
String[] arrays_numeros = fechaLlegada.split("");
String nuevaFecha = "";
for (int j = 0; j < arrays_numeros.length; j++){
if (j == 4 || j == 6 ) {
nuevaFecha = nuevaFecha.concat( "-" );
}
nuevaFecha = nuevaFecha.concat( arrays_numeros[j] );
}
//System.out.println("nuevaFecha: " + nuevaFecha);
return nuevaFecha;
}
public static String getDiferenciaFechasMesOrDias(String fechaInicial, String fechaFinal){
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd");
Date fecha1 = null ;
Date fecha2 = null ;
try {
fecha1 = dateFormatter.parse(fechaInicial);
fecha2 = dateFormatter.parse(fechaFinal);
} catch (ParseException e) {
e.printStackTrace();
}
int milisecondsByDay = 86400000;
int dias = (int) ((fecha2.getTime()-fecha1.getTime()) / milisecondsByDay);
String salida;
if (dias < 30 ){
salida = dias + " dias";
}
else{
int cantidadMeses = Math.round( ( dias / 30 ) ) ;
salida = (cantidadMeses > 1) ? cantidadMeses + " meses" : cantidadMeses + " mes";
}
return salida;
}
}
\ No newline at end of file
package com.colsubsidio.api.fe.cronfeeventos.util;
import com.google.gson.Gson;
public class GsonUtils {
/**
* Convierte de un objecto a un string
* @param src
* @return
*/
public static String serialize(Object src) {
Gson gson = new Gson();
return gson.toJson(src);
}
/**
* Convierte de string a un objecto
* @param <D>
* @param json
* @param dClass
* @return
*/
public static <D> D toObject(String json, Class<D> dClass) {
Gson gson = new Gson();
return gson.fromJson(json, dClass);
}
/**
* Convierte de un objecto a otro objecto
* @param <D>
* @param src
* @param dClass
* @return
*/
public static <D> D toObject(Object src, Class<D> dClass) {
Gson gson = new Gson();
String srcJson = gson.toJson(src);
return gson.fromJson(srcJson, dClass);
}
}
package com.colsubsidio.api.fe.cronfeeventos.util;
import java.text.SimpleDateFormat;
import java.time.DateTimeException;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.temporal.ChronoUnit;
import java.util.*;
import org.springframework.stereotype.Component;
@Component
public class HandleDate {
private static TimeZone timeZone = TimeZone.getTimeZone("America/Bogota");
public Date retornDateNow() {
Date date = null;
try {
Calendar calendar = Calendar.getInstance();
calendar.setTimeZone(timeZone);
date = Calendar.getInstance().getTime();
} catch (Exception e) {}
return date;
}
public String retornDateNowSimpleDateFormat() {
String date = null;
try {
Calendar calendar = Calendar.getInstance();
calendar.setTimeZone(timeZone);
SimpleDateFormat formatter = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss");
date = formatter.format(calendar.getTime());
} catch (Exception e) {}
return date;
}
public static Date retornDateByDay(int day) {
Date date = null;
try {
Calendar calendar = Calendar.getInstance();
calendar.setTimeZone(timeZone);
calendar.add(Calendar.DAY_OF_YEAR, -day);
date = calendar.getTime();
} catch (Exception e) {}
return date;
}
public static String retornDateTimeFormat(String date){
String str = null;
try {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date d = sdf.parse(date);
SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'");
str= sdf2.format(d);
} catch (Exception e) {}
return str;
}
public Date retornDateToString(String d) {
Date date = null;
try {
Calendar calendar = Calendar.getInstance();
SimpleDateFormat sdf = new SimpleDateFormat("dd-MM-yyyy HH:mm:ss");
calendar.setTime(sdf.parse(d));
calendar.setTimeZone(timeZone);
date = calendar.getTime();
} catch (Exception e) {}
return date;
}
public Long getMillisecondsFromStartDate(Date startdate) {
LocalDateTime startDateCast = startdate.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime();
return startDateCast.until(LocalDateTime.now(), ChronoUnit.MILLIS);
}
public String getMonthInPhraseFromInt(int month ){
String month_string = null;
String result = null;
try {
Locale locale = new Locale("es","ES");
Calendar calendarInicio = Calendar.getInstance();
calendarInicio.set(Calendar.MONTH, month-1);
month_string = calendarInicio.getDisplayName(Calendar.MONTH, Calendar.LONG, locale);
result = month_string.toUpperCase().charAt(0) + month_string.substring(1, month_string.length()).toLowerCase();
}catch (DateTimeException e){}
return result;
}
}
package com.colsubsidio.api.fe.cronfeeventos.util;
import org.slf4j.Logger;
import org.springframework.stereotype.Component;
@Component
public class LoggerFactory {
private static final Logger logger = org.slf4j.LoggerFactory.getLogger(LoggerFactory.class);
public void loggerTrace(String message, Object...objects){
logger.trace(message, objects);
}
public void loggerDebug(String message, Object...objects){
logger.debug(message, objects);
}
public void loggerError(String message, Object...objects){
logger.error(message, objects);
}
public void loggerInfo(String message, Object...objects){
logger.info(message, objects);
}
public void loggerWarn(String message, Object...objects){
logger.warn(message, objects);
}
}
package com.colsubsidio.api.fe.cronfeeventos.util;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
@Component
@Log4j2
@AllArgsConstructor
@NoArgsConstructor
public class LoggerUtil {
@Value("${spring.application.name}")
private String app;
@Value("${spring.application.version}")
private String version;
@Value("${spring.application.name-log}")
private String nombreLog;
@Async
public void logInfo(String message,Object...objects) {
log.info(message,objects);
}
@Async
public void logError(String message,Object...objects) {
log.error(message,objects);
}
@Async
public void logError(Exception e) {
log.error(e);
}
@Async
public void logTrace(String message,Object...objects) {
log.info(message,objects);
}
@Data
public static class MessageObject {
private Object message;
private String idProceso;
private String app;
private String type = "info";
}
}
\ No newline at end of file
package com.colsubsidio.api.fe.cronfeeventos.util;
import com.colsubsidio.api.fe.cronfeeventos.dto.ApigeeLogDTO;
import com.colsubsidio.api.fe.cronfeeventos.services.ApigeeService;
import com.google.gson.Gson;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.http.*;
import org.springframework.stereotype.Component;
import org.springframework.web.client.RestClientException;
import org.springframework.web.client.RestTemplate;
import org.springframework.web.util.UriComponentsBuilder;
@Component
public class RestTemplateUtil {
private static final String BEARER = "Bearer ";
@Autowired
private ApigeeService tokenService;
@Autowired
private RestTemplate restTemplate;
@Autowired
private LoggerUtil logUtils;
@Bean
public RestTemplate restTemplate(RestTemplateBuilder builder) {
// Do any additional configuration here
return builder.build();
}
public <T> ResponseEntity<T>sendRequest(UriComponentsBuilder uri,HttpMethod method ,Object body,Class<T> classOfT,HttpHeaders headersAdd,boolean apigeeToken,String tag){
long startTimeTry = System.currentTimeMillis();
ResponseEntity<String> resp = null;
ResponseEntity<T> result = null;
HttpHeaders headers = headersAdd!= null ? headersAdd : new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_JSON);
if(apigeeToken)
headers.add(HttpHeaders.AUTHORIZATION, BEARER + tokenService.getToken());
ApigeeLogDTO logServices = ApigeeLogDTO.builder()
.url(uri.toUriString())
.body(body)
.method(method)
.headers(headers)
.error("")
.tag(tag)
.build();
try {
HttpEntity<Object> entity = null;
entity = (body != null)?new HttpEntity<>(body,headers):new HttpEntity<>(headers);
resp = restTemplate.exchange(uri.toUriString(), method, entity, String.class);
logUtils.logInfo("info: [RestTemplateUtil][sendRequest] el servicio responde: ", resp);
T respClassOfT = new Gson().fromJson(resp.getBody(), classOfT);
result = new ResponseEntity<>(respClassOfT,resp.getHeaders(),resp.getStatusCode());
long endTimeConn = System.currentTimeMillis() - startTimeTry;
logServices.setBodyResponse(result.getBody());
logServices.setStatus((HttpStatus) result.getStatusCode());
logServices.setTimeConn(endTimeConn);
logUtils.logInfo("apigee api ws response: ",logServices);
}catch (Exception e) {
logUtils.logError("Error: [RestTemplateUtil][sendRequest] excepcion: ",e.getMessage());
buildLog(startTimeTry, resp, logServices, e);
}
return result;
}
private void buildLog(long startTimeTry, ResponseEntity<String> resp, ApigeeLogDTO logServices, Exception e) {
long endTimeConn = System.currentTimeMillis() - startTimeTry;
logServices.setBodyResponse(resp != null?resp.getBody():e.getMessage());
logServices.setStatus(resp != null? (HttpStatus) resp.getStatusCode() : HttpStatus.INTERNAL_SERVER_ERROR);
logServices.setTimeConn(endTimeConn);
logServices.setError(e.getMessage());
logUtils.logError(e.getMessage(),logServices);
}
public <T> ResponseEntity<T>sendRequest(UriComponentsBuilder uri,HttpMethod method ,Object body,Class<T> classOfT,HttpHeaders headersAdd,boolean apigeeToken,boolean isBodyJson){
long startTimeTry = System.currentTimeMillis();
ResponseEntity<String> resp = null;
ResponseEntity<T> result = null;
HttpHeaders headers = headersAdd!= null ? headersAdd : new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_JSON);
if(apigeeToken)
headers.add(HttpHeaders.AUTHORIZATION, BEARER + tokenService.getToken());
ApigeeLogDTO logServices = ApigeeLogDTO.builder()
.url(uri.toUriString())
.body(body)
.method(method)
.headers(headers)
.error("")
.build();
try {
HttpEntity<Object> entity = null;
entity = (body != null)?new HttpEntity<>(body,headers):new HttpEntity<>(headers);
resp = restTemplate.exchange(uri.toUriString(), method, entity, String.class);
if (classOfT != String.class) {
T respClassOfT = new Gson().fromJson(resp.getBody(), classOfT);
result = new ResponseEntity<>(respClassOfT,resp.getHeaders(),resp.getStatusCode());
}else {
T respClassOfT = (T) resp;
result = new ResponseEntity<>(respClassOfT,resp.getHeaders(),resp.getStatusCode());
}
long endTimeConn = System.currentTimeMillis() - startTimeTry;
logServices.setBodyResponse(result.getBody());
logServices.setStatus((HttpStatus) result.getStatusCode());
logServices.setTimeConn(endTimeConn);
logUtils.logInfo("apigee api ws response: ",logServices);
}catch (Exception e) {
buildLog(startTimeTry, resp, logServices, e);
}
return result;
}
}
\ No newline at end of file
spring:
config:
import: "file:./config/application.yml"
package com.colsubsidio.api.fe.cronfeeventos;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class CronDisparadorEventosFeApplicationTests {
@Test
void contextLoads() {
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment