esoe
2 months ago
28 changed files with 1551 additions and 0 deletions
@ -0,0 +1,5 @@ |
|||||||
|
PG_CONTAINER_NAME='teh-base' |
||||||
|
POSTGRES_USER='teh' |
||||||
|
POSTGRES_PASSWORD='teh' |
||||||
|
POSTGRES_DB='teh' |
||||||
|
PGDATA='/data/teh' |
@ -0,0 +1,2 @@ |
|||||||
|
# base |
||||||
|
миктосервис, предосавляющий доступ к postgres |
@ -0,0 +1,29 @@ |
|||||||
|
version: "3.7" |
||||||
|
services: |
||||||
|
teh-base: |
||||||
|
build: |
||||||
|
context: ../base |
||||||
|
dockerfile: dockerfile |
||||||
|
image: "teh-base" |
||||||
|
container_name: ${PG_CONTAINER_NAME} |
||||||
|
environment: |
||||||
|
POSTGRES_DB: ${POSTGRES_DB} |
||||||
|
POSTGRES_USER: ${POSTGRES_USER} |
||||||
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} |
||||||
|
PGDATA: ${PGDATA} |
||||||
|
volumes: |
||||||
|
- teh-base:${PGDATA} |
||||||
|
- teh-prebase:/var/lib/postgresql/data |
||||||
|
ports: |
||||||
|
- "5432:5432" |
||||||
|
restart: unless-stopped |
||||||
|
volumes: |
||||||
|
teh-base: |
||||||
|
external: true |
||||||
|
teh-prebase: |
||||||
|
external: true |
||||||
|
networks: |
||||||
|
default: |
||||||
|
name: teh-net |
||||||
|
external: true |
||||||
|
driver: bridge |
@ -0,0 +1,25 @@ |
|||||||
|
# Postgres-service start |
||||||
|
|
||||||
|
ARG VERSION=latest |
||||||
|
# Образ контейнера |
||||||
|
FROM postgres:${VERSION} |
||||||
|
|
||||||
|
# Сведения о контейнере |
||||||
|
LABEL author="esoe" |
||||||
|
LABEL description="postgres image for teh" |
||||||
|
LABEL version="1.0" |
||||||
|
|
||||||
|
# Переменные среды контейнера |
||||||
|
# ENV PG_CONTAINER_NAME='postgres-service' |
||||||
|
# ENV POSTGRES_USER='tech-services' |
||||||
|
# ENV POSTGRES_PASSWORD='password' |
||||||
|
# ENV POSTGRES_DB='tech-services' |
||||||
|
# ENV PGDATA='/data/tech-services' |
||||||
|
|
||||||
|
# COPY *.sql /docker-entrypoint-initdb.d/ |
||||||
|
|
||||||
|
# Сборка контейнера |
||||||
|
# docker build |
||||||
|
|
||||||
|
# Запуск контейнера |
||||||
|
# docker run |
@ -0,0 +1,5 @@ |
|||||||
|
# предварительная инициализация |
||||||
|
docker volume create teh-prebase |
||||||
|
docker volume create teh-base |
||||||
|
docker network create teh-net |
||||||
|
docker-compose up |
@ -0,0 +1,23 @@ |
|||||||
|
$container_name = "teh-base" |
||||||
|
$image_name = "teh-base" |
||||||
|
$build_name = "teh-base" |
||||||
|
$code_location = "C:\Users\devuser\Documents\code\teh\base" |
||||||
|
|
||||||
|
# Остановить и удалить существующий контейнер |
||||||
|
docker stop $container_name |
||||||
|
docker rm $container_name |
||||||
|
|
||||||
|
# Удалить существующий образ |
||||||
|
docker rmi $image_name |
||||||
|
|
||||||
|
# Перейти в каталог с проектом |
||||||
|
Set-Location $code_location |
||||||
|
|
||||||
|
# Собрать jar с помощью Maven |
||||||
|
# mvn clean package |
||||||
|
|
||||||
|
# Запустить контейнер с помощью docker-compose |
||||||
|
docker-compose up |
||||||
|
|
||||||
|
# Пауза скрипта |
||||||
|
Pause |
@ -0,0 +1,33 @@ |
|||||||
|
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/ |
@ -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 |
@ -0,0 +1,25 @@ |
|||||||
|
version: "3.7" |
||||||
|
services: |
||||||
|
storage: |
||||||
|
container_name: storage |
||||||
|
hostname: storage |
||||||
|
build: |
||||||
|
context: ../storage |
||||||
|
dockerfile: dockerfile |
||||||
|
image: "storage" |
||||||
|
command: ["java","-jar","/app/storage/storage-0.1.jar"] |
||||||
|
ports: |
||||||
|
- 82:8282 |
||||||
|
restart: unless-stopped |
||||||
|
volumes: |
||||||
|
- teh-storage:${DATA} |
||||||
|
networks: |
||||||
|
- teh-net |
||||||
|
volumes: |
||||||
|
teh-storage: |
||||||
|
external: true |
||||||
|
networks: |
||||||
|
teh-net: |
||||||
|
name: teh-net |
||||||
|
external: true |
||||||
|
driver: bridge |
@ -0,0 +1,5 @@ |
|||||||
|
FROM openjdk:17-jdk-alpine |
||||||
|
RUN apk update |
||||||
|
RUN apk upgrade |
||||||
|
COPY target/storage-0.1.jar /app/storage/storage-0.1.jar |
||||||
|
WORKDIR /app/storage |
@ -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 "$@" |
@ -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" |
@ -0,0 +1,79 @@ |
|||||||
|
<?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.4</version> |
||||||
|
<relativePath/> <!-- lookup parent from repository --> |
||||||
|
</parent> |
||||||
|
<groupId>gsp.technologies</groupId> |
||||||
|
<artifactId>storage</artifactId> |
||||||
|
<version>0.1</version> |
||||||
|
<name>storage</name> |
||||||
|
<description>обеспечени доступа к файловой системе teh-сервисов</description> |
||||||
|
<url/> |
||||||
|
<licenses> |
||||||
|
<license/> |
||||||
|
</licenses> |
||||||
|
<developers> |
||||||
|
<developer/> |
||||||
|
</developers> |
||||||
|
<scm> |
||||||
|
<connection/> |
||||||
|
<developerConnection/> |
||||||
|
<tag/> |
||||||
|
<url/> |
||||||
|
</scm> |
||||||
|
<properties> |
||||||
|
<java.version>17</java.version> |
||||||
|
</properties> |
||||||
|
<dependencies> |
||||||
|
<dependency> |
||||||
|
<groupId>org.projectlombok</groupId> |
||||||
|
<artifactId>lombok</artifactId> |
||||||
|
<optional>true</optional> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter-thymeleaf</artifactId> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter-web</artifactId> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter-data-jpa</artifactId> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.postgresql</groupId> |
||||||
|
<artifactId>postgresql</artifactId> |
||||||
|
<scope>runtime</scope> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-starter-test</artifactId> |
||||||
|
<scope>test</scope> |
||||||
|
</dependency> |
||||||
|
</dependencies> |
||||||
|
|
||||||
|
<build> |
||||||
|
<plugins> |
||||||
|
<plugin> |
||||||
|
<groupId>org.springframework.boot</groupId> |
||||||
|
<artifactId>spring-boot-maven-plugin</artifactId> |
||||||
|
<configuration> |
||||||
|
<excludes> |
||||||
|
<exclude> |
||||||
|
<groupId>org.projectlombok</groupId> |
||||||
|
<artifactId>lombok</artifactId> |
||||||
|
</exclude> |
||||||
|
</excludes> |
||||||
|
</configuration> |
||||||
|
</plugin> |
||||||
|
</plugins> |
||||||
|
</build> |
||||||
|
|
||||||
|
</project> |
@ -0,0 +1,23 @@ |
|||||||
|
$container_name = "storage" |
||||||
|
$image_name = "storage" |
||||||
|
$build_name = "storage" |
||||||
|
$code_location = "C:\Users\devuser\Documents\code\teh\storage" |
||||||
|
|
||||||
|
# Остановить и удалить существующий контейнер |
||||||
|
docker stop $container_name |
||||||
|
docker rm $container_name |
||||||
|
|
||||||
|
# Удалить существующий образ |
||||||
|
docker rmi $image_name |
||||||
|
|
||||||
|
# Перейти в каталог с проектом |
||||||
|
Set-Location $code_location |
||||||
|
|
||||||
|
# Собрать jar с помощью Maven |
||||||
|
mvn clean package |
||||||
|
|
||||||
|
# Запустить контейнер с помощью docker-compose |
||||||
|
docker-compose up |
||||||
|
|
||||||
|
# Пауза скрипта |
||||||
|
Pause |
@ -0,0 +1,13 @@ |
|||||||
|
package gsp.technologies.storage; |
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication; |
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication; |
||||||
|
|
||||||
|
@SpringBootApplication |
||||||
|
public class StorageApplication { |
||||||
|
|
||||||
|
public static void main(String[] args) { |
||||||
|
SpringApplication.run(StorageApplication.class, args); |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,18 @@ |
|||||||
|
package gsp.technologies.storage.config; |
||||||
|
|
||||||
|
import org.springframework.boot.context.properties.ConfigurationProperties; |
||||||
|
import org.springframework.context.annotation.Configuration; |
||||||
|
|
||||||
|
@Configuration |
||||||
|
@ConfigurationProperties(prefix = "storage") |
||||||
|
public class StorageConfig { |
||||||
|
|
||||||
|
private String location; |
||||||
|
public String getLocation() { |
||||||
|
return location; |
||||||
|
} |
||||||
|
public void setLocation(String location) { |
||||||
|
this.location = location; |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,52 @@ |
|||||||
|
package gsp.technologies.storage.controllers.hello; |
||||||
|
|
||||||
|
import org.springframework.stereotype.Controller; |
||||||
|
import org.springframework.web.bind.annotation.GetMapping; |
||||||
|
|
||||||
|
// import ru.molokoin.storagers.model.Document;
|
||||||
|
// import ru.molokoin.storagers.model.XlsxCell;
|
||||||
|
// import ru.molokoin.storagers.model.XlsxMultipartDocument;
|
||||||
|
// import ru.molokoin.storagers.service.StorageServiceFace;
|
||||||
|
|
||||||
|
/** |
||||||
|
* контроллер, для отрабтки тестов, |
||||||
|
* выводит страницу с информацией о сервисе пользователю |
||||||
|
*/ |
||||||
|
@Controller |
||||||
|
public class HelloController { |
||||||
|
/** |
||||||
|
* получаем в переменную root |
||||||
|
* значение свойства storage.location |
||||||
|
* из файла application.yaml |
||||||
|
*/ |
||||||
|
// private StorageServiceFace storage;
|
||||||
|
|
||||||
|
/** |
||||||
|
* Конструктор контроллера, дня инициализации объекта хранилища |
||||||
|
* - передается интерфейс |
||||||
|
* @param storage |
||||||
|
*/ |
||||||
|
// public HelloController(StorageServiceFace storage){
|
||||||
|
// this.storage = storage;
|
||||||
|
// }
|
||||||
|
|
||||||
|
@GetMapping("/hello") |
||||||
|
public String hello(){ |
||||||
|
// System.out.println("storageRS/hello-controller# " + "передача пользователю шаблона hello.html");
|
||||||
|
// System.out.println("storageRS/hello-controller#(из config): " + storage.root());
|
||||||
|
// System.out.println("Загружено документов: " + storage.list().size());
|
||||||
|
System.out.println("Перечень загруженных документов:"); |
||||||
|
// int i = 1;
|
||||||
|
// for (Document doc : storage.list()) {
|
||||||
|
// XlsxMultipartDocument parts = new XlsxMultipartDocument(doc);
|
||||||
|
// System.out.println("Document#" + i + ": " + doc.getPath() + "(size#" + doc.getSize() + ")" + " ### lines: " + parts.getLineCount());
|
||||||
|
// for (XlsxCell c: parts.line(i-1)) {
|
||||||
|
// System.out.println(c.getContent());
|
||||||
|
// }
|
||||||
|
// parts.close();
|
||||||
|
// System.out.println("---------------------");
|
||||||
|
// i++;
|
||||||
|
// }
|
||||||
|
return "hello"; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,24 @@ |
|||||||
|
package gsp.technologies.storage.services; |
||||||
|
|
||||||
|
import java.nio.file.Path; |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
import org.springframework.core.io.Resource; |
||||||
|
|
||||||
|
import gsp.technologies.storage.models.FileMetadata; |
||||||
|
|
||||||
|
public interface FileService { |
||||||
|
// List<FileMetadata> listFiles(String path, Boolean recursive);
|
||||||
|
// List<FileMetadata> listFiles(Path path, Boolean recursive);
|
||||||
|
List<FileMetadata> listFiles(String path); |
||||||
|
List<FileMetadata> listFiles(Path path); |
||||||
|
String uploadFile(String filename, byte[] content); |
||||||
|
void deleteFile(String filename); |
||||||
|
byte[] getFile(String filename); |
||||||
|
String createFile(String path, String name, byte[] content); |
||||||
|
void createDirectory(String path, String name); |
||||||
|
void deleteDirectory(String name); |
||||||
|
public Path root(); |
||||||
|
void init(); |
||||||
|
Resource loadAsResource(String filename); |
||||||
|
} |
@ -0,0 +1,228 @@ |
|||||||
|
package gsp.technologies.storage.services; |
||||||
|
|
||||||
|
import java.io.File; |
||||||
|
import java.io.FileNotFoundException; |
||||||
|
import java.io.IOException; |
||||||
|
import java.net.MalformedURLException; |
||||||
|
import java.nio.file.Files; |
||||||
|
import java.nio.file.Path; |
||||||
|
import java.nio.file.Paths; |
||||||
|
import java.util.Comparator; |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
import org.springframework.core.io.Resource; |
||||||
|
import org.springframework.core.io.UrlResource; |
||||||
|
import org.springframework.stereotype.Service; |
||||||
|
|
||||||
|
import gsp.technologies.storage.config.StorageConfig; |
||||||
|
import gsp.technologies.storage.models.FileMetadata; |
||||||
|
import jakarta.annotation.PostConstruct; |
||||||
|
|
||||||
|
@Service |
||||||
|
public class FileServiceImpl implements FileService { |
||||||
|
private final Path storageLocation; |
||||||
|
public FileServiceImpl(StorageConfig config) { |
||||||
|
this.storageLocation = Paths.get(config.getLocation()) |
||||||
|
.toAbsolutePath().normalize(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Инициализация сервиса файлов, создание директории для хранения файлов, если она не существует |
||||||
|
* Если произошла ошибка при создании директории, она выводится в консоль |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
@PostConstruct |
||||||
|
public void init() { |
||||||
|
try { |
||||||
|
// Создание директории для хранения файлов, если она не существует
|
||||||
|
Files.createDirectories(storageLocation); |
||||||
|
} catch (IOException e) { |
||||||
|
// Печатает в консоль сообщение об ошибке при создании директории
|
||||||
|
System.out.println("Ошибка создания директории для хранения файлов: " + e.getMessage()); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Получение перечня файлов по пути (Path) |
||||||
|
* |
||||||
|
* @param path путь к директории, для которой нужно получить список файлов |
||||||
|
* @return список метаданных файлов |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public List<FileMetadata> listFiles(Path path) { |
||||||
|
return new FileMetadata(path.toString()).getChildren(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Получение перечня файлов по пути (String) |
||||||
|
* |
||||||
|
* @param path путь к директории, для которой нужно получить список файлов |
||||||
|
* @return список метаданных файлов |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public List<FileMetadata> listFiles(String path) { |
||||||
|
return new FileMetadata(path).getChildren(); |
||||||
|
} |
||||||
|
/** |
||||||
|
* Загрузка файла в указанный путь в директории хранения |
||||||
|
* Если файл уже существует, возвращает null |
||||||
|
* Если произошла ошибка при создании файла, печатает сообщение об ошибке и возвращает null |
||||||
|
* |
||||||
|
* @param filename имя файла |
||||||
|
* @param content содержимое файла |
||||||
|
* @return имя загруженного файла или null в случае ошибки |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public String uploadFile(String filename, byte[] content) { |
||||||
|
try { |
||||||
|
File file = new File(storageLocation + "/" + filename); |
||||||
|
if (file.exists()) { |
||||||
|
// Если файл уже существует, возвращает null
|
||||||
|
return null; |
||||||
|
} |
||||||
|
file.createNewFile(); |
||||||
|
Files.write(file.toPath(), content); |
||||||
|
return filename; |
||||||
|
} catch (Exception e) { |
||||||
|
// Печатает в консоль сообщение об ошибке при создании файла
|
||||||
|
System.out.println("Ошибка загрузки файла: " + e.getMessage()); |
||||||
|
return null; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Удаляет файл с указанным именем. |
||||||
|
* |
||||||
|
* @param filename имя файла, который нужно удалить. |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public void deleteFile(String filename) { |
||||||
|
// Создаем объект файла с указанным именем.
|
||||||
|
File file = new File(filename); |
||||||
|
// Если файл существует, удаляем его.
|
||||||
|
if (file.exists()) { |
||||||
|
file.delete(); |
||||||
|
} |
||||||
|
} |
||||||
|
/** |
||||||
|
* Возвращает содержимое файла, указанного в параметре filename. |
||||||
|
* Если файл не найден, возвращает пустой массив байтов. |
||||||
|
* |
||||||
|
* @param filename имя файла |
||||||
|
* @return содержимое файла или пустой массив байтов, если файл не найден |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public byte[] getFile(String filename) { |
||||||
|
// Попытка прочитать содержимое файла
|
||||||
|
try { |
||||||
|
return java.nio.file.Files.readAllBytes(Paths.get(filename)); |
||||||
|
} catch (IOException e) { |
||||||
|
// Если файл не найден, возвращает пустой массив байтов
|
||||||
|
return new byte[0]; |
||||||
|
} |
||||||
|
} |
||||||
|
/** |
||||||
|
* Создает файл с указанным содержимым в указанном пути и указанным именем. |
||||||
|
* Если файл уже существует, возвращает null. |
||||||
|
* |
||||||
|
* @param string не используется, передается для совместимости с интерфейсом |
||||||
|
* @param path путь к директории, в которой нужно создать файл |
||||||
|
* @param name имя файла |
||||||
|
* @param content содержимое файла |
||||||
|
* @return имя созданного файла или null, если файл с таким именем уже существует |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public String createFile(String path, String name, byte[] content) { |
||||||
|
try { |
||||||
|
// Создаем объект файла с указанным именем в указанной директории.
|
||||||
|
File file = new File(path + "/" + name); |
||||||
|
// Если файл уже существует, возвращаем null.
|
||||||
|
if (file.exists()) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
// Создаем новый файл.
|
||||||
|
file.createNewFile(); |
||||||
|
// Записываем в файл указанное содержимое.
|
||||||
|
Files.write(file.toPath(), content); |
||||||
|
// Возвращаем имя созданного файла.
|
||||||
|
return name; |
||||||
|
} catch (IOException e) { |
||||||
|
// Если произошла ошибка при создании файла, печатаем сообщение об ошибке и возвращаем null.
|
||||||
|
System.out.println("Ошибка создания файла: " + e.getMessage()); |
||||||
|
return null; |
||||||
|
} |
||||||
|
} |
||||||
|
/** |
||||||
|
* Создает директорию с указанным именем в указанном пути. |
||||||
|
* Если директория уже существует, ничего не делает. |
||||||
|
* |
||||||
|
* @param path путь к директории, в которой нужно создать директорию |
||||||
|
* @param name имя директории |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public void createDirectory(String path, String name) { |
||||||
|
try { |
||||||
|
// Создаем объект директории с указанным именем в указанной директории.
|
||||||
|
File directory = new File(path + "/" + name); |
||||||
|
// Если директория уже существует, ничего не делаем.
|
||||||
|
if (directory.exists()) { |
||||||
|
return; |
||||||
|
} |
||||||
|
// Создаем новую директорию.
|
||||||
|
directory.mkdir(); |
||||||
|
} catch (SecurityException e) { |
||||||
|
// Если произошла ошибка при создании директории, печатаем сообщение об ошибке.
|
||||||
|
System.out.println("Ошибка создания директории: " + e.getMessage()); |
||||||
|
} |
||||||
|
} |
||||||
|
/** |
||||||
|
* Удаляет директорию с указанным именем. |
||||||
|
* Если директория не существует, ничего не делает. |
||||||
|
* |
||||||
|
* @param name имя директории |
||||||
|
*/ |
||||||
|
@Override |
||||||
|
public void deleteDirectory(String name) { |
||||||
|
try { |
||||||
|
// Создаем объект директории с указанным именем.
|
||||||
|
File directory = new File(name); |
||||||
|
// Если директория существует, удаляем ее.
|
||||||
|
if (directory.exists()) { |
||||||
|
Files.walk(directory.toPath()) |
||||||
|
.sorted(Comparator.reverseOrder()) |
||||||
|
.map(Path::toFile) |
||||||
|
.forEach(File::delete); |
||||||
|
} |
||||||
|
} catch (IOException e) { |
||||||
|
// Если произошла ошибка при удалении директории, печатаем сообщение об ошибке.
|
||||||
|
System.out.println("Ошибка удаления директории: " + e.getMessage()); |
||||||
|
} |
||||||
|
} |
||||||
|
@Override |
||||||
|
public Path root() { |
||||||
|
return this.storageLocation; |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public Resource loadAsResource(String filename) { |
||||||
|
try { |
||||||
|
Path file = load(filename); |
||||||
|
Resource resource = new UrlResource(file.toUri()); |
||||||
|
if (resource.exists() || resource.isReadable()) { |
||||||
|
return resource; |
||||||
|
} |
||||||
|
else { |
||||||
|
// throw new FileNotFoundException(
|
||||||
|
// "Could not read file: " + filename);
|
||||||
|
} |
||||||
|
} |
||||||
|
catch (MalformedURLException e) { |
||||||
|
// throw new FileNotFoundException("Could not read file: " + filename, e);
|
||||||
|
} |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
private Path load(String filename) { |
||||||
|
return storageLocation.resolve(filename); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,23 @@ |
|||||||
|
spring: |
||||||
|
application: |
||||||
|
name: storage |
||||||
|
servlet: |
||||||
|
multipart: |
||||||
|
max-file-size: 1000MB |
||||||
|
max-request-size: 1000MB |
||||||
|
enabled: true |
||||||
|
jpa: |
||||||
|
hibernate: |
||||||
|
ddl-auto: update |
||||||
|
database-platform: org.hibernate.dialect.PostgreSQLDialect |
||||||
|
datasource: |
||||||
|
url: "jdbc:postgresql://base:5432/teh" |
||||||
|
username: teh |
||||||
|
password: teh |
||||||
|
|
||||||
|
server: |
||||||
|
port: 8282 |
||||||
|
storage: |
||||||
|
location: ./uploads |
||||||
|
# root: ./ |
||||||
|
# uploads: |
@ -0,0 +1,51 @@ |
|||||||
|
# storage-rs |
||||||
|
Настоящий сервис задумывался как универсальное средство работы с файловой системой, которое в перспективе может использоваться различными сервисами. |
||||||
|
|
||||||
|
Сервис работы с файлами: |
||||||
|
- загрузка файлов на сервер |
||||||
|
- скачивание файлов с сервера |
||||||
|
- просмотр списка файлов |
||||||
|
- представление данных xlsx файлов в json |
||||||
|
|
||||||
|
Связка файлового хранилища с СУБД осуществляется контроллером третьего сервиса (gates) |
||||||
|
|
||||||
|
# Загрузка файлов на сервер |
||||||
|
1. файлы загружаются по одному, одновременно создается запись о пакете (table_pack) в базе |
||||||
|
|
||||||
|
table_pack: |
||||||
|
- id |
||||||
|
- наименование пакета |
||||||
|
- тип пакета (наименование загружаемой формы, для выбора последующего алгоритма обработки) |
||||||
|
|
||||||
|
# API |
||||||
|
## [GET domain:port/api/list-uploads](http://localhost:82/api/list-uploads) |
||||||
|
Получение списка размещенных в хранилище файлов |
||||||
|
|
||||||
|
## GET:/api/document/{filename} |
||||||
|
[link](http://localhost:82/api/document/107.xlsx) |
||||||
|
Получение метаданных размещенного в хранилище файла: |
||||||
|
- наименование |
||||||
|
- расширение |
||||||
|
- путь |
||||||
|
- размер в байтах |
||||||
|
|
||||||
|
Метаданные берутся из информации файловой системы и представляются пользователю в качестве объекта document, обображенного в json формате. |
||||||
|
|
||||||
|
## /api/document/content/{filename} |
||||||
|
[link](http://localhost:82/api/document/content/107.xlsx) |
||||||
|
Получение данных xlsx файла в json формате |
||||||
|
|
||||||
|
## DELETE:/api/document/delete/{filename} |
||||||
|
## POST:/api/document/store |
||||||
|
|
||||||
|
# Face |
||||||
|
## /view/{name} |
||||||
|
Просмотр содержимого xlsx-файла в виде таблицы |
||||||
|
|
||||||
|
## [/uploads](http://localhost:82/uploads) |
||||||
|
Просмотр списка файлов из хранилища по данным файловой системы. |
||||||
|
Доступ к инструментам: |
||||||
|
- добавления файлов в хранишище |
||||||
|
- удаление файлов |
||||||
|
- просмотр содержимого xlsx-файлов |
||||||
|
|
@ -0,0 +1,14 @@ |
|||||||
|
<!DOCTYPE html> |
||||||
|
<html xmlns="http://www.w3.org/1999/xhtml" |
||||||
|
xmlns:th="http://www.thymeleaf.org"> |
||||||
|
<head> |
||||||
|
<meta charset="UTF-8"> |
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
||||||
|
<title>hello-page</title> |
||||||
|
<script src="https://cdn.jsdelivr.net/npm/@webcomponents/webcomponentsjs@2/webcomponents-loader.min.js"></script> |
||||||
|
<script type="module" src="https://cdn.jsdelivr.net/gh/zerodevx/zero-md@1/src/zero-md.min.js"></script> |
||||||
|
</head> |
||||||
|
<body> |
||||||
|
<zero-md th:src="@{/content/md/hello.md}"></zero-md> |
||||||
|
</body> |
||||||
|
</html> |
@ -0,0 +1,48 @@ |
|||||||
|
<!DOCTYPE html> |
||||||
|
<html xmlns:th="http://www.thymeleaf.org"> |
||||||
|
<head> |
||||||
|
<title>mainframe</title> |
||||||
|
|
||||||
|
</head> |
||||||
|
<body> |
||||||
|
<header> |
||||||
|
<h1>MAINFRAME</h1> |
||||||
|
<hr> |
||||||
|
</header> |
||||||
|
<main> |
||||||
|
<div> |
||||||
|
<form th:action="@{/face/v1/upload}" th:method="post" enctype="multipart/form-data"> |
||||||
|
<input type="file" name="file"> |
||||||
|
<button type="submit">send</button> |
||||||
|
</form> |
||||||
|
<hr> |
||||||
|
<form th:action="@{/face/v1/upload-multiple-files}" |
||||||
|
th:method="post" |
||||||
|
enctype="multipart/form-data"> |
||||||
|
<input type="file" name="files" multiple> |
||||||
|
<button type="submit">send</button> |
||||||
|
</form> |
||||||
|
</div> |
||||||
|
<hr> |
||||||
|
|
||||||
|
<div class="files"> |
||||||
|
<h2>Files (tree): <span th:text="${root}"></span></h2> |
||||||
|
<table> |
||||||
|
<tr th:each="file : ${files}"> |
||||||
|
<td th:text="${file.name}"></td> |
||||||
|
<td> |
||||||
|
<span th:text="${file.type}"></span> |
||||||
|
</td> |
||||||
|
<td> |
||||||
|
<span th:text="${file.path}"></span> |
||||||
|
</td> |
||||||
|
<td><a th:href="@{/api/v1/files/{path}(path=${file.path})}">open</a></td> |
||||||
|
<td> |
||||||
|
<a th:href="@{/api/v1/files?filename={filename}(filename=${file.name})}">download"></a> |
||||||
|
</td> |
||||||
|
</tr> |
||||||
|
</table> |
||||||
|
</div> |
||||||
|
</main> |
||||||
|
</body> |
||||||
|
</html> |
@ -0,0 +1,13 @@ |
|||||||
|
package gsp.technologies.storage; |
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test; |
||||||
|
import org.springframework.boot.test.context.SpringBootTest; |
||||||
|
|
||||||
|
@SpringBootTest |
||||||
|
class StorageApplicationTests { |
||||||
|
|
||||||
|
@Test |
||||||
|
void contextLoads() { |
||||||
|
} |
||||||
|
|
||||||
|
} |
Loading…
Reference in new issue