Первый
This commit is contained in:
34
.gitignore
vendored
Normal file
34
.gitignore
vendored
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
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/
|
||||||
|
logs
|
||||||
19
.mvn/wrapper/maven-wrapper.properties
vendored
Normal file
19
.mvn/wrapper/maven-wrapper.properties
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
# or more contributor license agreements. See the NOTICE file
|
||||||
|
# distributed with this work for additional information
|
||||||
|
# regarding copyright ownership. The ASF licenses this file
|
||||||
|
# to you 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
|
||||||
|
#
|
||||||
|
# http://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.
|
||||||
|
wrapperVersion=3.3.2
|
||||||
|
distributionType=only-script
|
||||||
|
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.9/apache-maven-3.9.9-bin.zip
|
||||||
51
com_geovizor_dbms.properties
Normal file
51
com_geovizor_dbms.properties
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
spring.application.name=dbms
|
||||||
|
server.port=8084
|
||||||
|
|
||||||
|
issuer.name=geovizor
|
||||||
|
|
||||||
|
#??? ?????? ???????? ? ???????
|
||||||
|
logging.level.com.zaxxer.hikari=DEBUG
|
||||||
|
|
||||||
|
#spring.datasource.url=jdbc:postgresql://geovizor.com:5432/monitoring_new
|
||||||
|
#spring.datasource.username=postgres
|
||||||
|
#spring.datasource.password=y7HMHi0ATxx1VC3UU5WG
|
||||||
|
#spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
#????????? ??? ?????????? ? ????? ??????
|
||||||
|
spring.datasource.url=jdbc:postgresql://mcp.kz:5432/mcp
|
||||||
|
spring.datasource.username=igor
|
||||||
|
spring.datasource.password=VnzbUdcePSLtg22ktz13
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
#????????? ??? ???? ??????????
|
||||||
|
spring.datasource.hikari.maximum-pool-size=10
|
||||||
|
spring.datasource.hikari.minimum-idle=5
|
||||||
|
spring.datasource.hikari.max-lifetime=1700000
|
||||||
|
spring.datasource.hikari.idle-timeout=300000
|
||||||
|
spring.datasource.hikari.connection-timeout=30000
|
||||||
|
spring.datasource.hikari.connection-test-query=SELECT now()
|
||||||
|
spring.datasource.hikari.validation-timeout=60000
|
||||||
|
|
||||||
|
|
||||||
|
access.key=yon8FWKppyvpSSUMyRt3tGKiOKfZk3LRkgh9ZA2+Zh8=
|
||||||
|
access.time=600
|
||||||
|
|
||||||
|
refresh.key=yon8FWKppyvpSSUMyRt3tGKiOKfZk3LRkgh9ZA2+Zh8=
|
||||||
|
refresh.time=43200
|
||||||
|
|
||||||
|
|
||||||
|
captcha.key=PPExpv36jk4Vzda3NpYnXLfuHCLYXqaNrxlOH/Jr/1M=
|
||||||
|
captcha.time=600
|
||||||
|
|
||||||
|
mail.host=smtp.yandex.ru
|
||||||
|
mail.port=465
|
||||||
|
mail.loginModel=info@ccalm.org
|
||||||
|
mail.password=fu2lpsoGPGiq1xlRm8ag
|
||||||
|
|
||||||
|
url.reset=http://127.0.0.1:8088/reset
|
||||||
|
url.main=http://127.0.0.1:8088/
|
||||||
|
|
||||||
|
spring.redis.host=127.0.0.1
|
||||||
|
spring.redis.port=6379
|
||||||
|
spring.redis.password=9F3/NKWeOjd815vkadT2DcgVHf6fEpVQXw==
|
||||||
|
|
||||||
36
kz_istransit_dbms.properties
Normal file
36
kz_istransit_dbms.properties
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
spring.application.name=kz_istransit_dbms
|
||||||
|
server.port=8084
|
||||||
|
|
||||||
|
issuer.name=istransit
|
||||||
|
|
||||||
|
logging.level.com.zaxxer.hikari=DEBUG
|
||||||
|
|
||||||
|
spring.datasource.url=jdbc:postgresql://10.101.1.6:5432/transit_2024_09_03?ApplicationName=kz_istransit_jwt
|
||||||
|
spring.datasource.username=postgres
|
||||||
|
spring.datasource.password=PasSecrKey1
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
spring.datasource.hikari.maximum-pool-size=10
|
||||||
|
spring.datasource.hikari.minimum-idle=5
|
||||||
|
spring.datasource.hikari.max-lifetime=1700000
|
||||||
|
spring.datasource.hikari.idle-timeout=600000
|
||||||
|
spring.datasource.hikari.connection-timeout=30000
|
||||||
|
spring.datasource.hikari.connection-test-query=SELECT now()
|
||||||
|
spring.datasource.hikari.validation-timeout=60000
|
||||||
|
|
||||||
|
public.key=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArK1etFoDgmxQ8+5q6+QHXuMEqyo4AeD1/mNs87bXPOxSiC82bMKUL9ly0WVxG5IKQFYlffQbCg0ndH+OhU8p0x90qmwCeCn4bFT6nzA9sjYyQSUkci2dfUABXcsr3kSP2+KEPnTpdGYZQFEOR34ORt+HBPwMn6FWh0aJdmTqZH+Vy/dP3TysT7AGlsPi8IA9j3asyDZdS9exLKVVIzYkbHJUKpKHYc4T/260YauUtNyijbT5w4ZWSbHqeuzV/HGUCYIpfAZyMxhzKnRRfjQWaCz8v/q+FP1a+jtaD2e0St6J7WOnyTx2P2yNeyscELrJPAt7TyTcINlN5oZCd5hfdwIDAQAB
|
||||||
|
captcha.key=PPExpv36jk4Vzda3NpYnXLfuHCLYXqaNrxlOH/Jr/1M=
|
||||||
|
captcha.time=600
|
||||||
|
|
||||||
|
mail.host=92.46.51.29
|
||||||
|
mail.port=465
|
||||||
|
mail.login=no-reply@istt.kz
|
||||||
|
mail.password=je6&HHCEmJ
|
||||||
|
|
||||||
|
url.reset=http://127.0.0.1:8088/reset
|
||||||
|
url.main=http://127.0.0.1:8088/
|
||||||
|
|
||||||
|
spring.redis.host=10.101.1.6
|
||||||
|
spring.redis.port=6379
|
||||||
|
spring.redis.password=9F3/NKWeOjd815vkadT2DcgVHf6fEpVQXw==
|
||||||
|
|
||||||
36
kz_mcp_dbms.properties
Normal file
36
kz_mcp_dbms.properties
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
spring.application.name=kz_mcp_dbms
|
||||||
|
server.port=8084
|
||||||
|
|
||||||
|
issuer.name=geovizor
|
||||||
|
|
||||||
|
logging.level.com.zaxxer.hikari=DEBUG
|
||||||
|
|
||||||
|
spring.datasource.url=jdbc:postgresql://mcp.kz:5432/mcp
|
||||||
|
spring.datasource.username=igor
|
||||||
|
spring.datasource.password=VnzbUdcePSLtg22ktz13
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
spring.datasource.hikari.maximum-pool-size=10
|
||||||
|
spring.datasource.hikari.minimum-idle=5
|
||||||
|
spring.datasource.hikari.max-lifetime=1700000
|
||||||
|
spring.datasource.hikari.idle-timeout=600000
|
||||||
|
spring.datasource.hikari.connection-timeout=30000
|
||||||
|
spring.datasource.hikari.connection-test-query=SELECT now()
|
||||||
|
spring.datasource.hikari.validation-timeout=60000
|
||||||
|
|
||||||
|
public.key=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA30j+pSoKFHSdSulIGzdFtg+z+ANJPOSVFJ6jvehj1sonOqQsI2rz539+FgIrsDZE8iydFAlQNxS8vqYtWiQSksAUId7aOY/eq7mFkGW+U5xIA2OPgIvN0uhW1Edm85jS7aAg/P/c+lLHnPzQIFdsgVrAh4esFvVS10Pj6TjJVprDj0jOraIw84GVt0gYXZTudcvZavWcmGV1mQJf0jDIHQsCRcMJAE2lzBIKpJGPPZke9xs25lm8feTFR0NNjDNvCG4dYAimyAH36UslXa/zIfRB/7r4AB9KPBFxGe8szK1EcXbJY+paq+TazZJ8Lo8nEmpehCdHUNdD9iWtiYRjNQIDAQAB
|
||||||
|
captcha.key=PPExpv36jk4Vzda3NpYnXLfuHCLYXqaNrxlOH/Jr/1M=
|
||||||
|
captcha.time=600
|
||||||
|
|
||||||
|
mail.host=smtp.yandex.ru
|
||||||
|
mail.port=465
|
||||||
|
mail.loginModel=info@ccalm.org
|
||||||
|
mail.password=fu2lpsoGPGiq1xlRm8ag
|
||||||
|
|
||||||
|
url.reset=http://127.0.0.1:8088/reset
|
||||||
|
url.main=http://127.0.0.1:8088/
|
||||||
|
|
||||||
|
spring.redis.host=127.0.0.1
|
||||||
|
spring.redis.port=6379
|
||||||
|
spring.redis.password=9F3/NKWeOjd815vkadT2DcgVHf6fEpVQXw==
|
||||||
|
|
||||||
259
mvnw
vendored
Normal file
259
mvnw
vendored
Normal file
@ -0,0 +1,259 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
# Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
# or more contributor license agreements. See the NOTICE file
|
||||||
|
# distributed with this work for additional information
|
||||||
|
# regarding copyright ownership. The ASF licenses this file
|
||||||
|
# to you 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
|
||||||
|
#
|
||||||
|
# http://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.
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
# Apache Maven Wrapper startup batch script, version 3.3.2
|
||||||
|
#
|
||||||
|
# Optional ENV vars
|
||||||
|
# -----------------
|
||||||
|
# JAVA_HOME - location of a JDK home dir, required when download maven via java source
|
||||||
|
# MVNW_REPOURL - repo url base for downloading maven distribution
|
||||||
|
# MVNW_USERNAME/MVNW_PASSWORD - user and password for downloading maven
|
||||||
|
# MVNW_VERBOSE - true: enable verbose log; debug: trace the mvnw script; others: silence the output
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
set -euf
|
||||||
|
[ "${MVNW_VERBOSE-}" != debug ] || set -x
|
||||||
|
|
||||||
|
# OS specific support.
|
||||||
|
native_path() { printf %s\\n "$1"; }
|
||||||
|
case "$(uname)" in
|
||||||
|
CYGWIN* | MINGW*)
|
||||||
|
[ -z "${JAVA_HOME-}" ] || JAVA_HOME="$(cygpath --unix "$JAVA_HOME")"
|
||||||
|
native_path() { cygpath --path --windows "$1"; }
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# set JAVACMD and JAVACCMD
|
||||||
|
set_java_home() {
|
||||||
|
# For Cygwin and MinGW, ensure paths are in Unix format before anything is touched
|
||||||
|
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"
|
||||||
|
JAVACCMD="$JAVA_HOME/jre/sh/javac"
|
||||||
|
else
|
||||||
|
JAVACMD="$JAVA_HOME/bin/java"
|
||||||
|
JAVACCMD="$JAVA_HOME/bin/javac"
|
||||||
|
|
||||||
|
if [ ! -x "$JAVACMD" ] || [ ! -x "$JAVACCMD" ]; then
|
||||||
|
echo "The JAVA_HOME environment variable is not defined correctly, so mvnw cannot run." >&2
|
||||||
|
echo "JAVA_HOME is set to \"$JAVA_HOME\", but \"\$JAVA_HOME/bin/java\" or \"\$JAVA_HOME/bin/javac\" does not exist." >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
JAVACMD="$(
|
||||||
|
'set' +e
|
||||||
|
'unset' -f command 2>/dev/null
|
||||||
|
'command' -v java
|
||||||
|
)" || :
|
||||||
|
JAVACCMD="$(
|
||||||
|
'set' +e
|
||||||
|
'unset' -f command 2>/dev/null
|
||||||
|
'command' -v javac
|
||||||
|
)" || :
|
||||||
|
|
||||||
|
if [ ! -x "${JAVACMD-}" ] || [ ! -x "${JAVACCMD-}" ]; then
|
||||||
|
echo "The java/javac command does not exist in PATH nor is JAVA_HOME set, so mvnw cannot run." >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# hash string like Java String::hashCode
|
||||||
|
hash_string() {
|
||||||
|
str="${1:-}" h=0
|
||||||
|
while [ -n "$str" ]; do
|
||||||
|
char="${str%"${str#?}"}"
|
||||||
|
h=$(((h * 31 + $(LC_CTYPE=C printf %d "'$char")) % 4294967296))
|
||||||
|
str="${str#?}"
|
||||||
|
done
|
||||||
|
printf %x\\n $h
|
||||||
|
}
|
||||||
|
|
||||||
|
verbose() { :; }
|
||||||
|
[ "${MVNW_VERBOSE-}" != true ] || verbose() { printf %s\\n "${1-}"; }
|
||||||
|
|
||||||
|
die() {
|
||||||
|
printf %s\\n "$1" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
trim() {
|
||||||
|
# MWRAPPER-139:
|
||||||
|
# Trims trailing and leading whitespace, carriage returns, tabs, and linefeeds.
|
||||||
|
# Needed for removing poorly interpreted newline sequences when running in more
|
||||||
|
# exotic environments such as mingw bash on Windows.
|
||||||
|
printf "%s" "${1}" | tr -d '[:space:]'
|
||||||
|
}
|
||||||
|
|
||||||
|
# parse distributionUrl and optional distributionSha256Sum, requires .mvn/wrapper/maven-wrapper.properties
|
||||||
|
while IFS="=" read -r key value; do
|
||||||
|
case "${key-}" in
|
||||||
|
distributionUrl) distributionUrl=$(trim "${value-}") ;;
|
||||||
|
distributionSha256Sum) distributionSha256Sum=$(trim "${value-}") ;;
|
||||||
|
esac
|
||||||
|
done <"${0%/*}/.mvn/wrapper/maven-wrapper.properties"
|
||||||
|
[ -n "${distributionUrl-}" ] || die "cannot read distributionUrl property in ${0%/*}/.mvn/wrapper/maven-wrapper.properties"
|
||||||
|
|
||||||
|
case "${distributionUrl##*/}" in
|
||||||
|
maven-mvnd-*bin.*)
|
||||||
|
MVN_CMD=mvnd.sh _MVNW_REPO_PATTERN=/maven/mvnd/
|
||||||
|
case "${PROCESSOR_ARCHITECTURE-}${PROCESSOR_ARCHITEW6432-}:$(uname -a)" in
|
||||||
|
*AMD64:CYGWIN* | *AMD64:MINGW*) distributionPlatform=windows-amd64 ;;
|
||||||
|
:Darwin*x86_64) distributionPlatform=darwin-amd64 ;;
|
||||||
|
:Darwin*arm64) distributionPlatform=darwin-aarch64 ;;
|
||||||
|
:Linux*x86_64*) distributionPlatform=linux-amd64 ;;
|
||||||
|
*)
|
||||||
|
echo "Cannot detect native platform for mvnd on $(uname)-$(uname -m), use pure java version" >&2
|
||||||
|
distributionPlatform=linux-amd64
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
distributionUrl="${distributionUrl%-bin.*}-$distributionPlatform.zip"
|
||||||
|
;;
|
||||||
|
maven-mvnd-*) MVN_CMD=mvnd.sh _MVNW_REPO_PATTERN=/maven/mvnd/ ;;
|
||||||
|
*) MVN_CMD="mvn${0##*/mvnw}" _MVNW_REPO_PATTERN=/org/apache/maven/ ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# apply MVNW_REPOURL and calculate MAVEN_HOME
|
||||||
|
# maven home pattern: ~/.m2/wrapper/dists/{apache-maven-<version>,maven-mvnd-<version>-<platform>}/<hash>
|
||||||
|
[ -z "${MVNW_REPOURL-}" ] || distributionUrl="$MVNW_REPOURL$_MVNW_REPO_PATTERN${distributionUrl#*"$_MVNW_REPO_PATTERN"}"
|
||||||
|
distributionUrlName="${distributionUrl##*/}"
|
||||||
|
distributionUrlNameMain="${distributionUrlName%.*}"
|
||||||
|
distributionUrlNameMain="${distributionUrlNameMain%-bin}"
|
||||||
|
MAVEN_USER_HOME="${MAVEN_USER_HOME:-${HOME}/.m2}"
|
||||||
|
MAVEN_HOME="${MAVEN_USER_HOME}/wrapper/dists/${distributionUrlNameMain-}/$(hash_string "$distributionUrl")"
|
||||||
|
|
||||||
|
exec_maven() {
|
||||||
|
unset MVNW_VERBOSE MVNW_USERNAME MVNW_PASSWORD MVNW_REPOURL || :
|
||||||
|
exec "$MAVEN_HOME/bin/$MVN_CMD" "$@" || die "cannot exec $MAVEN_HOME/bin/$MVN_CMD"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ -d "$MAVEN_HOME" ]; then
|
||||||
|
verbose "found existing MAVEN_HOME at $MAVEN_HOME"
|
||||||
|
exec_maven "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "${distributionUrl-}" in
|
||||||
|
*?-bin.zip | *?maven-mvnd-?*-?*.zip) ;;
|
||||||
|
*) die "distributionUrl is not valid, must match *-bin.zip or maven-mvnd-*.zip, but found '${distributionUrl-}'" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# prepare tmp dir
|
||||||
|
if TMP_DOWNLOAD_DIR="$(mktemp -d)" && [ -d "$TMP_DOWNLOAD_DIR" ]; then
|
||||||
|
clean() { rm -rf -- "$TMP_DOWNLOAD_DIR"; }
|
||||||
|
trap clean HUP INT TERM EXIT
|
||||||
|
else
|
||||||
|
die "cannot create temp dir"
|
||||||
|
fi
|
||||||
|
|
||||||
|
mkdir -p -- "${MAVEN_HOME%/*}"
|
||||||
|
|
||||||
|
# Download and Install Apache Maven
|
||||||
|
verbose "Couldn't find MAVEN_HOME, downloading and installing it ..."
|
||||||
|
verbose "Downloading from: $distributionUrl"
|
||||||
|
verbose "Downloading to: $TMP_DOWNLOAD_DIR/$distributionUrlName"
|
||||||
|
|
||||||
|
# select .zip or .tar.gz
|
||||||
|
if ! command -v unzip >/dev/null; then
|
||||||
|
distributionUrl="${distributionUrl%.zip}.tar.gz"
|
||||||
|
distributionUrlName="${distributionUrl##*/}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# verbose opt
|
||||||
|
__MVNW_QUIET_WGET=--quiet __MVNW_QUIET_CURL=--silent __MVNW_QUIET_UNZIP=-q __MVNW_QUIET_TAR=''
|
||||||
|
[ "${MVNW_VERBOSE-}" != true ] || __MVNW_QUIET_WGET='' __MVNW_QUIET_CURL='' __MVNW_QUIET_UNZIP='' __MVNW_QUIET_TAR=v
|
||||||
|
|
||||||
|
# normalize http auth
|
||||||
|
case "${MVNW_PASSWORD:+has-password}" in
|
||||||
|
'') MVNW_USERNAME='' MVNW_PASSWORD='' ;;
|
||||||
|
has-password) [ -n "${MVNW_USERNAME-}" ] || MVNW_USERNAME='' MVNW_PASSWORD='' ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ -z "${MVNW_USERNAME-}" ] && command -v wget >/dev/null; then
|
||||||
|
verbose "Found wget ... using wget"
|
||||||
|
wget ${__MVNW_QUIET_WGET:+"$__MVNW_QUIET_WGET"} "$distributionUrl" -O "$TMP_DOWNLOAD_DIR/$distributionUrlName" || die "wget: Failed to fetch $distributionUrl"
|
||||||
|
elif [ -z "${MVNW_USERNAME-}" ] && command -v curl >/dev/null; then
|
||||||
|
verbose "Found curl ... using curl"
|
||||||
|
curl ${__MVNW_QUIET_CURL:+"$__MVNW_QUIET_CURL"} -f -L -o "$TMP_DOWNLOAD_DIR/$distributionUrlName" "$distributionUrl" || die "curl: Failed to fetch $distributionUrl"
|
||||||
|
elif set_java_home; then
|
||||||
|
verbose "Falling back to use Java to download"
|
||||||
|
javaSource="$TMP_DOWNLOAD_DIR/Downloader.java"
|
||||||
|
targetZip="$TMP_DOWNLOAD_DIR/$distributionUrlName"
|
||||||
|
cat >"$javaSource" <<-END
|
||||||
|
public class Downloader extends java.net.Authenticator
|
||||||
|
{
|
||||||
|
protected java.net.PasswordAuthentication getPasswordAuthentication()
|
||||||
|
{
|
||||||
|
return new java.net.PasswordAuthentication( System.getenv( "MVNW_USERNAME" ), System.getenv( "MVNW_PASSWORD" ).toCharArray() );
|
||||||
|
}
|
||||||
|
public static void main( String[] args ) throws Exception
|
||||||
|
{
|
||||||
|
setDefault( new Downloader() );
|
||||||
|
java.nio.file.Files.copy( java.net.URI.create( args[0] ).toURL().openStream(), java.nio.file.Paths.get( args[1] ).toAbsolutePath().normalize() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
END
|
||||||
|
# For Cygwin/MinGW, switch paths to Windows format before running javac and java
|
||||||
|
verbose " - Compiling Downloader.java ..."
|
||||||
|
"$(native_path "$JAVACCMD")" "$(native_path "$javaSource")" || die "Failed to compile Downloader.java"
|
||||||
|
verbose " - Running Downloader.java ..."
|
||||||
|
"$(native_path "$JAVACMD")" -cp "$(native_path "$TMP_DOWNLOAD_DIR")" Downloader "$distributionUrl" "$(native_path "$targetZip")"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# If specified, validate the SHA-256 sum of the Maven distribution zip file
|
||||||
|
if [ -n "${distributionSha256Sum-}" ]; then
|
||||||
|
distributionSha256Result=false
|
||||||
|
if [ "$MVN_CMD" = mvnd.sh ]; then
|
||||||
|
echo "Checksum validation is not supported for maven-mvnd." >&2
|
||||||
|
echo "Please disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." >&2
|
||||||
|
exit 1
|
||||||
|
elif command -v sha256sum >/dev/null; then
|
||||||
|
if echo "$distributionSha256Sum $TMP_DOWNLOAD_DIR/$distributionUrlName" | sha256sum -c >/dev/null 2>&1; then
|
||||||
|
distributionSha256Result=true
|
||||||
|
fi
|
||||||
|
elif command -v shasum >/dev/null; then
|
||||||
|
if echo "$distributionSha256Sum $TMP_DOWNLOAD_DIR/$distributionUrlName" | shasum -a 256 -c >/dev/null 2>&1; then
|
||||||
|
distributionSha256Result=true
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Checksum validation was requested but neither 'sha256sum' or 'shasum' are available." >&2
|
||||||
|
echo "Please install either command, or disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ $distributionSha256Result = false ]; then
|
||||||
|
echo "Error: Failed to validate Maven distribution SHA-256, your Maven distribution might be compromised." >&2
|
||||||
|
echo "If you updated your Maven version, you need to update the specified distributionSha256Sum property." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# unzip and move
|
||||||
|
if command -v unzip >/dev/null; then
|
||||||
|
unzip ${__MVNW_QUIET_UNZIP:+"$__MVNW_QUIET_UNZIP"} "$TMP_DOWNLOAD_DIR/$distributionUrlName" -d "$TMP_DOWNLOAD_DIR" || die "failed to unzip"
|
||||||
|
else
|
||||||
|
tar xzf${__MVNW_QUIET_TAR:+"$__MVNW_QUIET_TAR"} "$TMP_DOWNLOAD_DIR/$distributionUrlName" -C "$TMP_DOWNLOAD_DIR" || die "failed to untar"
|
||||||
|
fi
|
||||||
|
printf %s\\n "$distributionUrl" >"$TMP_DOWNLOAD_DIR/$distributionUrlNameMain/mvnw.url"
|
||||||
|
mv -- "$TMP_DOWNLOAD_DIR/$distributionUrlNameMain" "$MAVEN_HOME" || [ -d "$MAVEN_HOME" ] || die "fail to move MAVEN_HOME"
|
||||||
|
|
||||||
|
clean || :
|
||||||
|
exec_maven "$@"
|
||||||
149
mvnw.cmd
vendored
Normal file
149
mvnw.cmd
vendored
Normal file
@ -0,0 +1,149 @@
|
|||||||
|
<# : batch portion
|
||||||
|
@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 http://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.3.2
|
||||||
|
@REM
|
||||||
|
@REM Optional ENV vars
|
||||||
|
@REM MVNW_REPOURL - repo url base for downloading maven distribution
|
||||||
|
@REM MVNW_USERNAME/MVNW_PASSWORD - user and password for downloading maven
|
||||||
|
@REM MVNW_VERBOSE - true: enable verbose log; others: silence the output
|
||||||
|
@REM ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@IF "%__MVNW_ARG0_NAME__%"=="" (SET __MVNW_ARG0_NAME__=%~nx0)
|
||||||
|
@SET __MVNW_CMD__=
|
||||||
|
@SET __MVNW_ERROR__=
|
||||||
|
@SET __MVNW_PSMODULEP_SAVE=%PSModulePath%
|
||||||
|
@SET PSModulePath=
|
||||||
|
@FOR /F "usebackq tokens=1* delims==" %%A IN (`powershell -noprofile "& {$scriptDir='%~dp0'; $script='%__MVNW_ARG0_NAME__%'; icm -ScriptBlock ([Scriptblock]::Create((Get-Content -Raw '%~f0'))) -NoNewScope}"`) DO @(
|
||||||
|
IF "%%A"=="MVN_CMD" (set __MVNW_CMD__=%%B) ELSE IF "%%B"=="" (echo %%A) ELSE (echo %%A=%%B)
|
||||||
|
)
|
||||||
|
@SET PSModulePath=%__MVNW_PSMODULEP_SAVE%
|
||||||
|
@SET __MVNW_PSMODULEP_SAVE=
|
||||||
|
@SET __MVNW_ARG0_NAME__=
|
||||||
|
@SET MVNW_USERNAME=
|
||||||
|
@SET MVNW_PASSWORD=
|
||||||
|
@IF NOT "%__MVNW_CMD__%"=="" (%__MVNW_CMD__% %*)
|
||||||
|
@echo Cannot start maven from wrapper >&2 && exit /b 1
|
||||||
|
@GOTO :EOF
|
||||||
|
: end batch / begin powershell #>
|
||||||
|
|
||||||
|
$ErrorActionPreference = "Stop"
|
||||||
|
if ($env:MVNW_VERBOSE -eq "true") {
|
||||||
|
$VerbosePreference = "Continue"
|
||||||
|
}
|
||||||
|
|
||||||
|
# calculate distributionUrl, requires .mvn/wrapper/maven-wrapper.properties
|
||||||
|
$distributionUrl = (Get-Content -Raw "$scriptDir/.mvn/wrapper/maven-wrapper.properties" | ConvertFrom-StringData).distributionUrl
|
||||||
|
if (!$distributionUrl) {
|
||||||
|
Write-Error "cannot read distributionUrl property in $scriptDir/.mvn/wrapper/maven-wrapper.properties"
|
||||||
|
}
|
||||||
|
|
||||||
|
switch -wildcard -casesensitive ( $($distributionUrl -replace '^.*/','') ) {
|
||||||
|
"maven-mvnd-*" {
|
||||||
|
$USE_MVND = $true
|
||||||
|
$distributionUrl = $distributionUrl -replace '-bin\.[^.]*$',"-windows-amd64.zip"
|
||||||
|
$MVN_CMD = "mvnd.cmd"
|
||||||
|
break
|
||||||
|
}
|
||||||
|
default {
|
||||||
|
$USE_MVND = $false
|
||||||
|
$MVN_CMD = $script -replace '^mvnw','mvn'
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# apply MVNW_REPOURL and calculate MAVEN_HOME
|
||||||
|
# maven home pattern: ~/.m2/wrapper/dists/{apache-maven-<version>,maven-mvnd-<version>-<platform>}/<hash>
|
||||||
|
if ($env:MVNW_REPOURL) {
|
||||||
|
$MVNW_REPO_PATTERN = if ($USE_MVND) { "/org/apache/maven/" } else { "/maven/mvnd/" }
|
||||||
|
$distributionUrl = "$env:MVNW_REPOURL$MVNW_REPO_PATTERN$($distributionUrl -replace '^.*'+$MVNW_REPO_PATTERN,'')"
|
||||||
|
}
|
||||||
|
$distributionUrlName = $distributionUrl -replace '^.*/',''
|
||||||
|
$distributionUrlNameMain = $distributionUrlName -replace '\.[^.]*$','' -replace '-bin$',''
|
||||||
|
$MAVEN_HOME_PARENT = "$HOME/.m2/wrapper/dists/$distributionUrlNameMain"
|
||||||
|
if ($env:MAVEN_USER_HOME) {
|
||||||
|
$MAVEN_HOME_PARENT = "$env:MAVEN_USER_HOME/wrapper/dists/$distributionUrlNameMain"
|
||||||
|
}
|
||||||
|
$MAVEN_HOME_NAME = ([System.Security.Cryptography.MD5]::Create().ComputeHash([byte[]][char[]]$distributionUrl) | ForEach-Object {$_.ToString("x2")}) -join ''
|
||||||
|
$MAVEN_HOME = "$MAVEN_HOME_PARENT/$MAVEN_HOME_NAME"
|
||||||
|
|
||||||
|
if (Test-Path -Path "$MAVEN_HOME" -PathType Container) {
|
||||||
|
Write-Verbose "found existing MAVEN_HOME at $MAVEN_HOME"
|
||||||
|
Write-Output "MVN_CMD=$MAVEN_HOME/bin/$MVN_CMD"
|
||||||
|
exit $?
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! $distributionUrlNameMain -or ($distributionUrlName -eq $distributionUrlNameMain)) {
|
||||||
|
Write-Error "distributionUrl is not valid, must end with *-bin.zip, but found $distributionUrl"
|
||||||
|
}
|
||||||
|
|
||||||
|
# prepare tmp dir
|
||||||
|
$TMP_DOWNLOAD_DIR_HOLDER = New-TemporaryFile
|
||||||
|
$TMP_DOWNLOAD_DIR = New-Item -Itemtype Directory -Path "$TMP_DOWNLOAD_DIR_HOLDER.dir"
|
||||||
|
$TMP_DOWNLOAD_DIR_HOLDER.Delete() | Out-Null
|
||||||
|
trap {
|
||||||
|
if ($TMP_DOWNLOAD_DIR.Exists) {
|
||||||
|
try { Remove-Item $TMP_DOWNLOAD_DIR -Recurse -Force | Out-Null }
|
||||||
|
catch { Write-Warning "Cannot remove $TMP_DOWNLOAD_DIR" }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
New-Item -Itemtype Directory -Path "$MAVEN_HOME_PARENT" -Force | Out-Null
|
||||||
|
|
||||||
|
# Download and Install Apache Maven
|
||||||
|
Write-Verbose "Couldn't find MAVEN_HOME, downloading and installing it ..."
|
||||||
|
Write-Verbose "Downloading from: $distributionUrl"
|
||||||
|
Write-Verbose "Downloading to: $TMP_DOWNLOAD_DIR/$distributionUrlName"
|
||||||
|
|
||||||
|
$webclient = New-Object System.Net.WebClient
|
||||||
|
if ($env:MVNW_USERNAME -and $env:MVNW_PASSWORD) {
|
||||||
|
$webclient.Credentials = New-Object System.Net.NetworkCredential($env:MVNW_USERNAME, $env:MVNW_PASSWORD)
|
||||||
|
}
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
|
||||||
|
$webclient.DownloadFile($distributionUrl, "$TMP_DOWNLOAD_DIR/$distributionUrlName") | Out-Null
|
||||||
|
|
||||||
|
# If specified, validate the SHA-256 sum of the Maven distribution zip file
|
||||||
|
$distributionSha256Sum = (Get-Content -Raw "$scriptDir/.mvn/wrapper/maven-wrapper.properties" | ConvertFrom-StringData).distributionSha256Sum
|
||||||
|
if ($distributionSha256Sum) {
|
||||||
|
if ($USE_MVND) {
|
||||||
|
Write-Error "Checksum validation is not supported for maven-mvnd. `nPlease disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties."
|
||||||
|
}
|
||||||
|
Import-Module $PSHOME\Modules\Microsoft.PowerShell.Utility -Function Get-FileHash
|
||||||
|
if ((Get-FileHash "$TMP_DOWNLOAD_DIR/$distributionUrlName" -Algorithm SHA256).Hash.ToLower() -ne $distributionSha256Sum) {
|
||||||
|
Write-Error "Error: Failed to validate Maven distribution SHA-256, your Maven distribution might be compromised. If you updated your Maven version, you need to update the specified distributionSha256Sum property."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# unzip and move
|
||||||
|
Expand-Archive "$TMP_DOWNLOAD_DIR/$distributionUrlName" -DestinationPath "$TMP_DOWNLOAD_DIR" | Out-Null
|
||||||
|
Rename-Item -Path "$TMP_DOWNLOAD_DIR/$distributionUrlNameMain" -NewName $MAVEN_HOME_NAME | Out-Null
|
||||||
|
try {
|
||||||
|
Move-Item -Path "$TMP_DOWNLOAD_DIR/$MAVEN_HOME_NAME" -Destination $MAVEN_HOME_PARENT | Out-Null
|
||||||
|
} catch {
|
||||||
|
if (! (Test-Path -Path "$MAVEN_HOME" -PathType Container)) {
|
||||||
|
Write-Error "fail to move MAVEN_HOME"
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
try { Remove-Item $TMP_DOWNLOAD_DIR -Recurse -Force | Out-Null }
|
||||||
|
catch { Write-Warning "Cannot remove $TMP_DOWNLOAD_DIR" }
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Output "MVN_CMD=$MAVEN_HOME/bin/$MVN_CMD"
|
||||||
39
org_ccalm_dbms.properties
Normal file
39
org_ccalm_dbms.properties
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
spring.application.name=dbms
|
||||||
|
server.port=8084
|
||||||
|
|
||||||
|
issuer.name=geovizor
|
||||||
|
|
||||||
|
logging.level.com.zaxxer.hikari=DEBUG
|
||||||
|
|
||||||
|
spring.datasource.url=jdbc:postgresql://91.201.214.156:5432/CCALM
|
||||||
|
spring.datasource.username=postgres
|
||||||
|
spring.datasource.password=PasSecrKey1
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
spring.datasource.hikari.maximum-pool-size=10
|
||||||
|
spring.datasource.hikari.minimum-idle=5
|
||||||
|
spring.datasource.hikari.max-lifetime=1700000
|
||||||
|
spring.datasource.hikari.idle-timeout=600000
|
||||||
|
spring.datasource.hikari.connection-timeout=30000
|
||||||
|
spring.datasource.hikari.connection-test-query=SELECT now()
|
||||||
|
spring.datasource.hikari.validation-timeout=60000
|
||||||
|
|
||||||
|
|
||||||
|
public.key=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAzYLWgn7uUJYVn1PGyQKKC6F/m6PwEbL6FlCX+TaHZBjor83uS6rbuXquqbU/oFSiviBLI6Zg7BTzAhNglu8S2X4G7a1pkz3fn4kW9mf3zLnXnaNeuh+VhIEt/kw1ire1pCwP95KryKnQaLbi+ARDcGY+giIxjXRtNUTbAmgwP78U5M8fZ48+pH4AHWv/sG3TiTcIzUYCG/QMnnUE+Tir6kV3qrs66zig/cK5tTuJ7/JQOlhYOWBDElu0+lkSHgK2bEK9Wh7+qpIruO2K3gKX3RSFh8XfUIpwPVqyz2HVlzja+/scr6kuDB0iYfWZgrzLHPx3Bd0RyYBMIIgvBOoYmQIDAQAB
|
||||||
|
captcha.key=PPExpv36jk4Vzda3NpYnXLfuHCLYXqaNrxlOH/Jr/1M=
|
||||||
|
access.time=600
|
||||||
|
refresh.time=43200
|
||||||
|
captcha.time=600
|
||||||
|
|
||||||
|
mail.host=smtp.yandex.ru
|
||||||
|
mail.port=465
|
||||||
|
mail.loginModel=info@ccalm.org
|
||||||
|
mail.password=fu2lpsoGPGiq1xlRm8ag
|
||||||
|
|
||||||
|
url.reset=http://127.0.0.1:8088/reset
|
||||||
|
url.main=http://127.0.0.1:8088/
|
||||||
|
|
||||||
|
spring.redis.host=127.0.0.1
|
||||||
|
spring.redis.port=6379
|
||||||
|
spring.redis.password=9F3/NKWeOjd815vkadT2DcgVHf6fEpVQXw==
|
||||||
|
|
||||||
128
pom.xml
Normal file
128
pom.xml
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
<?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>3.3.3</version>
|
||||||
|
<relativePath/> <!-- lookup parent from repository -->
|
||||||
|
</parent>
|
||||||
|
<groupId>org.ccalm</groupId>
|
||||||
|
<artifactId>dbms</artifactId>
|
||||||
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
|
<name>dbms</name>
|
||||||
|
<description>Database management system</description>
|
||||||
|
<url/>
|
||||||
|
<licenses>
|
||||||
|
<license/>
|
||||||
|
</licenses>
|
||||||
|
<developers>
|
||||||
|
<developer/>
|
||||||
|
</developers>
|
||||||
|
<scm>
|
||||||
|
<connection/>
|
||||||
|
<developerConnection/>
|
||||||
|
<tag/>
|
||||||
|
<url/>
|
||||||
|
</scm>
|
||||||
|
<properties>
|
||||||
|
<java.version>21</java.version>
|
||||||
|
</properties>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-web</artifactId>
|
||||||
|
<version>3.3.3</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-data-redis</artifactId>
|
||||||
|
<version>3.3.3</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
|
<version>3.3.3</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-jdbc</artifactId>
|
||||||
|
<version>3.3.3</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.postgresql</groupId>
|
||||||
|
<artifactId>postgresql</artifactId>
|
||||||
|
<version>42.7.4</version>
|
||||||
|
<scope>runtime</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.json</groupId>
|
||||||
|
<artifactId>json</artifactId>
|
||||||
|
<version>20231013</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>javax.mail</groupId>
|
||||||
|
<artifactId>mail</artifactId>
|
||||||
|
<version>1.4</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework</groupId>
|
||||||
|
<artifactId>spring-jdbc</artifactId>
|
||||||
|
<version>6.1.12</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.xerial</groupId>
|
||||||
|
<artifactId>sqlite-jdbc</artifactId>
|
||||||
|
<version>3.36.0.1</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.zaxxer</groupId>
|
||||||
|
<artifactId>HikariCP</artifactId>
|
||||||
|
<version>5.0.1</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.jsonwebtoken</groupId>
|
||||||
|
<artifactId>jjwt-api</artifactId>
|
||||||
|
<version>0.11.2</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.jsonwebtoken</groupId>
|
||||||
|
<artifactId>jjwt-impl</artifactId>
|
||||||
|
<version>0.11.2</version>
|
||||||
|
<scope>runtime</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>io.jsonwebtoken</groupId>
|
||||||
|
<artifactId>jjwt-jackson</artifactId>
|
||||||
|
<version>0.11.2</version>
|
||||||
|
<scope>runtime</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>commons-io</groupId>
|
||||||
|
<artifactId>commons-io</artifactId>
|
||||||
|
<version>2.16.1</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<version>2.22.2</version>
|
||||||
|
<configuration>
|
||||||
|
<systemPropertyVariables>
|
||||||
|
<spring.config.location>file:kz_mcp_dbms.properties</spring.config.location>
|
||||||
|
</systemPropertyVariables>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
|
||||||
|
</project>
|
||||||
2342
src/main/java/dbms/DBMSRecords.java
Normal file
2342
src/main/java/dbms/DBMSRecords.java
Normal file
File diff suppressed because it is too large
Load Diff
443
src/main/java/dbms/DBMSTree.java
Normal file
443
src/main/java/dbms/DBMSTree.java
Normal file
@ -0,0 +1,443 @@
|
|||||||
|
package dbms;
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.DriverManager;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Statement;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
//import javax.servlet.ServletContext;
|
||||||
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.xpath.XPath;
|
||||||
|
import javax.xml.xpath.XPathConstants;
|
||||||
|
import javax.xml.xpath.XPathExpression;
|
||||||
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
|
import javax.xml.xpath.XPathFactory;
|
||||||
|
|
||||||
|
import jakarta.servlet.ServletContext;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.core.io.ClassPathResource;
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import org.springframework.web.bind.annotation.ModelAttribute;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
import org.springframework.web.bind.annotation.ResponseBody;
|
||||||
|
import org.springframework.web.bind.annotation.SessionAttributes;
|
||||||
|
import org.springframework.web.context.ServletContextAware;
|
||||||
|
import org.w3c.dom.DOMException;
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.w3c.dom.Element;
|
||||||
|
import org.w3c.dom.Node;
|
||||||
|
import org.w3c.dom.NodeList;
|
||||||
|
|
||||||
|
import tctable.Tools;
|
||||||
|
import tools.DBTools;
|
||||||
|
import tools.XMLTools;
|
||||||
|
import tools.User;
|
||||||
|
|
||||||
|
|
||||||
|
@Controller
|
||||||
|
public class DBMSTree implements ServletContextAware {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(DBMSTree.class);
|
||||||
|
private ServletContext context;
|
||||||
|
|
||||||
|
@RequestMapping(value = "/tree",method = RequestMethod.POST,produces = "application/xml; charset=utf-8")
|
||||||
|
@ResponseBody
|
||||||
|
public Object ajaxTamer(@ModelAttribute User user,@RequestBody byte[] reqData,@RequestParam(required=false,name="lng") String language_id) {
|
||||||
|
|
||||||
|
if(language_id!=null && !language_id.equals(""))
|
||||||
|
user.language_id=language_id;
|
||||||
|
|
||||||
|
logger.info("user.id="+user.id+" user.name="+user.name+" user.language_id="+user.language_id+" user.country_id="+user.country_id);
|
||||||
|
|
||||||
|
boolean error=false;
|
||||||
|
String result="<metadata fn=\"-1\"><![CDATA[Request not processed!]]></metadata>";
|
||||||
|
|
||||||
|
String jspPath = context.getRealPath("/");
|
||||||
|
String db_url="";
|
||||||
|
String db_login="";
|
||||||
|
String db_password="";
|
||||||
|
Properties prop = new Properties();
|
||||||
|
try {
|
||||||
|
prop.load(new FileInputStream("application.properties")); // load a properties file
|
||||||
|
db_url = prop.getProperty("spring.datasource.url");
|
||||||
|
db_login = prop.getProperty("spring.datasource.username");
|
||||||
|
db_password = prop.getProperty("spring.datasource.password");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
logger.error("Error load application.properties",e);
|
||||||
|
}
|
||||||
|
|
||||||
|
Connection conn = null;
|
||||||
|
try {
|
||||||
|
Class.forName("org.postgresql.Driver");
|
||||||
|
conn = DriverManager.getConnection(db_url, db_login, db_password);
|
||||||
|
if (conn != null) {
|
||||||
|
logger.info("Connect is OK!");
|
||||||
|
} else {
|
||||||
|
error=true;
|
||||||
|
result="<metadata fn=\"-1\"><![CDATA[An error occurred while connecting to the database!]]></metadata>";
|
||||||
|
}
|
||||||
|
} catch (Exception ex) {
|
||||||
|
logger.info(ex.getMessage());
|
||||||
|
error=true;
|
||||||
|
result="<metadata fn=\"-1\"><![CDATA[An error occurred while connecting to the database!]]></metadata>";
|
||||||
|
}
|
||||||
|
|
||||||
|
String fn="";
|
||||||
|
String treeid="";
|
||||||
|
String htmlid="";
|
||||||
|
|
||||||
|
//Парсим принятый XML запрос
|
||||||
|
InputStream body = new ByteArrayInputStream(reqData);
|
||||||
|
Document doc = null;
|
||||||
|
Element reqNode = null;
|
||||||
|
try {
|
||||||
|
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
|
||||||
|
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
|
||||||
|
doc = dBuilder.parse(body);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
logger.info(ex.getMessage());
|
||||||
|
return "<metadata fn=\"-1\"><![CDATA[Parsing request error!]]></metadata>";
|
||||||
|
}
|
||||||
|
if (doc != null) {
|
||||||
|
reqNode = doc.getDocumentElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//Парсим XML из файла
|
||||||
|
Document objXMLDocument = null;
|
||||||
|
try {
|
||||||
|
File inputFile = new File(jspPath+"resources"+File.separator+"engine/tree.xml");
|
||||||
|
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
|
||||||
|
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
|
||||||
|
objXMLDocument = dBuilder.parse(inputFile);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
logger.info(ex.getMessage());
|
||||||
|
error=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Node mainNode=null;
|
||||||
|
//находим нужный узел в tree.xml для того чтобы выполнить запрос
|
||||||
|
XPathFactory xPathfactory = XPathFactory.newInstance();
|
||||||
|
XPath xpath = xPathfactory.newXPath();
|
||||||
|
|
||||||
|
if (doc != null) {
|
||||||
|
Object exprResult=null;
|
||||||
|
try {
|
||||||
|
XPathExpression expr = xpath.compile("//metadata/type[@id='" + treeid + "']");
|
||||||
|
exprResult = expr.evaluate(doc, XPathConstants.NODESET);
|
||||||
|
} catch (XPathExpressionException ex) {
|
||||||
|
logger.info(ex.getMessage());
|
||||||
|
}
|
||||||
|
NodeList nodeList = (NodeList) exprResult;
|
||||||
|
|
||||||
|
if (nodeList.getLength() > 0)
|
||||||
|
mainNode = nodeList.item(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
String retrez="";
|
||||||
|
if(mainNode!=null)
|
||||||
|
{
|
||||||
|
//перебераем все дочерние элементы и для каждого выполняем запрос c фильтрацией
|
||||||
|
Node currNode = mainNode.getFirstChild(); //из tree.xml
|
||||||
|
while (currNode != null)
|
||||||
|
{
|
||||||
|
|
||||||
|
Node tmpNode=currNode; //если узел goto
|
||||||
|
|
||||||
|
if (tmpNode.getNodeName().equals("goto")) //если встретилась "зацикливалка"
|
||||||
|
{
|
||||||
|
treeid = tmpNode.getAttributes().getNamedItem("id").getNodeValue();
|
||||||
|
tmpNode=XMLTools.findFirstNodeOnAttribute(objXMLDocument.getDocumentElement(),"type","id",treeid);
|
||||||
|
if(tmpNode==null) { currNode = currNode.getNextSibling(); continue; }
|
||||||
|
}
|
||||||
|
|
||||||
|
if(tmpNode.getNodeName().equals("type")) //если выборка из базы
|
||||||
|
{
|
||||||
|
treeid=tmpNode.getAttributes().getNamedItem("id").getNodeValue();
|
||||||
|
String caption=tmpNode.getAttributes().getNamedItem("c").getNodeValue();
|
||||||
|
|
||||||
|
//j=0;
|
||||||
|
XMLTools.applyNodeToNode(reqNode,tmpNode,"n");
|
||||||
|
|
||||||
|
//Переносим значения в SQL запрос из фильтра
|
||||||
|
String sql=XMLTools.getCDATAValue(XMLTools.findNode(tmpNode,"sql-query"));
|
||||||
|
Node nFs=XMLTools.findNode(tmpNode, "filter");
|
||||||
|
if(nFs!=null)
|
||||||
|
{
|
||||||
|
Node nF=nFs.getFirstChild();
|
||||||
|
while(nF != null)
|
||||||
|
{
|
||||||
|
if(nF.getNodeName().equals("column"))
|
||||||
|
{
|
||||||
|
String vt = nF.getAttributes().getNamedItem("vt").getNodeValue();
|
||||||
|
String val= XMLTools.getCDATAValue(nF);
|
||||||
|
sql = sql.replace("${" + nF.getAttributes().getNamedItem("n").getNodeValue() + "}", DBTools.getSQLValue(vt, val));
|
||||||
|
}
|
||||||
|
nF=nF.getNextSibling();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Выполняем подготовленный SQL
|
||||||
|
Statement stmt;
|
||||||
|
ResultSet rs=null;
|
||||||
|
try {
|
||||||
|
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
|
||||||
|
rs = stmt.executeQuery(sql);
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//res=fnGetData(reqNode,tmpNode);//currNode из tree.xml
|
||||||
|
if(rs==null)
|
||||||
|
{
|
||||||
|
//sendError('fnGetData==null!');
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
while (rs.next()) //while (row = res->fetch(PDO::FETCH_ASSOC))
|
||||||
|
{
|
||||||
|
String fid="";
|
||||||
|
String iid="";
|
||||||
|
String val="";
|
||||||
|
|
||||||
|
if(DBTools.hasColumn(rs,"id")) fid=rs.getString("id"); else fid=""; //Уникальный id записи
|
||||||
|
if(DBTools.hasColumn(rs,"icon_id")) iid=rs.getString("icon_id"); else iid=""; //id значка
|
||||||
|
if(DBTools.hasColumn(rs,caption)) val=rs.getString(caption); else val=""; //Заголовок
|
||||||
|
|
||||||
|
String visible = "";
|
||||||
|
if(tmpNode.getAttributes().getNamedItem("visible").getNodeValue().equals("0")) visible=" visible=\"0\" ";
|
||||||
|
//Для проверки есть ли дети составляем XML запрос и отправляем в вункцию как будто он пришел от клиента
|
||||||
|
//c - Есть ли под узлы по умолчанию есть
|
||||||
|
//fid - id записи
|
||||||
|
//iid - id иконки
|
||||||
|
//treeid - id ветки дерева
|
||||||
|
//ObjectID - название поля с уникальным идентификатором записи
|
||||||
|
String xmlnode = "<?xml version=\"1.0\" encoding=\"utf-8\"?>";
|
||||||
|
xmlnode+="<tree c=\"1\" fid=\""+fid+"\" iid=\""+iid+"\" treeid=\""+treeid+"\" t=\""+tmpNode.getAttributes().getNamedItem("n").getNodeValue()+"\" ObjectID=\""+tmpNode.getAttributes().getNamedItem("ObjectID").getNodeValue()+"\""+visible+">";
|
||||||
|
xmlnode+="<![CDATA["+val+"]]>";
|
||||||
|
//сохраняем параметры фильтра для дочерних элементов с текщем состоянием
|
||||||
|
//перебираем фильтры которые должны быть заполненны для каждого узла даные для фильтра беруться из результ сета
|
||||||
|
xmlnode+="<columns>";
|
||||||
|
|
||||||
|
//считываем название поля и находим данные в результсете
|
||||||
|
Node nodeParam = XMLTools.findFirstNode(tmpNode, "columns"); //tree.xml
|
||||||
|
if(nodeParam!=null) nodeParam=nodeParam.getFirstChild();
|
||||||
|
while (nodeParam != null)
|
||||||
|
{
|
||||||
|
if(nodeParam.getNodeName().equals("param"))
|
||||||
|
{
|
||||||
|
String fname = nodeParam.getAttributes().getNamedItem("n").getNodeValue();
|
||||||
|
String fval="";
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if(DBTools.hasColumn(rs,fname))
|
||||||
|
{
|
||||||
|
fval=rs.getString(fname);
|
||||||
|
}else
|
||||||
|
{ fval=XMLTools.getCDATAValue(nodeParam);
|
||||||
|
}
|
||||||
|
} catch (Exception e)
|
||||||
|
{
|
||||||
|
//sendError(e->getMessage());
|
||||||
|
}
|
||||||
|
xmlnode+="<param n=\""+fname+"\"><![CDATA["+fval+"]]></param>";
|
||||||
|
}
|
||||||
|
nodeParam = nodeParam.getNextSibling();
|
||||||
|
}
|
||||||
|
xmlnode+="</columns>";
|
||||||
|
xmlnode+="</tree>";
|
||||||
|
|
||||||
|
//парсим созданную ветку дерева в DOMDocument потом посылаем в функцию взятия данных как будто их все открыли
|
||||||
|
//если есть данные то у этого узла дерева есть дети c="1" инече нет c="0".
|
||||||
|
int child = 0;
|
||||||
|
Document objXMLDocTree=null;
|
||||||
|
try
|
||||||
|
{ //objXMLDocTree->loadXML(xmlnode);
|
||||||
|
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
|
||||||
|
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
|
||||||
|
objXMLDocument = dBuilder.parse(xmlnode);
|
||||||
|
} catch (Exception e)
|
||||||
|
{ //sendError(e->getMessage());
|
||||||
|
}
|
||||||
|
Element testNodeTree = objXMLDocTree.getDocumentElement();
|
||||||
|
|
||||||
|
Node testNode = tmpNode.getFirstChild(); //Текущий узел из tree.xml
|
||||||
|
while (testNode != null)
|
||||||
|
{
|
||||||
|
Node tmpNode2 = testNode;
|
||||||
|
if(tmpNode2.getNodeName().equals("goto"))
|
||||||
|
{
|
||||||
|
treeid=tmpNode2.getAttributes().getNamedItem("id").getNodeValue();
|
||||||
|
tmpNode2=XMLTools.findFirstNodeOnAttribute(objXMLDocument.getDocumentElement(),"type","id",treeid);
|
||||||
|
if(tmpNode2==null) { testNode = testNode.getNextSibling(); continue; }
|
||||||
|
}
|
||||||
|
if(tmpNode2.getNodeName().equals("type"))
|
||||||
|
{
|
||||||
|
/*Object testrs = fnGetData(conn,testNodeTree,tmpNode2);
|
||||||
|
if((testrs!=null)&&(testrs.rowCount()>0))
|
||||||
|
{
|
||||||
|
child=1;
|
||||||
|
break;
|
||||||
|
}*/
|
||||||
|
}
|
||||||
|
testNode = testNode.getNextSibling();
|
||||||
|
}
|
||||||
|
//testNodeTree.getAttribute("c",child);
|
||||||
|
|
||||||
|
//retrez+=objXMLDocTree->saveXML(objXMLDocTree.getDocumentElement());
|
||||||
|
//Закончили проверку на детей
|
||||||
|
|
||||||
|
}
|
||||||
|
} catch (DOMException | SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
rs.close();
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
currNode = currNode.getNextSibling();
|
||||||
|
}
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
result="<metadata fn=\"-1\"><![CDATA[Not find find id=\""+treeid+"\"!]]></metadata>";
|
||||||
|
}
|
||||||
|
|
||||||
|
result="<?xml version=\"1.0\" encoding=\"utf-8\"?><metadata fn=\"1\" htmlid=\""+htmlid+"\">"+retrez+"</metadata>";
|
||||||
|
//header('Content-type: text/xml');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
try {
|
||||||
|
conn.close();
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
//return body content
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Replace all the values of the first filter values from the second
|
||||||
|
public void setFilter(Node n1, Node n2) {
|
||||||
|
if (n1 == null || n2 == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
XPathFactory xPathfactory = XPathFactory.newInstance();
|
||||||
|
XPath xpath = xPathfactory.newXPath();
|
||||||
|
|
||||||
|
Node nc1 = n1.getFirstChild();
|
||||||
|
while (nc1 != null) {
|
||||||
|
if (nc1.getNodeName().equals("column")) {
|
||||||
|
try {
|
||||||
|
String path = "column[@n='" + nc1.getAttributes().getNamedItem("n").getNodeValue() + "']";
|
||||||
|
XPathExpression expr = xpath.compile(path);
|
||||||
|
NodeList nodeList = (NodeList) expr.evaluate(n2, XPathConstants.NODESET);
|
||||||
|
if (nodeList.getLength() > 0) {
|
||||||
|
Node nc2 = nodeList.item(0);
|
||||||
|
|
||||||
|
XMLTools.setCharacterDataToElement((Element) nc1, XMLTools.getCharacterDataFromElement((Element) nc2));
|
||||||
|
|
||||||
|
//getCdata($nc1)->nodeValue=getCdata($nc2)->nodeValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (Exception ex) {
|
||||||
|
System.out.println(ex.getMessage());
|
||||||
|
//String message = "XML parsing error!";
|
||||||
|
//return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
nc1 = nc1.getNextSibling();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public ResultSet fnGetData(Connection conn,Node treeNode,Node currNode)
|
||||||
|
{
|
||||||
|
String sql=getSQL(treeNode,currNode);
|
||||||
|
|
||||||
|
/*if(gettype($_SESSION['USER_ID'])=='string')
|
||||||
|
sql=str_replace('${_user_id}',$_SESSION['USER_ID']=='' ? 'null' : '\''.$_SESSION['USER_ID'].'\'',$sql);
|
||||||
|
else
|
||||||
|
sql=str_replace('${_user_id}',$_SESSION['USER_ID']=='' ? 'null' : $_SESSION['USER_ID'],$sql);*/
|
||||||
|
|
||||||
|
Statement stmt;
|
||||||
|
ResultSet rs=null;
|
||||||
|
try {
|
||||||
|
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
|
||||||
|
rs = stmt.executeQuery(sql);
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return rs;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Перенести параметры из родительского в sql строку дочернего элемента
|
||||||
|
* @param XMLNode $nParent Родительский узел
|
||||||
|
* @param XMLNode $nChild Дочерний узел
|
||||||
|
* @result Строка
|
||||||
|
*/
|
||||||
|
public String getSQL(Node nParent,Node nChild)
|
||||||
|
{
|
||||||
|
if(nChild==null) return "";
|
||||||
|
String sql="";
|
||||||
|
|
||||||
|
Node nPs=XMLTools.findNode(nParent, "columns");
|
||||||
|
Node nFs=XMLTools.findNode(nChild, "filter");
|
||||||
|
//Переносим значения в фильтр
|
||||||
|
if(nFs!=null)
|
||||||
|
{
|
||||||
|
Node nP;
|
||||||
|
if(nPs!=null) nP=nPs.getFirstChild(); else nP=null;
|
||||||
|
while (nP != null)
|
||||||
|
{
|
||||||
|
if (nP.getNodeName().equals("param"))
|
||||||
|
{
|
||||||
|
String val=XMLTools.getCDATAValue(nP);
|
||||||
|
|
||||||
|
Node nF=XMLTools.findNodeOnAttribute(nFs, "column", "pn", nP.getAttributes().getNamedItem("n").getNodeValue());
|
||||||
|
if(nF!=null)
|
||||||
|
XMLTools.setCharacterDataToElement(nF, val);
|
||||||
|
}
|
||||||
|
nP = nP.getNextSibling();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Переносим значения в SQL запрос из фильтра
|
||||||
|
sql=XMLTools.getCDATAValue(XMLTools.findNode(nChild,"sql-query"));
|
||||||
|
nFs=XMLTools.findNode(nChild, "filter");
|
||||||
|
if(nFs!=null)
|
||||||
|
{ Node nF = nFs.getFirstChild();
|
||||||
|
while(nF != null)
|
||||||
|
{
|
||||||
|
if(nF.getNodeName().equals("column"))
|
||||||
|
{
|
||||||
|
sql = sql.replace("{"+nF.getAttributes().getNamedItem("n").getNodeValue()+"}", DBTools.getSQLValue(nF.getAttributes().getNamedItem("vt").getNodeValue(),XMLTools.getCDATAValue(nF)));
|
||||||
|
}
|
||||||
|
nF=nF.getNextSibling();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return sql;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setServletContext(ServletContext servletContext) {
|
||||||
|
this.context=servletContext;
|
||||||
|
}
|
||||||
|
}
|
||||||
13
src/main/java/org/ccalm/dbms/DbmsApplication.java
Normal file
13
src/main/java/org/ccalm/dbms/DbmsApplication.java
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
package org.ccalm.dbms;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
|
||||||
|
@SpringBootApplication(scanBasePackages = {"org.ccalm.dbms", "dbms"})
|
||||||
|
public class DbmsApplication {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(DbmsApplication.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
38
src/main/java/org/ccalm/dbms/MainController.java
Normal file
38
src/main/java/org/ccalm/dbms/MainController.java
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
package org.ccalm.dbms;
|
||||||
|
|
||||||
|
import com.zaxxer.hikari.HikariDataSource;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import org.springframework.ui.Model;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
import org.springframework.web.bind.annotation.ResponseBody;
|
||||||
|
|
||||||
|
@Controller
|
||||||
|
public class MainController {
|
||||||
|
|
||||||
|
private HikariDataSource dataSource;
|
||||||
|
|
||||||
|
@Value("${spring.application.name}")
|
||||||
|
String application_name="";
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public void DatabaseService(HikariDataSource dataSource) {
|
||||||
|
this.dataSource = dataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(value = "/",method = {RequestMethod.POST,RequestMethod.GET},produces = "application/json;charset=utf-8")
|
||||||
|
@ResponseBody
|
||||||
|
public String index(Model model, @RequestParam(required=false,name="lng",defaultValue = "1") String language_id) {
|
||||||
|
JSONObject json = new JSONObject();
|
||||||
|
json.put("error_code",0);
|
||||||
|
json.put("error_message","Application name: "+application_name);
|
||||||
|
//json.put("active_connections",dataSource.getHikariPoolMXBean().getActiveConnections());
|
||||||
|
//json.put("idle_connections",dataSource.getHikariPoolMXBean().getIdleConnections());
|
||||||
|
return json.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
89
src/main/java/tools/DBTools.java
Normal file
89
src/main/java/tools/DBTools.java
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
package tools;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
import org.springframework.jdbc.core.RowMapper;
|
||||||
|
import tctable.Tools;
|
||||||
|
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.ResultSetMetaData;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class DBTools {
|
||||||
|
|
||||||
|
public static class JsonRowMapper implements RowMapper<String> {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String mapRow(ResultSet rs, int rowNum) throws SQLException {
|
||||||
|
ObjectMapper objectMapper = new ObjectMapper();
|
||||||
|
Map<String, Object> resultMap = new HashMap<>();
|
||||||
|
|
||||||
|
// Получаем метаданные ResultSet для получения названий столбцов
|
||||||
|
int columnCount = rs.getMetaData().getColumnCount();
|
||||||
|
for (int i = 1; i <= columnCount; i++) {
|
||||||
|
String columnName = rs.getMetaData().getColumnName(i);
|
||||||
|
Object columnValue = rs.getObject(i);
|
||||||
|
resultMap.put(columnName, columnValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Преобразовываем Map в JSON строку
|
||||||
|
try {
|
||||||
|
return objectMapper.writeValueAsString(resultMap);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException("Failed to convert Map to JSON", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean hasColumn(ResultSet rs, String columnName) throws SQLException {
|
||||||
|
ResultSetMetaData metaData = rs.getMetaData();
|
||||||
|
int columnCount = metaData.getColumnCount();
|
||||||
|
|
||||||
|
for (int i = 1; i <= columnCount; i++) {
|
||||||
|
if (columnName.equalsIgnoreCase(metaData.getColumnName(i))) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getSQLValue(String t, String v) {
|
||||||
|
//if($t=='object' && (strtoupper($v)!='NULL' && gettype($v)=='string')) $t='string'; //Если id шники uuid
|
||||||
|
|
||||||
|
if (t.equals("object") || t.equals("uid")) {
|
||||||
|
if (v.equals(""))
|
||||||
|
v = "NULL";
|
||||||
|
} else if (t.equals("i4") || t.equals("integer")) {
|
||||||
|
if (v.equals(""))
|
||||||
|
v = "NULL";
|
||||||
|
} else if (t.equals("f8")) {
|
||||||
|
if (v.equals(""))
|
||||||
|
v = "NULL";
|
||||||
|
v = Tools.replaceAll(v,",", "."); //The decimal part: point.
|
||||||
|
} else if (t.equals("f4")) {
|
||||||
|
if (v.equals(""))
|
||||||
|
v = "NULL";
|
||||||
|
v = Tools.replaceAll(v,",", "."); //The decimal part: point.
|
||||||
|
} else if (t.equals("b")) {
|
||||||
|
if (v.equals(""))
|
||||||
|
v = "NULL";
|
||||||
|
else if (v.equals("1"))
|
||||||
|
v = "true";
|
||||||
|
else if (v.equals("0"))
|
||||||
|
v = "false";
|
||||||
|
} else if (t.equals("string") || t.equals("text") || t.equals("dateTime") || t.equals("date")) {
|
||||||
|
if (v.equals("")) {
|
||||||
|
v = "NULL";
|
||||||
|
} else {
|
||||||
|
v = Tools.replaceAll(v,"'", "''");
|
||||||
|
v = "'" + v + "'";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
v = "'" + v + "'";
|
||||||
|
}
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
65
src/main/java/tools/EmailUtility.java
Normal file
65
src/main/java/tools/EmailUtility.java
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
//From: http://www.codejava.net/java-ee/jsp/sending-e-mail-with-jsp-servlet-and-javamail
|
||||||
|
package tools;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import javax.mail.Authenticator;
|
||||||
|
import javax.mail.Message;
|
||||||
|
import javax.mail.MessagingException;
|
||||||
|
import javax.mail.PasswordAuthentication;
|
||||||
|
import javax.mail.Session;
|
||||||
|
import javax.mail.Transport;
|
||||||
|
import javax.mail.internet.AddressException;
|
||||||
|
import javax.mail.internet.InternetAddress;
|
||||||
|
import javax.mail.internet.MimeMessage;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A utility class for sending e-mail messages
|
||||||
|
* @author www.codejava.net
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class EmailUtility {
|
||||||
|
|
||||||
|
public static void sendEmail(String host, String port,
|
||||||
|
final String userName, final String password, String toAddress,
|
||||||
|
String subject, String message) throws AddressException,
|
||||||
|
MessagingException
|
||||||
|
{
|
||||||
|
// sets SMTP server properties
|
||||||
|
Properties properties = new Properties();
|
||||||
|
|
||||||
|
properties.put("mail.smtp.host", host);
|
||||||
|
properties.put("mail.smtp.port", port);
|
||||||
|
properties.put("mail.smtp.auth", "true");
|
||||||
|
//properties.put("mail.smtp.starttls.enable","true"); STARTTLS requested but already using SSL
|
||||||
|
properties.put("mail.smtp.EnableSSL.enable","true");
|
||||||
|
properties.put("mail.smtp.socketFactory.port", port);
|
||||||
|
properties.put("mail.smtp.socketFactory.class","javax.net.ssl.SSLSocketFactory");
|
||||||
|
//properties.put("mail.debug", "true");
|
||||||
|
|
||||||
|
|
||||||
|
// creates a new session with an authenticator
|
||||||
|
Authenticator auth = new Authenticator() {
|
||||||
|
public PasswordAuthentication getPasswordAuthentication() {
|
||||||
|
return new PasswordAuthentication(userName, password);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Session session = Session.getInstance(properties, auth);
|
||||||
|
|
||||||
|
//creates a new e-mail message
|
||||||
|
Message msg = new MimeMessage(session);
|
||||||
|
|
||||||
|
msg.setFrom(new InternetAddress(userName));
|
||||||
|
InternetAddress[] toAddresses = { new InternetAddress(toAddress) };
|
||||||
|
msg.setRecipients(Message.RecipientType.TO, toAddresses);
|
||||||
|
msg.setSubject(subject);
|
||||||
|
msg.setSentDate(new Date());
|
||||||
|
//msg.setText(message);
|
||||||
|
msg.setContent(message, "text/html; charset=utf-8");
|
||||||
|
|
||||||
|
// sends the e-mail
|
||||||
|
Transport.send(msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
218
src/main/java/tools/PreparedStatementNamed.java
Normal file
218
src/main/java/tools/PreparedStatementNamed.java
Normal file
@ -0,0 +1,218 @@
|
|||||||
|
package tools;
|
||||||
|
|
||||||
|
//import org.ccalm.main.AcceptASDCController;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Types;
|
||||||
|
import java.text.DateFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class PreparedStatementNamed {
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(PreparedStatementNamed.class);
|
||||||
|
|
||||||
|
private class HMap{
|
||||||
|
public String name = "";
|
||||||
|
public int pos = -1;
|
||||||
|
public HMap(String name,int pos) {
|
||||||
|
this.name = name;
|
||||||
|
this.pos = pos;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private List< HMap > fields = new ArrayList< HMap >();
|
||||||
|
private PreparedStatement m_prepStmt;
|
||||||
|
|
||||||
|
public PreparedStatementNamed(Connection conn, String sql) throws SQLException {
|
||||||
|
int cnt=0;
|
||||||
|
int pos = 0;
|
||||||
|
while((pos = sql.indexOf("${")) != -1) {
|
||||||
|
int end = sql.substring(pos).indexOf("}");
|
||||||
|
if (end == -1)
|
||||||
|
end = sql.length();
|
||||||
|
else
|
||||||
|
end += pos+1;
|
||||||
|
cnt++;
|
||||||
|
fields.add(new HMap(sql.substring(pos+2,end-1),cnt));
|
||||||
|
sql = sql.substring(0, pos) + "?" + sql.substring(end); //Removing a parameter from a string
|
||||||
|
}
|
||||||
|
m_prepStmt = conn.prepareStatement(sql);
|
||||||
|
}
|
||||||
|
public void setString(String name, String value) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setString(fields.get(i).pos, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setNULLString(String name) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setNull(fields.get(i).pos,Types.NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setInt(String name, String value) throws SQLException {
|
||||||
|
if(value==null){
|
||||||
|
setNULLInt(name);
|
||||||
|
}else {
|
||||||
|
for (int i = 0; i < fields.size(); i++) {
|
||||||
|
if (fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setInt(fields.get(i).pos, Integer.parseInt(value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setInt(String name, int value) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setInt(fields.get(i).pos, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setNULLInt(String name) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setNull(fields.get(i).pos,Types.INTEGER);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setBoolean(String name, String value) throws SQLException {
|
||||||
|
if(value==null){
|
||||||
|
setNULLBoolean(name);
|
||||||
|
}else {
|
||||||
|
for (int i = 0; i < fields.size(); i++) {
|
||||||
|
if (fields.get(i).name.equals(name)) {
|
||||||
|
if (value.equals("0") || value.equals("false") || value.equals(""))
|
||||||
|
m_prepStmt.setBoolean(fields.get(i).pos, false);
|
||||||
|
else
|
||||||
|
m_prepStmt.setBoolean(fields.get(i).pos, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setBoolean(String name, int value) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
if(value==0)
|
||||||
|
m_prepStmt.setBoolean(fields.get(i).pos, false);
|
||||||
|
else
|
||||||
|
m_prepStmt.setBoolean(fields.get(i).pos, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setNULLBoolean(String name) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setNull(fields.get(i).pos,Types.BOOLEAN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*private int getIndex(String name) {
|
||||||
|
size()
|
||||||
|
} */
|
||||||
|
public void setDouble(String name, String value) throws SQLException {
|
||||||
|
if(value==null){
|
||||||
|
setNULLDouble(name);
|
||||||
|
}else {
|
||||||
|
for (int i = 0; i < fields.size(); i++) {
|
||||||
|
if (fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setDouble(fields.get(i).pos, Double.parseDouble(value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setDouble(String name, double value) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setDouble(fields.get(i).pos, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setNULLDouble(String name) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setNull(fields.get(i).pos,Types.DOUBLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setFloat(String name, String value) throws SQLException {
|
||||||
|
if(value==null){
|
||||||
|
setNULLFloat(name);
|
||||||
|
}else {
|
||||||
|
for (int i = 0; i < fields.size(); i++) {
|
||||||
|
if (fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setDouble(fields.get(i).pos, Float.parseFloat(value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setFloat(String name, float value) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setFloat(fields.get(i).pos, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void setNULLFloat(String name) throws SQLException {
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setNull(fields.get(i).pos,Types.FLOAT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTimestamp(String name, String value) throws SQLException {
|
||||||
|
if(value==null){
|
||||||
|
for(int i=0;i<fields.size();i++) {
|
||||||
|
if(fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setNull(fields.get(i).pos,Types.DATE, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
if(value.matches("\\d+")) //If old date format in UNIX time
|
||||||
|
{
|
||||||
|
long uDate=Long.parseLong(value)+1;
|
||||||
|
java.sql.Timestamp tm=new java.sql.Timestamp(uDate*1000);
|
||||||
|
for (int i = 0; i < fields.size(); i++) {
|
||||||
|
if (fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setTimestamp(fields.get(i).pos, tm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
java.sql.Timestamp tm=null;
|
||||||
|
DateFormat dfm = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //2016-05-29 18:00:01 in "GMT"
|
||||||
|
try{
|
||||||
|
tm = new java.sql.Timestamp(dfm.parse(value).getTime());
|
||||||
|
} catch (Exception ex) {
|
||||||
|
logger.error("Error",ex.getMessage());
|
||||||
|
}
|
||||||
|
for (int i = 0; i < fields.size(); i++) {
|
||||||
|
if (fields.get(i).name.equals(name)) {
|
||||||
|
m_prepStmt.setTimestamp(fields.get(i).pos, tm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public PreparedStatement getPreparedStatement() {
|
||||||
|
return m_prepStmt;
|
||||||
|
}
|
||||||
|
/*public ResultSet executeQuery() throws SQLException {
|
||||||
|
return m_prepStmt.executeQuery();
|
||||||
|
}
|
||||||
|
public void close() throws SQLException {
|
||||||
|
m_prepStmt.close();
|
||||||
|
}*/
|
||||||
|
}
|
||||||
82
src/main/java/tools/Translation.java
Normal file
82
src/main/java/tools/Translation.java
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
package tools;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import java.sql.*;
|
||||||
|
|
||||||
|
public class Translation {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(Translation.class);
|
||||||
|
|
||||||
|
public int language_id;
|
||||||
|
//public NamedParameterJdbcTemplate jdbcTemplate;
|
||||||
|
public Connection conn;
|
||||||
|
public Translation(String lng, Connection conn){
|
||||||
|
language_id=1;
|
||||||
|
switch (lng) {
|
||||||
|
case "kz":
|
||||||
|
case "kk":
|
||||||
|
language_id = 2;
|
||||||
|
break;
|
||||||
|
case "en":
|
||||||
|
language_id = 3;
|
||||||
|
break;
|
||||||
|
case "uz":
|
||||||
|
language_id = 4;
|
||||||
|
break;
|
||||||
|
case "ru":
|
||||||
|
default:
|
||||||
|
language_id = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
this.conn = conn;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String trt(String text){
|
||||||
|
|
||||||
|
boolean find = false;
|
||||||
|
String sql = """
|
||||||
|
select
|
||||||
|
translation
|
||||||
|
from
|
||||||
|
main._translations
|
||||||
|
where
|
||||||
|
del=false
|
||||||
|
and language_id=${language_id}
|
||||||
|
and identifier=${identifier};
|
||||||
|
""";
|
||||||
|
|
||||||
|
PreparedStatementNamed stmtn=null;
|
||||||
|
try {
|
||||||
|
stmtn = new PreparedStatementNamed(conn, sql);
|
||||||
|
stmtn.setInt("language_id", language_id);
|
||||||
|
stmtn.setString("identifier", text);
|
||||||
|
} catch (SQLException e) {
|
||||||
|
logger.error("Error",e);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(stmtn!=null){
|
||||||
|
PreparedStatement stmt=stmtn.getPreparedStatement();
|
||||||
|
ResultSet rs = null;
|
||||||
|
try {
|
||||||
|
rs = stmt.executeQuery();
|
||||||
|
while (rs.next()) {
|
||||||
|
text = rs.getString(1);
|
||||||
|
find = true;
|
||||||
|
}
|
||||||
|
} catch (SQLException e) {
|
||||||
|
logger.error("Error",e);
|
||||||
|
e.printStackTrace();
|
||||||
|
}finally{
|
||||||
|
try { if (rs != null) rs.close(); } catch (Exception e) {};
|
||||||
|
try { if (stmt != null) stmt.close(); } catch (Exception e) {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!find){
|
||||||
|
text = text.replace("_", " ");
|
||||||
|
}
|
||||||
|
return text;
|
||||||
|
}
|
||||||
|
}
|
||||||
45
src/main/java/tools/User.java
Normal file
45
src/main/java/tools/User.java
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
package tools;
|
||||||
|
|
||||||
|
public class User {
|
||||||
|
|
||||||
|
public String id; //User id from database
|
||||||
|
public String name; //Name Surname Patronymic
|
||||||
|
public String language_id; //User language
|
||||||
|
public String role; //User role
|
||||||
|
public String country_id; //User role
|
||||||
|
|
||||||
|
public User()
|
||||||
|
{
|
||||||
|
id="null"; //null так как заменяю в SQL строке строку вида ${_user_id} на цифровое значение
|
||||||
|
name="___";
|
||||||
|
language_id="1";
|
||||||
|
role="___";
|
||||||
|
country_id="";
|
||||||
|
}
|
||||||
|
public User(String name)
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
id="null";
|
||||||
|
this.name=name;
|
||||||
|
language_id="1";
|
||||||
|
role="___";
|
||||||
|
country_id="";
|
||||||
|
}
|
||||||
|
public void setName(String name)
|
||||||
|
{
|
||||||
|
this.name=name;
|
||||||
|
}
|
||||||
|
public String getName()
|
||||||
|
{
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
public void Logout()
|
||||||
|
{
|
||||||
|
id="null";
|
||||||
|
name="___";
|
||||||
|
language_id="1";
|
||||||
|
role="___";
|
||||||
|
country_id="";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
189
src/main/java/tools/XMLTools.java
Normal file
189
src/main/java/tools/XMLTools.java
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
package tools;
|
||||||
|
|
||||||
|
import javax.xml.xpath.XPath;
|
||||||
|
import javax.xml.xpath.XPathExpression;
|
||||||
|
|
||||||
|
import org.w3c.dom.CharacterData;
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.w3c.dom.Element;
|
||||||
|
import org.w3c.dom.NamedNodeMap;
|
||||||
|
import org.w3c.dom.Node;
|
||||||
|
import org.w3c.dom.NodeList;
|
||||||
|
|
||||||
|
import javax.xml.xpath.XPath;
|
||||||
|
import javax.xml.xpath.XPathConstants;
|
||||||
|
import javax.xml.xpath.XPathExpression;
|
||||||
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
|
import javax.xml.xpath.XPathFactory;
|
||||||
|
|
||||||
|
public class XMLTools
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Вернуть значение первой попавшийся CDATA
|
||||||
|
* @return строка
|
||||||
|
*/
|
||||||
|
public static String getCDATAValue(Node node)
|
||||||
|
{
|
||||||
|
if(node==null) return "";
|
||||||
|
NodeList items = node.getChildNodes();
|
||||||
|
for (int i=0;i<items.getLength();i++)
|
||||||
|
{
|
||||||
|
Node n=items.item(i);
|
||||||
|
if(n.getNodeName().equals("#cdata-section"))
|
||||||
|
return n.getNodeValue();
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Найти узел по атрибуту
|
||||||
|
*/
|
||||||
|
public static Node findNodeOnAttribute(Node node, String nodename, String attribute, String val)
|
||||||
|
{
|
||||||
|
if(node==null) return null;
|
||||||
|
NodeList items = node.getChildNodes();
|
||||||
|
for (int i=0;i<items.getLength();i++)
|
||||||
|
{
|
||||||
|
Node n=items.item(i);
|
||||||
|
if(n.getNodeName().equals(nodename))
|
||||||
|
{
|
||||||
|
NamedNodeMap nnm=n.getAttributes();
|
||||||
|
if(nnm.getNamedItem(attribute).getNodeValue().equals(val)) return n;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Node findFirstNodeOnAttribute(Node node, String nodename,String attribute,String val)
|
||||||
|
{
|
||||||
|
Node result=null;
|
||||||
|
if(node==null) return result;
|
||||||
|
javax.xml.xpath.XPathFactory xPathfactory = javax.xml.xpath.XPathFactory.newInstance();
|
||||||
|
XPath xpath = xPathfactory.newXPath();
|
||||||
|
XPathExpression expr=null;
|
||||||
|
Object exprResult=null;
|
||||||
|
try {
|
||||||
|
expr = xpath.compile("//*/"+nodename+"[@"+attribute+"='" + val + "']");
|
||||||
|
exprResult = expr.evaluate(node, XPathConstants.NODESET);
|
||||||
|
} catch (XPathExpressionException ex) {
|
||||||
|
|
||||||
|
}
|
||||||
|
NodeList nodeList = (NodeList) exprResult;
|
||||||
|
if (nodeList.getLength() > 0)
|
||||||
|
result = nodeList.item(0);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Поиск среди текущего и дочерних узлов
|
||||||
|
* @param {Node} node Корневой узел
|
||||||
|
* @param {String} nodename Имя первого попавшегося узла
|
||||||
|
* @returns {undefined}
|
||||||
|
*/
|
||||||
|
public static Node findFirstNode(Node node, String nodename)
|
||||||
|
{
|
||||||
|
Node result=null;
|
||||||
|
if(node==null) return result;
|
||||||
|
javax.xml.xpath.XPathFactory xPathfactory = javax.xml.xpath.XPathFactory.newInstance();
|
||||||
|
XPath xpath = xPathfactory.newXPath();
|
||||||
|
XPathExpression expr=null;
|
||||||
|
Object exprResult=null;
|
||||||
|
try {
|
||||||
|
expr = xpath.compile("//*/"+nodename);
|
||||||
|
exprResult = expr.evaluate(node, XPathConstants.NODESET);
|
||||||
|
} catch (XPathExpressionException ex) {
|
||||||
|
|
||||||
|
}
|
||||||
|
NodeList nodeList = (NodeList) exprResult;
|
||||||
|
if (nodeList.getLength() > 0)
|
||||||
|
result = nodeList.item(0);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Присвоить дочерние узлы первого дерева второму если их нет, иначе дополнить либо заменить. (Работает через рекурсию нужно для передачи параметров между окнами)
|
||||||
|
* @param {XML} first Узел где ханятся настройки
|
||||||
|
* @param {XML} second Узел к которому применяются настройки
|
||||||
|
* @param {String} name Имя атрибута по которому будут находиться одинаковые XML узлы
|
||||||
|
* @returns {undefined}
|
||||||
|
*/
|
||||||
|
public static void applyNodeToNode(Node first, Node second,String name)
|
||||||
|
{
|
||||||
|
if(first==null || second==null || name==null) return;
|
||||||
|
|
||||||
|
//Если есть совпадающие узлы то передаём в рекурсию если нет то просто копируем
|
||||||
|
Node fn=first.getFirstChild();
|
||||||
|
while (fn != null)
|
||||||
|
{
|
||||||
|
Node sn=null;
|
||||||
|
if(!fn.getNodeName().equals("#text") && !fn.getNodeName().equals("#cdata-section") && !fn.getNodeName().equals("#comment")) { //потому что для этих getAttribute вызывает ошибку
|
||||||
|
sn=findNodeOnAttribute(second,fn.getNodeName(),name,fn.getAttributes().getNamedItem(name).getNodeValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
if(sn!=null) //Если по имени атрибуту совпали узлы
|
||||||
|
{
|
||||||
|
//Переписываем значения атрибутов из первого второму, если их нет то создаём.
|
||||||
|
for(int i=0;i<fn.getAttributes().getLength();i++)
|
||||||
|
{
|
||||||
|
Element el=(Element) sn;
|
||||||
|
el.setAttribute(fn.getAttributes().item(i).getNodeName(),fn.getAttributes().item(i).getNodeValue());
|
||||||
|
}
|
||||||
|
applyNodeToNode(fn,sn,name); //В рекурсию
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//Значения CDADA или text node не должны накапливаться их мы пересоздаём (потом по момеру можно сделать 1й заменяется первым итд.)
|
||||||
|
if(fn.getNodeName().equals("#cdata-section"))
|
||||||
|
{
|
||||||
|
XMLTools.setCharacterDataToElement((Element)second, XMLTools.getCharacterDataFromElement((Element) fn)); //getCdata(second).nodeValue = fn.nodeValue;
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
second.appendChild(fn.cloneNode(true));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fn=fn.getNextSibling();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Найти узел по имени
|
||||||
|
* @param node
|
||||||
|
* @param nodename
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static Node findNode(Node node, String nodename)
|
||||||
|
{
|
||||||
|
if(node==null || nodename==null) return null;
|
||||||
|
NodeList items = node.getChildNodes();
|
||||||
|
for (int i=0;i<items.getLength();i++)
|
||||||
|
{
|
||||||
|
Node n=items.item(i);
|
||||||
|
if(n.getNodeName().equals(nodename))
|
||||||
|
{
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getCharacterDataFromElement(Element e) {
|
||||||
|
Node child = e.getFirstChild();
|
||||||
|
if (child instanceof CharacterData) {
|
||||||
|
CharacterData cd = (CharacterData) child;
|
||||||
|
return cd.getData().trim();
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setCharacterDataToElement(Node nF, String data) {
|
||||||
|
Node child = nF.getFirstChild();
|
||||||
|
if (child instanceof CharacterData) {
|
||||||
|
CharacterData cd = (CharacterData) child;
|
||||||
|
cd.setData(data);
|
||||||
|
} else //Create new CDATA node
|
||||||
|
{
|
||||||
|
Document doc = nF.getOwnerDocument();
|
||||||
|
nF.appendChild(doc.createCDATASection(data));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
33
src/main/resources/logback-spring.xml
Normal file
33
src/main/resources/logback-spring.xml
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<configuration>
|
||||||
|
|
||||||
|
<!-- Please check if the user has access to the directory from which the application is being executed -->
|
||||||
|
<property name="LOGS" value="logs" />
|
||||||
|
<springProperty scope="context" name="appName" source="spring.application.name"/>
|
||||||
|
|
||||||
|
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
||||||
|
<file>${LOGS}/${appName}.log</file>
|
||||||
|
<encoder>
|
||||||
|
<pattern>{"timestamp":"%d{yyyy-MM-dd'T'HH:mm:ss.SSS'Z'}","thread":"[%thread]","level":"%level","logger":"%logger{36}","marker":"%X{marker}","message":"%msg"}%n</pattern>
|
||||||
|
</encoder>
|
||||||
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
||||||
|
<fileNamePattern>${LOGS}/${appName}.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
|
||||||
|
<maxHistory>30</maxHistory>
|
||||||
|
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
||||||
|
<maxFileSize>100MB</maxFileSize>
|
||||||
|
</timeBasedFileNamingAndTriggeringPolicy>
|
||||||
|
</rollingPolicy>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||||||
|
<encoder>
|
||||||
|
<pattern>%d{yyyy-MM-dd'T'HH:mm:ss.SSS'Z'} | %level | %logger{36} | %X{marker} | %msg%n</pattern>
|
||||||
|
</encoder>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<root level="info">
|
||||||
|
<appender-ref ref="FILE" />
|
||||||
|
<appender-ref ref="CONSOLE" />
|
||||||
|
</root>
|
||||||
|
|
||||||
|
</configuration>
|
||||||
13
src/test/java/com/geovizor/dbms/DbmsApplicationTests.java
Normal file
13
src/test/java/com/geovizor/dbms/DbmsApplicationTests.java
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
package org.ccalm.dbms;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
class DbmsApplicationTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void contextLoads() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
51
transit.properties
Normal file
51
transit.properties
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
spring.application.name=dbms
|
||||||
|
server.port=8084
|
||||||
|
|
||||||
|
issuer.name=geovizor
|
||||||
|
|
||||||
|
#??? ?????? ???????? ? ???????
|
||||||
|
logging.level.com.zaxxer.hikari=DEBUG
|
||||||
|
|
||||||
|
#spring.datasource.url=jdbc:postgresql://geovizor.com:5432/monitoring_new
|
||||||
|
#spring.datasource.username=postgres
|
||||||
|
#spring.datasource.password=y7HMHi0ATxx1VC3UU5WG
|
||||||
|
#spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
#????????? ??? ?????????? ? ????? ??????
|
||||||
|
spring.datasource.url=jdbc:postgresql://mcp.kz:5432/mcp
|
||||||
|
spring.datasource.username=igor
|
||||||
|
spring.datasource.password=VnzbUdcePSLtg22ktz13
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
#????????? ??? ???? ??????????
|
||||||
|
spring.datasource.hikari.maximum-pool-size=10
|
||||||
|
spring.datasource.hikari.minimum-idle=5
|
||||||
|
spring.datasource.hikari.max-lifetime=1700000
|
||||||
|
spring.datasource.hikari.idle-timeout=600000
|
||||||
|
spring.datasource.hikari.connection-timeout=30000
|
||||||
|
spring.datasource.hikari.connection-test-query=SELECT now()
|
||||||
|
spring.datasource.hikari.validation-timeout=60000
|
||||||
|
|
||||||
|
|
||||||
|
access.key=yon8FWKppyvpSSUMyRt3tGKiOKfZk3LRkgh9ZA2+Zh8=
|
||||||
|
access.time=600
|
||||||
|
|
||||||
|
refresh.key=yon8FWKppyvpSSUMyRt3tGKiOKfZk3LRkgh9ZA2+Zh8=
|
||||||
|
refresh.time=43200
|
||||||
|
|
||||||
|
|
||||||
|
captcha.key=PPExpv36jk4Vzda3NpYnXLfuHCLYXqaNrxlOH/Jr/1M=
|
||||||
|
captcha.time=600
|
||||||
|
|
||||||
|
mail.host=smtp.yandex.ru
|
||||||
|
mail.port=465
|
||||||
|
mail.loginModel=info@ccalm.org
|
||||||
|
mail.password=fu2lpsoGPGiq1xlRm8ag
|
||||||
|
|
||||||
|
url.reset=http://127.0.0.1:8088/reset
|
||||||
|
url.main=http://127.0.0.1:8088/
|
||||||
|
|
||||||
|
spring.redis.host=127.0.0.1
|
||||||
|
spring.redis.port=6379
|
||||||
|
spring.redis.password=9F3/NKWeOjd815vkadT2DcgVHf6fEpVQXw==
|
||||||
|
|
||||||
Reference in New Issue
Block a user