@ -0,0 +1,15 @@ | |||||
Thumbs.db | |||||
.DS_Store | |||||
.gradle | |||||
build/ | |||||
target/ | |||||
out/ | |||||
.micronaut/ | |||||
.idea | |||||
*.iml | |||||
*.ipr | |||||
*.iws | |||||
.project | |||||
.settings | |||||
.classpath | |||||
.factorypath |
@ -0,0 +1,3 @@ | |||||
{ | |||||
"java.configuration.updateBuildConfiguration": "interactive" | |||||
} |
@ -0,0 +1,31 @@ | |||||
## Micronaut 4.8.3 Documentation | |||||
- [User Guide](https://docs.micronaut.io/4.8.3/guide/index.html) | |||||
- [API Reference](https://docs.micronaut.io/4.8.3/api/index.html) | |||||
- [Configuration Reference](https://docs.micronaut.io/4.8.3/guide/configurationreference.html) | |||||
- [Micronaut Guides](https://guides.micronaut.io/index.html) | |||||
--- | |||||
- [Shadow Gradle Plugin](https://gradleup.com/shadow/) | |||||
- [Micronaut Gradle Plugin documentation](https://micronaut-projects.github.io/micronaut-gradle-plugin/latest/) | |||||
- [GraalVM Gradle Plugin documentation](https://graalvm.github.io/native-build-tools/latest/gradle-plugin.html) | |||||
## Feature validation documentation | |||||
- [Micronaut Validation documentation](https://micronaut-projects.github.io/micronaut-validation/latest/guide/) | |||||
## Feature test-resources documentation | |||||
- [Micronaut Test Resources documentation](https://micronaut-projects.github.io/micronaut-test-resources/latest/guide/) | |||||
## Feature micronaut-aot documentation | |||||
- [Micronaut AOT documentation](https://micronaut-projects.github.io/micronaut-aot/latest/guide/) | |||||
## Feature jdbc-hikari documentation | |||||
- [Micronaut Hikari JDBC Connection Pool documentation](https://micronaut-projects.github.io/micronaut-sql/latest/guide/index.html#jdbc) | |||||
@ -0,0 +1,83 @@ | |||||
plugins { | |||||
id("io.micronaut.application") version "4.5.3" | |||||
id("com.gradleup.shadow") version "8.3.6" | |||||
id("io.micronaut.test-resources") version "4.5.3" | |||||
id("io.micronaut.aot") version "4.5.3" | |||||
} | |||||
version = "0.1" | |||||
group = "jumapacelaya.gob.mx" | |||||
repositories { | |||||
mavenCentral() | |||||
flatDir { | |||||
dirs 'libs' | |||||
} | |||||
} | |||||
dependencies { | |||||
implementation("io.micronaut.sql:micronaut-jdbc") | |||||
annotationProcessor("io.micronaut:micronaut-http-validation") | |||||
annotationProcessor("io.micronaut.validation:micronaut-validation-processor") | |||||
implementation("io.micronaut:micronaut-jackson-databind") | |||||
implementation("io.micronaut.sql:micronaut-jdbc-hikari") | |||||
implementation("io.micronaut.validation:micronaut-validation") | |||||
implementation("jakarta.validation:jakarta.validation-api") | |||||
compileOnly("io.micronaut:micronaut-http-client") | |||||
runtimeOnly("ch.qos.logback:logback-classic") | |||||
runtimeOnly("com.oracle.database.jdbc:ojdbc11") | |||||
//runtimeOnly("com.oracle.database.jdbc:ojdbc8:19.3.0.0") | |||||
implementation("io.micronaut.data:micronaut-data-jdbc") | |||||
testImplementation("io.micronaut:micronaut-http-client") | |||||
runtimeOnly("org.yaml:snakeyaml") | |||||
implementation("jakarta.persistence:jakarta.persistence-api:3.1.0") | |||||
implementation("io.micronaut.data:micronaut-data-processor") | |||||
annotationProcessor("io.micronaut.data:micronaut-data-processor") | |||||
implementation("io.micronaut.data:micronaut-data-jpa") | |||||
implementation("io.micronaut.data:micronaut-data-hibernate-jpa") | |||||
} | |||||
application { | |||||
mainClass = "jumapacelaya.gob.mx.Application" | |||||
} | |||||
java { | |||||
sourceCompatibility = JavaVersion.toVersion("21") | |||||
targetCompatibility = JavaVersion.toVersion("21") | |||||
} | |||||
graalvmNative.toolchainDetection = false | |||||
micronaut { | |||||
runtime("netty") | |||||
testRuntime("junit5") | |||||
processing { | |||||
incremental(true) | |||||
annotations("jumapacelaya.gob.mx.*") | |||||
} | |||||
testResources { | |||||
enabled = false | |||||
//additionalModules.add("jdbc-oracle-free") | |||||
} | |||||
aot { | |||||
// Please review carefully the optimizations enabled below | |||||
// Check https://micronaut-projects.github.io/micronaut-aot/latest/guide/ for more details | |||||
optimizeServiceLoading = false | |||||
convertYamlToJava = false | |||||
precomputeOperations = true | |||||
cacheEnvironment = true | |||||
optimizeClassLoading = true | |||||
deduceEnvironment = true | |||||
optimizeNetty = true | |||||
replaceLogbackXml = true | |||||
} | |||||
} | |||||
tasks.named("dockerfileNative") { | |||||
jdkVersion = "21" | |||||
} | |||||
@ -0,0 +1 @@ | |||||
micronautVersion=4.8.3 |
@ -0,0 +1,7 @@ | |||||
distributionBase=GRADLE_USER_HOME | |||||
distributionPath=wrapper/dists | |||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-bin.zip | |||||
networkTimeout=10000 | |||||
validateDistributionUrl=true | |||||
zipStoreBase=GRADLE_USER_HOME | |||||
zipStorePath=wrapper/dists |
@ -0,0 +1,251 @@ | |||||
#!/bin/sh | |||||
# | |||||
# Copyright © 2015-2021 the original authors. | |||||
# | |||||
# Licensed under the Apache License, Version 2.0 (the "License"); | |||||
# you may not use this file except in compliance with the License. | |||||
# You may obtain a copy of the License at | |||||
# | |||||
# https://www.apache.org/licenses/LICENSE-2.0 | |||||
# | |||||
# Unless required by applicable law or agreed to in writing, software | |||||
# distributed under the License is distributed on an "AS IS" BASIS, | |||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |||||
# See the License for the specific language governing permissions and | |||||
# limitations under the License. | |||||
# | |||||
# SPDX-License-Identifier: Apache-2.0 | |||||
# | |||||
############################################################################## | |||||
# | |||||
# Gradle start up script for POSIX generated by Gradle. | |||||
# | |||||
# Important for running: | |||||
# | |||||
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is | |||||
# noncompliant, but you have some other compliant shell such as ksh or | |||||
# bash, then to run this script, type that shell name before the whole | |||||
# command line, like: | |||||
# | |||||
# ksh Gradle | |||||
# | |||||
# Busybox and similar reduced shells will NOT work, because this script | |||||
# requires all of these POSIX shell features: | |||||
# * functions; | |||||
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», | |||||
# «${var#prefix}», «${var%suffix}», and «$( cmd )»; | |||||
# * compound commands having a testable exit status, especially «case»; | |||||
# * various built-in commands including «command», «set», and «ulimit». | |||||
# | |||||
# Important for patching: | |||||
# | |||||
# (2) This script targets any POSIX shell, so it avoids extensions provided | |||||
# by Bash, Ksh, etc; in particular arrays are avoided. | |||||
# | |||||
# The "traditional" practice of packing multiple parameters into a | |||||
# space-separated string is a well documented source of bugs and security | |||||
# problems, so this is (mostly) avoided, by progressively accumulating | |||||
# options in "$@", and eventually passing that to Java. | |||||
# | |||||
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, | |||||
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; | |||||
# see the in-line comments for details. | |||||
# | |||||
# There are tweaks for specific operating systems such as AIX, CygWin, | |||||
# Darwin, MinGW, and NonStop. | |||||
# | |||||
# (3) This script is generated from the Groovy template | |||||
# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt | |||||
# within the Gradle project. | |||||
# | |||||
# You can find Gradle at https://github.com/gradle/gradle/. | |||||
# | |||||
############################################################################## | |||||
# Attempt to set APP_HOME | |||||
# Resolve links: $0 may be a link | |||||
app_path=$0 | |||||
# Need this for daisy-chained symlinks. | |||||
while | |||||
APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path | |||||
[ -h "$app_path" ] | |||||
do | |||||
ls=$( ls -ld "$app_path" ) | |||||
link=${ls#*' -> '} | |||||
case $link in #( | |||||
/*) app_path=$link ;; #( | |||||
*) app_path=$APP_HOME$link ;; | |||||
esac | |||||
done | |||||
# This is normally unused | |||||
# shellcheck disable=SC2034 | |||||
APP_BASE_NAME=${0##*/} | |||||
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036) | |||||
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s\n' "$PWD" ) || exit | |||||
# Use the maximum available, or set MAX_FD != -1 to use that value. | |||||
MAX_FD=maximum | |||||
warn () { | |||||
echo "$*" | |||||
} >&2 | |||||
die () { | |||||
echo | |||||
echo "$*" | |||||
echo | |||||
exit 1 | |||||
} >&2 | |||||
# OS specific support (must be 'true' or 'false'). | |||||
cygwin=false | |||||
msys=false | |||||
darwin=false | |||||
nonstop=false | |||||
case "$( uname )" in #( | |||||
CYGWIN* ) cygwin=true ;; #( | |||||
Darwin* ) darwin=true ;; #( | |||||
MSYS* | MINGW* ) msys=true ;; #( | |||||
NONSTOP* ) nonstop=true ;; | |||||
esac | |||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | |||||
# Determine the Java command to use to start the JVM. | |||||
if [ -n "$JAVA_HOME" ] ; then | |||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | |||||
# IBM's JDK on AIX uses strange locations for the executables | |||||
JAVACMD=$JAVA_HOME/jre/sh/java | |||||
else | |||||
JAVACMD=$JAVA_HOME/bin/java | |||||
fi | |||||
if [ ! -x "$JAVACMD" ] ; then | |||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | |||||
Please set the JAVA_HOME variable in your environment to match the | |||||
location of your Java installation." | |||||
fi | |||||
else | |||||
JAVACMD=java | |||||
if ! command -v java >/dev/null 2>&1 | |||||
then | |||||
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | |||||
Please set the JAVA_HOME variable in your environment to match the | |||||
location of your Java installation." | |||||
fi | |||||
fi | |||||
# Increase the maximum file descriptors if we can. | |||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then | |||||
case $MAX_FD in #( | |||||
max*) | |||||
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. | |||||
# shellcheck disable=SC2039,SC3045 | |||||
MAX_FD=$( ulimit -H -n ) || | |||||
warn "Could not query maximum file descriptor limit" | |||||
esac | |||||
case $MAX_FD in #( | |||||
'' | soft) :;; #( | |||||
*) | |||||
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. | |||||
# shellcheck disable=SC2039,SC3045 | |||||
ulimit -n "$MAX_FD" || | |||||
warn "Could not set maximum file descriptor limit to $MAX_FD" | |||||
esac | |||||
fi | |||||
# Collect all arguments for the java command, stacking in reverse order: | |||||
# * args from the command line | |||||
# * the main class name | |||||
# * -classpath | |||||
# * -D...appname settings | |||||
# * --module-path (only if needed) | |||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. | |||||
# For Cygwin or MSYS, switch paths to Windows format before running java | |||||
if "$cygwin" || "$msys" ; then | |||||
APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | |||||
CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | |||||
JAVACMD=$( cygpath --unix "$JAVACMD" ) | |||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh | |||||
for arg do | |||||
if | |||||
case $arg in #( | |||||
-*) false ;; # don't mess with options #( | |||||
/?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath | |||||
[ -e "$t" ] ;; #( | |||||
*) false ;; | |||||
esac | |||||
then | |||||
arg=$( cygpath --path --ignore --mixed "$arg" ) | |||||
fi | |||||
# Roll the args list around exactly as many times as the number of | |||||
# args, so each arg winds up back in the position where it started, but | |||||
# possibly modified. | |||||
# | |||||
# NB: a `for` loop captures its iteration list before it begins, so | |||||
# changing the positional parameters here affects neither the number of | |||||
# iterations, nor the values presented in `arg`. | |||||
shift # remove old arg | |||||
set -- "$@" "$arg" # push replacement arg | |||||
done | |||||
fi | |||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | |||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | |||||
# Collect all arguments for the java command: | |||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments, | |||||
# and any embedded shellness will be escaped. | |||||
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be | |||||
# treated as '${Hostname}' itself on the command line. | |||||
set -- \ | |||||
"-Dorg.gradle.appname=$APP_BASE_NAME" \ | |||||
-classpath "$CLASSPATH" \ | |||||
org.gradle.wrapper.GradleWrapperMain \ | |||||
"$@" | |||||
# Stop when "xargs" is not available. | |||||
if ! command -v xargs >/dev/null 2>&1 | |||||
then | |||||
die "xargs is not available" | |||||
fi | |||||
# Use "xargs" to parse quoted args. | |||||
# | |||||
# With -n1 it outputs one arg per line, with the quotes and backslashes removed. | |||||
# | |||||
# In Bash we could simply go: | |||||
# | |||||
# readarray ARGS < <( xargs -n1 <<<"$var" ) && | |||||
# set -- "${ARGS[@]}" "$@" | |||||
# | |||||
# but POSIX shell has neither arrays nor command substitution, so instead we | |||||
# post-process each arg (as a line of input to sed) to backslash-escape any | |||||
# character that might be a shell metacharacter, then use eval to reverse | |||||
# that process (while maintaining the separation between arguments), and wrap | |||||
# the whole thing up as a single "set" statement. | |||||
# | |||||
# This will of course break if any of these variables contains a newline or | |||||
# an unmatched quote. | |||||
# | |||||
eval "set -- $( | |||||
printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | | |||||
xargs -n1 | | |||||
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | | |||||
tr '\n' ' ' | |||||
)" '"$@"' | |||||
exec "$JAVACMD" "$@" |
@ -0,0 +1,94 @@ | |||||
@rem | |||||
@rem Copyright 2015 the original author or authors. | |||||
@rem | |||||
@rem Licensed under the Apache License, Version 2.0 (the "License"); | |||||
@rem you may not use this file except in compliance with the License. | |||||
@rem 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, software | |||||
@rem distributed under the License is distributed on an "AS IS" BASIS, | |||||
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |||||
@rem See the License for the specific language governing permissions and | |||||
@rem limitations under the License. | |||||
@rem | |||||
@rem SPDX-License-Identifier: Apache-2.0 | |||||
@rem | |||||
@if "%DEBUG%"=="" @echo off | |||||
@rem ########################################################################## | |||||
@rem | |||||
@rem Gradle startup script for Windows | |||||
@rem | |||||
@rem ########################################################################## | |||||
@rem Set local scope for the variables with windows NT shell | |||||
if "%OS%"=="Windows_NT" setlocal | |||||
set DIRNAME=%~dp0 | |||||
if "%DIRNAME%"=="" set DIRNAME=. | |||||
@rem This is normally unused | |||||
set APP_BASE_NAME=%~n0 | |||||
set APP_HOME=%DIRNAME% | |||||
@rem Resolve any "." and ".." in APP_HOME to make it shorter. | |||||
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | |||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | |||||
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | |||||
@rem Find java.exe | |||||
if defined JAVA_HOME goto findJavaFromJavaHome | |||||
set JAVA_EXE=java.exe | |||||
%JAVA_EXE% -version >NUL 2>&1 | |||||
if %ERRORLEVEL% equ 0 goto execute | |||||
echo. 1>&2 | |||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 | |||||
echo. 1>&2 | |||||
echo Please set the JAVA_HOME variable in your environment to match the 1>&2 | |||||
echo location of your Java installation. 1>&2 | |||||
goto fail | |||||
:findJavaFromJavaHome | |||||
set JAVA_HOME=%JAVA_HOME:"=% | |||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe | |||||
if exist "%JAVA_EXE%" goto execute | |||||
echo. 1>&2 | |||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 | |||||
echo. 1>&2 | |||||
echo Please set the JAVA_HOME variable in your environment to match the 1>&2 | |||||
echo location of your Java installation. 1>&2 | |||||
goto fail | |||||
:execute | |||||
@rem Setup the command line | |||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | |||||
@rem Execute Gradle | |||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | |||||
:end | |||||
@rem End local scope for the variables with windows NT shell | |||||
if %ERRORLEVEL% equ 0 goto mainEnd | |||||
:fail | |||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | |||||
rem the _cmd.exe /c_ return code! | |||||
set EXIT_CODE=%ERRORLEVEL% | |||||
if %EXIT_CODE% equ 0 set EXIT_CODE=1 | |||||
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% | |||||
exit /b %EXIT_CODE% | |||||
:mainEnd | |||||
if "%OS%"=="Windows_NT" endlocal | |||||
:omega |
@ -0,0 +1,6 @@ | |||||
applicationType: default | |||||
defaultPackage: jumapacelaya.gob.mx | |||||
testFramework: junit | |||||
sourceLanguage: java | |||||
buildTool: gradle | |||||
features: [app-name, gradle, http-client-test, jackson-databind, java, java-application, jdbc-hikari, junit, logback, micronaut-aot, micronaut-build, micronaut-http-validation, netty-server, oracle, properties, readme, shade, static-resources, test-resources, validation] |
@ -0,0 +1,4 @@ | |||||
rootProject.name="API_ePay_Micronaut" | |||||
@ -0,0 +1,10 @@ | |||||
package jumapacelaya.gob.mx; | |||||
import io.micronaut.runtime.Micronaut; | |||||
public class Application { | |||||
public static void main(String[] args) { | |||||
Micronaut.run(Application.class, args); | |||||
} | |||||
} |
@ -0,0 +1,12 @@ | |||||
package jumapacelaya.gob.mx.controller; | |||||
import io.micronaut.http.annotation.*; | |||||
@Controller("/ping") | |||||
public class PingController { | |||||
@Get("/") | |||||
public String ping() { | |||||
return "pong"; | |||||
} | |||||
} |
@ -0,0 +1,47 @@ | |||||
package jumapacelaya.gob.mx.predios.controlador; | |||||
import java.util.Collections; | |||||
import java.util.Map; | |||||
import java.util.Optional; | |||||
import io.micronaut.http.HttpResponse; | |||||
import io.micronaut.http.annotation.Controller; | |||||
import io.micronaut.http.annotation.Get; | |||||
import io.micronaut.http.annotation.PathVariable; | |||||
import jumapacelaya.gob.mx.predios.servicio.PredioServicio; | |||||
import jumapacelaya.gob.mx.predios.dto.PredioDTO; | |||||
@Controller("/predios") | |||||
public class PredioControlador { | |||||
private final PredioServicio predioServicio; | |||||
public PredioControlador(PredioServicio predioServicio) { | |||||
this.predioServicio = predioServicio; | |||||
} | |||||
@Get("/{id}") | |||||
public PredioDTO obtenerPredio(Long id) { | |||||
return predioServicio.obtenerPredio(id); | |||||
} | |||||
@Get("/var/{id}") | |||||
public HttpResponse<?> obtenerPredioVar(@PathVariable Long id) { | |||||
Optional<PredioDTO> predio = predioServicio.obtenerPredioVar(id); | |||||
if (predio.isPresent()) { | |||||
return HttpResponse.ok(predio.get()); | |||||
} else { | |||||
return HttpResponse.notFound(Collections.singletonMap("message", "Predio no encontrado")); | |||||
} | |||||
} | |||||
@Get("/atm/{referencia}") | |||||
public HttpResponse<?> getPredioATM(@PathVariable String referencia) { | |||||
return predioServicio.obtenerPredioATM(referencia) | |||||
.<HttpResponse<?>>map(HttpResponse::ok) | |||||
.orElse(HttpResponse.notFound( | |||||
Map.of("message", "Predio no encontrado para referencia: " + referencia) | |||||
)); | |||||
} | |||||
} |
@ -0,0 +1,16 @@ | |||||
package jumapacelaya.gob.mx.predios.convertidor; | |||||
import io.micronaut.core.convert.TypeConverter; | |||||
import io.micronaut.core.convert.ConversionContext; | |||||
import jakarta.inject.Singleton; | |||||
import java.math.BigDecimal; | |||||
import java.util.Optional; | |||||
@Singleton | |||||
public class BigDecimalToDoubleConverter implements TypeConverter<BigDecimal, Double> { | |||||
@Override | |||||
public Optional<Double> convert(BigDecimal object, Class<Double> targetType, ConversionContext context) { | |||||
return Optional.ofNullable(object != null ? object.doubleValue() : null); | |||||
} | |||||
} |
@ -0,0 +1,16 @@ | |||||
package jumapacelaya.gob.mx.predios.convertidor; | |||||
import io.micronaut.core.convert.TypeConverter; | |||||
import io.micronaut.core.convert.ConversionContext; | |||||
import jakarta.inject.Singleton; | |||||
import java.math.BigDecimal; | |||||
import java.util.Optional; | |||||
@Singleton | |||||
public class BigDecimalToIntegerConverter implements TypeConverter<BigDecimal, Integer> { | |||||
@Override | |||||
public Optional<Integer> convert(BigDecimal object, Class<Integer> targetType, ConversionContext context) { | |||||
return Optional.ofNullable(object != null ? object.intValue() : null); | |||||
} | |||||
} |
@ -0,0 +1,16 @@ | |||||
package jumapacelaya.gob.mx.predios.convertidor; | |||||
import io.micronaut.core.convert.TypeConverter; | |||||
import io.micronaut.core.convert.ConversionContext; | |||||
import jakarta.inject.Singleton; | |||||
import java.math.BigDecimal; | |||||
import java.util.Optional; | |||||
@Singleton | |||||
public class BigDecimalToLongConverter implements TypeConverter<BigDecimal, Long> { | |||||
@Override | |||||
public Optional<Long> convert(BigDecimal object, Class<Long> targetType, ConversionContext context) { | |||||
return Optional.ofNullable(object != null ? object.longValue() : null); | |||||
} | |||||
} |
@ -0,0 +1,135 @@ | |||||
package jumapacelaya.gob.mx.predios.dto; | |||||
import io.micronaut.core.annotation.Introspected; | |||||
@Introspected | |||||
public class PredioDTO { | |||||
private Long predioId; | |||||
private Long clienteId; | |||||
private String contrato; | |||||
private String nombreCliente; | |||||
private String direccion; | |||||
private String direccionMostrar; | |||||
private String direccionCorta; | |||||
private String telefono; | |||||
private Double coordX; | |||||
private Double coordY; | |||||
private String zonaFactId; | |||||
private String serialMedidor; | |||||
private String marcaMedidor; | |||||
private String modeloMedidor; | |||||
private String estadoPredioId; | |||||
private String estadoPredio; | |||||
private String usoId; | |||||
private String uso; | |||||
private Integer actividadId; | |||||
private String actividad; | |||||
private Double adeudoCortes; | |||||
// Constructor consulta predio | |||||
public PredioDTO(Long predioId, Long clienteId, String contrato, String nombreCliente, | |||||
String direccion, String direccionMostrar, String direccionCorta, String telefono, | |||||
Double coordX, Double coordY, String zonaFactId, String serialMedidor, | |||||
String marcaMedidor, String modeloMedidor, String estadoPredioId, | |||||
String estadoPredio, String usoId, String uso, Integer actividadId, | |||||
String actividad) { | |||||
this(predioId, clienteId, contrato, nombreCliente, direccion, direccionMostrar, direccionCorta, | |||||
telefono, coordX, coordY, zonaFactId, serialMedidor, marcaMedidor, modeloMedidor, | |||||
estadoPredioId, estadoPredio, usoId, uso, actividadId, actividad, null); | |||||
} | |||||
// Constructor completo (para restPredioVar) | |||||
public PredioDTO(Long predioId, Long clienteId, String contrato, String nombreCliente, | |||||
String direccion, String direccionMostrar, String direccionCorta, String telefono, | |||||
Double coordX, Double coordY, String zonaFactId, String serialMedidor, | |||||
String marcaMedidor, String modeloMedidor, String estadoPredioId, | |||||
String estadoPredio, String usoId, String uso, Integer actividadId, | |||||
String actividad, Double adeudoCortes) { | |||||
this.predioId = predioId; | |||||
this.clienteId = clienteId; | |||||
this.contrato = contrato; | |||||
this.nombreCliente = nombreCliente; | |||||
this.direccion = direccion; | |||||
this.direccionMostrar = direccionMostrar; | |||||
this.direccionCorta = direccionCorta; | |||||
this.telefono = telefono; | |||||
this.coordX = coordX; | |||||
this.coordY = coordY; | |||||
this.zonaFactId = zonaFactId; | |||||
this.serialMedidor = serialMedidor; | |||||
this.marcaMedidor = marcaMedidor; | |||||
this.modeloMedidor = modeloMedidor; | |||||
this.estadoPredioId = estadoPredioId; | |||||
this.estadoPredio = estadoPredio; | |||||
this.usoId = usoId; | |||||
this.uso = uso; | |||||
this.actividadId = actividadId; | |||||
this.actividad = actividad; | |||||
this.adeudoCortes = adeudoCortes; | |||||
} | |||||
// Getters y setters | |||||
public Long getPredioId() { return predioId; } | |||||
public void setPredioId(Long predioId) { this.predioId = predioId; } | |||||
public Long getClienteId() { return clienteId; } | |||||
public void setClienteId(Long clienteId) { this.clienteId = clienteId; } | |||||
public String getContrato() { return contrato; } | |||||
public void setContrato(String contrato) { this.contrato = contrato; } | |||||
public String getNombreCliente() { return nombreCliente; } | |||||
public void setNombreCliente(String nombreCliente) { this.nombreCliente = nombreCliente; } | |||||
public String getDireccion() { return direccion; } | |||||
public void setDireccion(String direccion) { this.direccion = direccion; } | |||||
public String getDireccionMostrar() { return direccionMostrar; } | |||||
public void setDireccionMostrar(String direccionMostrar) { this.direccionMostrar = direccionMostrar; } | |||||
public String getDireccionCorta() { return direccionCorta; } | |||||
public void setDireccionCorta(String direccionCorta) { this.direccionCorta = direccionCorta; } | |||||
public String getTelefono() { return telefono; } | |||||
public void setTelefono(String telefono) { this.telefono = telefono; } | |||||
public Double getCoordX() { return coordX; } | |||||
public void setCoordX(Double coordX) { this.coordX = coordX; } | |||||
public Double getCoordY() { return coordY; } | |||||
public void setCoordY(Double coordY) { this.coordY = coordY; } | |||||
public String getZonaFactId() { return zonaFactId; } | |||||
public void setZonaFactId(String zonaFactId) { this.zonaFactId = zonaFactId; } | |||||
public String getSerialMedidor() { return serialMedidor; } | |||||
public void setSerialMedidor(String serialMedidor) { this.serialMedidor = serialMedidor; } | |||||
public String getMarcaMedidor() { return marcaMedidor; } | |||||
public void setMarcaMedidor(String marcaMedidor) { this.marcaMedidor = marcaMedidor; } | |||||
public String getModeloMedidor() { return modeloMedidor; } | |||||
public void setModeloMedidor(String modeloMedidor) { this.modeloMedidor = modeloMedidor; } | |||||
public String getEstadoPredioId() { return estadoPredioId; } | |||||
public void setEstadoPredioId(String estadoPredioId) { this.estadoPredioId = estadoPredioId; } | |||||
public String getEstadoPredio() { return estadoPredio; } | |||||
public void setEstadoPredio(String estadoPredio) { this.estadoPredio = estadoPredio; } | |||||
public String getUsoId() { return usoId; } | |||||
public void setUsoId(String usoId) { this.usoId = usoId; } | |||||
public String getUso() { return uso; } | |||||
public void setUso(String uso) { this.uso = uso; } | |||||
public Integer getActividadId() { return actividadId; } | |||||
public void setActividadId(Integer actividadId) { this.actividadId = actividadId; } | |||||
public String getActividad() { return actividad; } | |||||
public void setActividad(String actividad) { this.actividad = actividad; } | |||||
public Double getAdeudoCortes() { return adeudoCortes; } | |||||
public void setAdeudoCortes(Double adeudoCortes) { this.adeudoCortes = adeudoCortes; } | |||||
} |
@ -0,0 +1,133 @@ | |||||
package jumapacelaya.gob.mx.predios.entidad; | |||||
import io.micronaut.core.annotation.Introspected; | |||||
import jakarta.persistence.*; | |||||
@Introspected | |||||
@Entity | |||||
@Table(name = "PREDIOS") | |||||
public class Predio { | |||||
@Id | |||||
@Column(name = "PREDIOID") | |||||
private Long predioId; | |||||
@Column(name = "CLIENTEID") | |||||
private Long clienteId; | |||||
@Column(name = "CONTRATO") | |||||
private String contrato; | |||||
@Column(name = "COORDX") | |||||
private Double coordX; | |||||
@Column(name = "COORDY") | |||||
private Double coordY; | |||||
@Column(name = "ZONAFACTID") | |||||
private String zonaFactId; | |||||
@Column(name = "SERIALMED") | |||||
private String serialMed; | |||||
@Column(name = "EDOPREDIOID") | |||||
private String edoPredioId; | |||||
@Column(name = "USOID") | |||||
private String usoId; | |||||
@Column(name = "ACTIVIDADID") | |||||
private Integer actividadId; | |||||
@Column(name = "DIRECID") | |||||
private Long direcId; | |||||
// Getters y setters | |||||
public Long getPredioId() { | |||||
return predioId; | |||||
} | |||||
public void setPredioId(Long predioId) { | |||||
this.predioId = predioId; | |||||
} | |||||
public Long getClienteId() { | |||||
return clienteId; | |||||
} | |||||
public void setClienteId(Long clienteId) { | |||||
this.clienteId = clienteId; | |||||
} | |||||
public String getContrato() { | |||||
return contrato; | |||||
} | |||||
public void setContrato(String contrato) { | |||||
this.contrato = contrato; | |||||
} | |||||
public Double getCoordX() { | |||||
return coordX; | |||||
} | |||||
public void setCoordX(Double coordX) { | |||||
this.coordX = coordX; | |||||
} | |||||
public Double getCoordY() { | |||||
return coordY; | |||||
} | |||||
public void setCoordY(Double coordY) { | |||||
this.coordY = coordY; | |||||
} | |||||
public String getZonaFactId() { | |||||
return zonaFactId; | |||||
} | |||||
public void setZonaFactId(String zonaFactId) { | |||||
this.zonaFactId = zonaFactId; | |||||
} | |||||
public String getSerialMed() { | |||||
return serialMed; | |||||
} | |||||
public void setSerialMed(String serialMed) { | |||||
this.serialMed = serialMed; | |||||
} | |||||
public String getEdoPredioId() { | |||||
return edoPredioId; | |||||
} | |||||
public void setEdoPredioId(String edoPredioId) { | |||||
this.edoPredioId = edoPredioId; | |||||
} | |||||
public String getUsoId() { | |||||
return usoId; | |||||
} | |||||
public void setUsoId(String usoId) { | |||||
this.usoId = usoId; | |||||
} | |||||
public Integer getActividadId() { | |||||
return actividadId; | |||||
} | |||||
public void setActividadId(Integer actividadId) { | |||||
this.actividadId = actividadId; | |||||
} | |||||
public Long getDirecId() { | |||||
return direcId; | |||||
} | |||||
public void setDirecId(Long direcId) { | |||||
this.direcId = direcId; | |||||
} | |||||
} |
@ -0,0 +1,32 @@ | |||||
package jumapacelaya.gob.mx.predios.repositorio; | |||||
import io.micronaut.data.annotation.Repository; | |||||
import io.micronaut.data.jdbc.annotation.JdbcRepository; | |||||
import io.micronaut.data.model.query.builder.sql.Dialect; | |||||
import io.micronaut.data.repository.CrudRepository; | |||||
import jumapacelaya.gob.mx.predios.entidad.Predio; | |||||
import jumapacelaya.gob.mx.predios.dto.PredioDTO; | |||||
import java.util.List; | |||||
import io.micronaut.data.annotation.Id; | |||||
import io.micronaut.data.annotation.Query; | |||||
@JdbcRepository(dialect = Dialect.ORACLE) | |||||
public interface PredioRepositorio extends CrudRepository<Predio, Long> { | |||||
/*@Query("Select predioid, clienteid, contrato, c.nombre nomcliente, " + | |||||
"fn_getdomicilio(p.direcid) direccion, fn_get_direccion(p.direcid) direccionmostrar, fn_direccionshort(p.direcid) direccioncorta, " + | |||||
"fn_gettelefono(clienteid) telefono, " + | |||||
"p.coordx, p.coordy, p.zonafactid, p.serialmed, marcamedid||'-'||ma.descripcion marcamed, (decode(mo.descripcion,null,'Desconocido',modelomedid||'-'||mo.descripcion)) modelomed, " + | |||||
"edopredioid, e.nombre edopredio, usoid, u.nombre uso, actividadid, a.nombre actividad " + | |||||
"from predios p " + | |||||
"left join clientes c using (clienteid) " + | |||||
"left join estadospredio e using(edopredioid) " + | |||||
"left join usos u using (usoid) " + | |||||
"left join actividades a using (usoid, actividadid) " + | |||||
"left join marcasmedidor ma using(marcamedid) " + | |||||
"left join modelosmedidor mo using(marcamedid, modelomedid) " + | |||||
"where predioid = :id") | |||||
Object[] findPredioById(@Id Long id);*/ | |||||
} |
@ -0,0 +1,243 @@ | |||||
package jumapacelaya.gob.mx.predios.servicio; | |||||
import io.micronaut.transaction.annotation.ReadOnly; | |||||
import io.micronaut.transaction.annotation.Transactional; | |||||
import jakarta.inject.Singleton; | |||||
import javax.sql.DataSource; | |||||
import java.sql.Connection; | |||||
import java.sql.PreparedStatement; | |||||
import java.sql.ResultSet; | |||||
import java.sql.SQLException; | |||||
import java.util.Optional; | |||||
import jumapacelaya.gob.mx.predios.dto.PredioDTO; | |||||
@Singleton | |||||
public class PredioServicio { | |||||
private final DataSource dataSource; | |||||
public PredioServicio(DataSource dataSource) { | |||||
this.dataSource = dataSource; | |||||
} | |||||
@ReadOnly | |||||
public PredioDTO obtenerPredio(Long predioId) { | |||||
String query = "SELECT predioid, clienteid, contrato, c.nombre nomcliente, " + | |||||
"fn_getdomicilio(p.direcid) direccion, fn_get_direccion(p.direcid) direccionmostrar, " + | |||||
"fn_direccionshort(p.direcid) direccioncorta, fn_gettelefono(clienteid) telefono, " + | |||||
"p.coordx, p.coordy, p.zonafactid, p.serialmed, " + | |||||
"marcamedid||'-'||ma.descripcion marcamed, " + | |||||
"(decode(mo.descripcion,null,'Desconocido',modelomedid||'-'||mo.descripcion)) modelomed, " + | |||||
"edopredioid, e.nombre edopredio, usoid, u.nombre uso, actividadid, a.nombre actividad " + | |||||
"FROM predios p " + | |||||
"LEFT JOIN clientes c USING (clienteid) " + | |||||
"LEFT JOIN estadospredio e USING(edopredioid) " + | |||||
"LEFT JOIN usos u USING (usoid) " + | |||||
"LEFT JOIN actividades a USING (usoid, actividadid) " + | |||||
"LEFT JOIN marcasmedidor ma USING(marcamedid) " + | |||||
"LEFT JOIN modelosmedidor mo USING(marcamedid, modelomedid) " + | |||||
"WHERE predioid = ?"; | |||||
try (Connection connection = dataSource.getConnection(); | |||||
PreparedStatement stmt = connection.prepareStatement(query)) { | |||||
stmt.setLong(1, predioId); | |||||
try (ResultSet rs = stmt.executeQuery()) { | |||||
if (rs.next()) { | |||||
return new PredioDTO( | |||||
rs.getLong("predioid"), | |||||
rs.getLong("clienteid"), | |||||
rs.getString("contrato"), | |||||
rs.getString("nomcliente"), | |||||
rs.getString("direccion"), | |||||
rs.getString("direccionmostrar"), | |||||
rs.getString("direccioncorta"), | |||||
rs.getString("telefono"), | |||||
rs.getDouble("coordx"), | |||||
rs.getDouble("coordy"), | |||||
rs.getString("zonafactid"), | |||||
rs.getString("serialmed"), | |||||
rs.getString("marcamed"), | |||||
rs.getString("modelomed"), | |||||
rs.getString("edopredioid"), | |||||
rs.getString("edopredio"), | |||||
rs.getString("usoid"), | |||||
rs.getString("uso"), | |||||
rs.getInt("actividadid"), | |||||
rs.getString("actividad") | |||||
); | |||||
} else { | |||||
return null; | |||||
} | |||||
} | |||||
} catch (SQLException e) { | |||||
throw new RuntimeException("Error al consultar predio: " + e.getMessage(), e); | |||||
} | |||||
} | |||||
@ReadOnly | |||||
public Optional<PredioDTO> obtenerPredioVar(Long predioId) { | |||||
String query = """ | |||||
SELECT predioid, clienteid, contrato, c.nombre nomcliente, | |||||
fn_getdomicilio(p.direcid) direccion, fn_get_direccion(p.direcid) direccionmostrar, fn_direccionshort(p.direcid) direccioncorta, | |||||
fn_gettelefono(clienteid) telefono, | |||||
p.coordx, p.coordy, p.zonafactid, p.serialmed, | |||||
marcamedid || '-' || ma.descripcion marcamed, | |||||
DECODE(mo.descripcion, NULL, 'Desconocido', modelomedid || '-' || mo.descripcion) modelomed, | |||||
edopredioid, e.nombre edopredio, usoid, u.nombre uso, | |||||
actividadid, a.nombre actividad, | |||||
(SELECT SUM(total) FROM TABLE(cobranza.pk_carven.fn_getadeudocortes(predioid, TO_CHAR(SYSDATE, 'dd/mm/yyyy')))) adeudocortes | |||||
FROM predios p | |||||
LEFT JOIN clientes c USING (clienteid) | |||||
LEFT JOIN estadospredio e USING (edopredioid) | |||||
LEFT JOIN usos u USING (usoid) | |||||
LEFT JOIN actividades a USING (usoid, actividadid) | |||||
LEFT JOIN marcasmedidor ma USING (marcamedid) | |||||
LEFT JOIN modelosmedidor mo USING (marcamedid, modelomedid) | |||||
WHERE predioid = ? | |||||
"""; | |||||
try (Connection connection = dataSource.getConnection(); | |||||
PreparedStatement stmt = connection.prepareStatement(query)) { | |||||
stmt.setLong(1, predioId); | |||||
try (ResultSet rs = stmt.executeQuery()) { | |||||
if (rs.next()) { | |||||
PredioDTO dto = new PredioDTO( | |||||
rs.getLong("predioid"), | |||||
rs.getLong("clienteid"), | |||||
rs.getString("contrato"), | |||||
rs.getString("nomcliente"), | |||||
rs.getString("direccion"), | |||||
rs.getString("direccionmostrar"), | |||||
rs.getString("direccioncorta"), | |||||
rs.getString("telefono"), | |||||
rs.getDouble("coordx"), | |||||
rs.getDouble("coordy"), | |||||
rs.getString("zonafactid"), | |||||
rs.getString("serialmed"), | |||||
rs.getString("marcamed"), | |||||
rs.getString("modelomed"), | |||||
rs.getString("edopredioid"), | |||||
rs.getString("edopredio"), | |||||
rs.getString("usoid"), | |||||
rs.getString("uso"), | |||||
rs.getInt("actividadid"), | |||||
rs.getString("actividad"), | |||||
rs.getDouble("adeudocortes") // asegúrate de haberlo agregado al DTO | |||||
); | |||||
return Optional.of(dto); | |||||
} else { | |||||
return Optional.empty(); | |||||
} | |||||
} | |||||
} catch (SQLException e) { | |||||
throw new RuntimeException("Error al consultar predio var: " + e.getMessage(), e); | |||||
} | |||||
} | |||||
@ReadOnly | |||||
public Optional<PredioDTO> obtenerPredioATM(String valor) { | |||||
if ("7777777".equals(valor)) { | |||||
return Optional.of(new PredioDTO( | |||||
7777777L, 7777777L, "7777777", "Cliente de Prueba ATMs", | |||||
"Dirección ficticia", "Dirección ficticia larga", "Dir. Falsa", | |||||
null, 0.0, 0.0, "G7", "13166429", "NO-AUTOMATICO", "Desconocido", | |||||
"NO", "NORMAL", "T", "TESTING", 7, "TESTING", 0.0 | |||||
)); | |||||
} | |||||
String query; | |||||
boolean isLong = valor.length() == 30; | |||||
boolean isContract = valor.length() == 8; | |||||
boolean isPredioId = valor.length() <= 6; | |||||
if (isLong) { | |||||
query = """ | |||||
SELECT predioid, contrato, clienteid, c.nombre nomcliente, | |||||
fn_getdomicilio(p.direcid) direccion, fn_get_direccion(p.direcid) direccionmostrar, | |||||
fn_direccionshort(p.direcid) direccioncorta, p.coordx, p.coordy, p.zonafactid, | |||||
p.serialmed, edopredioid, e.nombre edopredio, usoid, u.nombre uso, | |||||
actividadid, a.nombre actividad | |||||
FROM predios p | |||||
LEFT JOIN clientes c USING (clienteid) | |||||
LEFT JOIN estadospredio e USING (edopredioid) | |||||
LEFT JOIN usos u USING (usoid) | |||||
LEFT JOIN actividades a USING (usoid, actividadid) | |||||
WHERE predioid = TO_NUMBER(SUBSTR(?, 24, 6)) | |||||
"""; | |||||
} else if (isContract) { | |||||
query = """ | |||||
SELECT predioid, contrato, clienteid, c.nombre nomcliente, | |||||
fn_getdomicilio(p.direcid) direccion, fn_get_direccion(p.direcid) direccionmostrar, | |||||
fn_direccionshort(p.direcid) direccioncorta, p.coordx, p.coordy, p.zonafactid, | |||||
p.serialmed, edopredioid, e.nombre edopredio, usoid, u.nombre uso, | |||||
actividadid, a.nombre actividad | |||||
FROM predios p | |||||
LEFT JOIN clientes c USING (clienteid) | |||||
LEFT JOIN estadospredio e USING (edopredioid) | |||||
LEFT JOIN usos u USING (usoid) | |||||
LEFT JOIN actividades a USING (usoid, actividadid) | |||||
WHERE REGEXP_LIKE(contrato, ?) | |||||
"""; | |||||
} else if (isPredioId) { | |||||
query = """ | |||||
SELECT predioid, contrato, clienteid, c.nombre nomcliente, | |||||
fn_getdomicilio(p.direcid) direccion, fn_get_direccion(p.direcid) direccionmostrar, | |||||
fn_direccionshort(p.direcid) direccioncorta, p.coordx, p.coordy, p.zonafactid, | |||||
p.serialmed, edopredioid, e.nombre edopredio, usoid, u.nombre uso, | |||||
actividadid, a.nombre actividad | |||||
FROM predios p | |||||
LEFT JOIN clientes c USING (clienteid) | |||||
LEFT JOIN estadospredio e USING (edopredioid) | |||||
LEFT JOIN usos u USING (usoid) | |||||
LEFT JOIN actividades a USING (usoid, actividadid) | |||||
WHERE predioid = TO_NUMBER(?) | |||||
"""; | |||||
} else { | |||||
return Optional.empty(); | |||||
} | |||||
try (Connection conn = dataSource.getConnection(); | |||||
PreparedStatement stmt = conn.prepareStatement(query)) { | |||||
stmt.setString(1, valor); | |||||
try (ResultSet rs = stmt.executeQuery()) { | |||||
if (rs.next()) { | |||||
return Optional.of(new PredioDTO( | |||||
rs.getLong("predioid"), | |||||
rs.getLong("clienteid"), | |||||
rs.getString("contrato"), | |||||
rs.getString("nomcliente"), | |||||
rs.getString("direccion"), | |||||
rs.getString("direccionmostrar"), | |||||
rs.getString("direccioncorta"), | |||||
null, | |||||
rs.getDouble("coordx"), | |||||
rs.getDouble("coordy"), | |||||
rs.getString("zonafactid"), | |||||
rs.getString("serialmed"), | |||||
null, | |||||
null, | |||||
rs.getString("edopredioid"), | |||||
rs.getString("edopredio"), | |||||
rs.getString("usoid"), | |||||
rs.getString("uso"), | |||||
rs.getInt("actividadid"), | |||||
rs.getString("actividad"), | |||||
null | |||||
)); | |||||
} | |||||
} | |||||
} catch (SQLException e) { | |||||
throw new RuntimeException("Error al consultar predio ATM: " + e.getMessage(), e); | |||||
} | |||||
return Optional.empty(); | |||||
} | |||||
} |
@ -0,0 +1,19 @@ | |||||
micronaut: | |||||
application: | |||||
name: API_ePay_Micronaut | |||||
datasources: | |||||
default: | |||||
url: jdbc:oracle:thin:@svrcomer:1521/comerpdb.JUMAPACELAYA.GOB.MX | |||||
username: Comercial | |||||
password: Comercial | |||||
driverClassName: oracle.jdbc.OracleDriver | |||||
dialect: ORACLE | |||||
maximum-pool-size: 10 | |||||
schema-generate: NONE | |||||
autoCommit: true | |||||
logger: | |||||
levels: | |||||
io.micronaut.data: DEBUG | |||||
io.micronaut.jdbc: DEBUG |
@ -0,0 +1,14 @@ | |||||
<configuration> | |||||
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> | |||||
<!-- encoders are assigned the type | |||||
ch.qos.logback.classic.encoder.PatternLayoutEncoder by default --> | |||||
<encoder> | |||||
<pattern>%cyan(%d{HH:mm:ss.SSS}) %gray([%thread]) %highlight(%-5level) %magenta(%logger{36}) - %msg%n</pattern> | |||||
</encoder> | |||||
</appender> | |||||
<root level="info"> | |||||
<appender-ref ref="STDOUT" /> | |||||
</root> | |||||
</configuration> |
@ -0,0 +1,21 @@ | |||||
package jumapacelaya.gob.mx; | |||||
import io.micronaut.runtime.EmbeddedApplication; | |||||
import io.micronaut.test.extensions.junit5.annotation.MicronautTest; | |||||
import org.junit.jupiter.api.Test; | |||||
import org.junit.jupiter.api.Assertions; | |||||
import jakarta.inject.Inject; | |||||
@MicronautTest | |||||
class API_ePay_MicronautTest { | |||||
@Inject | |||||
EmbeddedApplication<?> application; | |||||
@Test | |||||
void testItWorks() { | |||||
Assertions.assertTrue(application.isRunning()); | |||||
} | |||||
} |