Create project

This commit is contained in:
Viltskaa 2023-05-03 02:14:52 +04:00
commit 1fc6b0f67c
36 changed files with 1496 additions and 0 deletions

33
.gitignore vendored Normal file
View File

@ -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/

10
.jpb/jpb-settings.xml Normal file
View File

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="JpaPluginProjectSettings">
<option name="entityNameTemplate" />
<option name="columnNameTemplate" value="${fieldName.underscore()}" />
<option name="useLazyOnToOneAssociations" value="true" />
<option name="indexCase" value="upper" />
<option name="scaffoldingLanguage" />
</component>
</project>

BIN
.mvn/wrapper/maven-wrapper.jar vendored Normal file

Binary file not shown.

18
.mvn/wrapper/maven-wrapper.properties vendored Normal file
View File

@ -0,0 +1,18 @@
# 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
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.7/apache-maven-3.8.7-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar

316
mvnw vendored Normal file
View File

@ -0,0 +1,316 @@
#!/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
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# Maven Start Up Batch script
#
# Required ENV vars:
# ------------------
# JAVA_HOME - location of a JDK home dir
#
# Optional ENV vars
# -----------------
# M2_HOME - location of maven2's installed home dir
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
# e.g. to debug Maven itself, use
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
# ----------------------------------------------------------------------------
if [ -z "$MAVEN_SKIP_RC" ] ; then
if [ -f /usr/local/etc/mavenrc ] ; then
. /usr/local/etc/mavenrc
fi
if [ -f /etc/mavenrc ] ; then
. /etc/mavenrc
fi
if [ -f "$HOME/.mavenrc" ] ; then
. "$HOME/.mavenrc"
fi
fi
# OS specific support. $var _must_ be set to either true or false.
cygwin=false;
darwin=false;
mingw=false
case "`uname`" in
CYGWIN*) cygwin=true ;;
MINGW*) mingw=true;;
Darwin*) darwin=true
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
if [ -z "$JAVA_HOME" ]; then
if [ -x "/usr/libexec/java_home" ]; then
export JAVA_HOME="`/usr/libexec/java_home`"
else
export JAVA_HOME="/Library/Java/Home"
fi
fi
;;
esac
if [ -z "$JAVA_HOME" ] ; then
if [ -r /etc/gentoo-release ] ; then
JAVA_HOME=`java-config --jre-home`
fi
fi
if [ -z "$M2_HOME" ] ; then
## resolve links - $0 may be a link to maven's home
PRG="$0"
# need this for relative symlinks
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG="`dirname "$PRG"`/$link"
fi
done
saveddir=`pwd`
M2_HOME=`dirname "$PRG"`/..
# make it fully qualified
M2_HOME=`cd "$M2_HOME" && pwd`
cd "$saveddir"
# echo Using m2 at $M2_HOME
fi
# For Cygwin, ensure paths are in UNIX format before anything is touched
if $cygwin ; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --unix "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
fi
# For Mingw, ensure paths are in UNIX format before anything is touched
if $mingw ; then
[ -n "$M2_HOME" ] &&
M2_HOME="`(cd "$M2_HOME"; pwd)`"
[ -n "$JAVA_HOME" ] &&
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
fi
if [ -z "$JAVA_HOME" ]; then
javaExecutable="`which javac`"
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
# readlink(1) is not available as standard on Solaris 10.
readLink=`which readlink`
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
if $darwin ; then
javaHome="`dirname \"$javaExecutable\"`"
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
else
javaExecutable="`readlink -f \"$javaExecutable\"`"
fi
javaHome="`dirname \"$javaExecutable\"`"
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
JAVA_HOME="$javaHome"
export JAVA_HOME
fi
fi
fi
if [ -z "$JAVACMD" ] ; then
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
else
JAVACMD="`\\unset -f command; \\command -v java`"
fi
fi
if [ ! -x "$JAVACMD" ] ; then
echo "Error: JAVA_HOME is not defined correctly." >&2
echo " We cannot execute $JAVACMD" >&2
exit 1
fi
if [ -z "$JAVA_HOME" ] ; then
echo "Warning: JAVA_HOME environment variable is not set."
fi
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
# traverses directory structure from process work directory to filesystem root
# first directory with .mvn subdirectory is considered project base directory
find_maven_basedir() {
if [ -z "$1" ]
then
echo "Path not specified to find_maven_basedir"
return 1
fi
basedir="$1"
wdir="$1"
while [ "$wdir" != '/' ] ; do
if [ -d "$wdir"/.mvn ] ; then
basedir=$wdir
break
fi
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
if [ -d "${wdir}" ]; then
wdir=`cd "$wdir/.."; pwd`
fi
# end of workaround
done
echo "${basedir}"
}
# concatenates all lines of a file
concat_lines() {
if [ -f "$1" ]; then
echo "$(tr -s '\n' ' ' < "$1")"
fi
}
BASE_DIR=`find_maven_basedir "$(pwd)"`
if [ -z "$BASE_DIR" ]; then
exit 1;
fi
##########################################################################################
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
# This allows using the maven wrapper in projects that prohibit checking in binary data.
##########################################################################################
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found .mvn/wrapper/maven-wrapper.jar"
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
fi
if [ -n "$MVNW_REPOURL" ]; then
jarUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
else
jarUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
fi
while IFS="=" read key value; do
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
esac
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
if [ "$MVNW_VERBOSE" = true ]; then
echo "Downloading from: $jarUrl"
fi
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
if $cygwin; then
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
fi
if command -v wget > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found wget ... using wget"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
wget "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath"
else
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath"
fi
elif command -v curl > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found curl ... using curl"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
curl -o "$wrapperJarPath" "$jarUrl" -f
else
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Falling back to using Java to download"
fi
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
# For Cygwin, switch paths to Windows format before running javac
if $cygwin; then
javaClass=`cygpath --path --windows "$javaClass"`
fi
if [ -e "$javaClass" ]; then
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Compiling MavenWrapperDownloader.java ..."
fi
# Compiling the Java class
("$JAVA_HOME/bin/javac" "$javaClass")
fi
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
# Running the downloader
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Running MavenWrapperDownloader.java ..."
fi
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
fi
fi
fi
fi
##########################################################################################
# End of extension
##########################################################################################
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
if [ "$MVNW_VERBOSE" = true ]; then
echo $MAVEN_PROJECTBASEDIR
fi
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
# For Cygwin, switch paths to Windows format before running java
if $cygwin; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --path --windows "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
[ -n "$MAVEN_PROJECTBASEDIR" ] &&
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
fi
# Provide a "standardized" way to retrieve the CLI args that will
# work with both Windows and non-Windows executions.
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
export MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
exec "$JAVACMD" \
$MAVEN_OPTS \
$MAVEN_DEBUG_OPTS \
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
"-Dmaven.home=${M2_HOME}" \
"-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"

188
mvnw.cmd vendored Normal file
View File

@ -0,0 +1,188 @@
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM https://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %*
if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %*
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% ^
%JVM_CONFIG_MAVEN_PROPS% ^
%MAVEN_OPTS% ^
%MAVEN_DEBUG_OPTS% ^
-classpath %WRAPPER_JAR% ^
"-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^
%WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat"
if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%"=="on" pause
if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE%
cmd /C exit /B %ERROR_CODE%

71
pom.xml Normal file
View File

@ -0,0 +1,71 @@
<?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.0.6</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>sybd</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>sybd</name>
<description>sybd</description>
<properties>
<java.version>17</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</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>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.26</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.jetbrains</groupId>
<artifactId>annotations</artifactId>
<version>23.0.0</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.webjars</groupId>
<artifactId>bootstrap</artifactId>
<version>5.2.3</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>

View File

@ -0,0 +1,13 @@
package com.example.sybd;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class SybdApplication {
public static void main(String[] args) {
SpringApplication.run(SybdApplication.class, args);
}
}

View File

@ -0,0 +1,42 @@
//package com.example.sybd.controllers;
//
//import com.example.sybd.models.Service;
//import com.example.sybd.models.ServiceGroup;
//import com.example.sybd.repository.ServiceGroupRepository;
//import com.example.sybd.repository.ServiceRepository;
//import org.springframework.beans.factory.annotation.Autowired;
//import org.springframework.stereotype.Controller;
//import org.springframework.web.bind.annotation.GetMapping;
//import org.springframework.web.bind.annotation.RequestMapping;
//import org.springframework.web.bind.annotation.RestController;
//
//import java.util.ArrayList;
//import java.util.List;
//import java.util.stream.StreamSupport;
//
//@RestController
//@RequestMapping("/serv")
//public class ServiceGroupController {
// @Autowired
// private ServiceGroupRepository serviceGroupRepository;
// @Autowired
// private ServiceRepository serviceRepository;
//
// @GetMapping("/all")
// public List<List<String>> all() {
// List<String> list1 = new ArrayList<>();
// for (ServiceGroup serviceGroup : serviceGroupRepository.findAll()) {
// String name = serviceGroup.getName();
// list1.add(name);
// }
// List<String> list2 = new ArrayList<>();
// for (Service service : serviceRepository.findAll()) {
// String name = service.getName();
// list2.add(name);
// }
// ArrayList<List<String>> out = new ArrayList<>();
// out.add(list1);
// out.add(list2);
// return out;
// }
//}

View File

@ -0,0 +1,4 @@
package com.example.sybd.controllers;
public class UserController {
}

View File

@ -0,0 +1,27 @@
package com.example.sybd.controllers;
import com.example.sybd.services.VisitService;
import com.example.sybd.services.WorkerService;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/worker")
public class WorkerController {
private final VisitService visitService;
private final WorkerService workerService;
public WorkerController(VisitService visitService, WorkerService workerService) {
this.visitService = visitService;
this.workerService = workerService;
}
@GetMapping("/")
public String main(Model model) {
model.addAttribute("visits", visitService.all());
model.addAttribute("workers", workerService.all());
return "workerMain";
}
}

View File

@ -0,0 +1,15 @@
package com.example.sybd.controllers;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class testCont {
@GetMapping("/")
public String main(Model model) {
model.addAttribute("message", "hello world");
return "welcome";
}
}

View File

@ -0,0 +1,33 @@
package com.example.sybd.models;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
import org.hibernate.mapping.Set;
import java.text.MessageFormat;
import java.util.Collection;
@Getter
@Setter
@Entity
@Table( name = "client" )
public class Client {
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "id", nullable = false )
private Long id;
private String name;
private String lastName;
private String secondName;
private String telephone;
private String address;
@OneToMany( mappedBy = "client" )
private Collection<Visit> visits;
public String getFio() {
return MessageFormat.format("{0} {1} {2}", secondName, name, lastName);
}
}

View File

@ -0,0 +1,21 @@
package com.example.sybd.models;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
@Getter
@Setter
@Entity
@Table( name = "post" )
public class Post {
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "id", nullable = false )
private Long id;
private String name;
@ManyToOne
@JoinColumn( name = "group_id" )
private ServiceGroup group;
}

View File

@ -0,0 +1,34 @@
package com.example.sybd.models;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
import java.util.Collection;
@Getter
@Setter
@Entity
@Table( name = "services" )
public class Service {
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "id", nullable = false )
private Long id;
private String name;
@ManyToOne
@JoinColumn( name = "group_id" )
private ServiceGroup group;
private Integer cost;
@OneToMany( mappedBy = "service" )
private Collection<Visit> visit;
public Collection<Visit> getVisit() {
return visit;
}
public void setVisit(Collection<Visit> visit) {
this.visit = visit;
}
}

View File

@ -0,0 +1,22 @@
package com.example.sybd.models;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
@NoArgsConstructor
@Getter
@Setter
@Entity
@Table( name = "services_group" )
@Inheritance( strategy = InheritanceType.SINGLE_TABLE )
public class ServiceGroup {
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "id", nullable = false )
private Long id;
@Column( name = "name" )
private String name;
}

View File

@ -0,0 +1,35 @@
package com.example.sybd.models;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
import java.sql.Date;
import java.sql.Time;
@Getter
@Setter
@Entity
@Table( name = "visit" )
public class Visit {
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "id", nullable = false )
private Long id;
@ManyToOne
@JoinColumn( name = "client_id" )
private Client client;
@ManyToOne
@JoinColumn( name = "service_id" )
private Service service;
@ManyToOne
@JoinColumn( name = "worker_id" )
private Worker worker;
private Date dateVisit;
private Time time;
private boolean isEnded;
}

View File

@ -0,0 +1,31 @@
package com.example.sybd.models;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
import java.util.Collection;
@Getter
@Setter
@Entity
@Table( name = "worker" )
public class Worker {
@Id
@GeneratedValue( strategy = GenerationType.IDENTITY )
@Column( name = "id", nullable = false )
private Long id;
private String name;
private String lastName;
private String secondName;
private String telephone;
private String address;
@ManyToOne
@JoinColumn( name = "post_id" )
private Post post;
@OneToMany( mappedBy = "worker" )
private Collection<Visit> visits;
}

View File

@ -0,0 +1,7 @@
package com.example.sybd.repository;
import com.example.sybd.models.Client;
import org.springframework.data.repository.CrudRepository;
public interface ClientRepository extends CrudRepository<Client, Long> {
}

View File

@ -0,0 +1,7 @@
package com.example.sybd.repository;
import com.example.sybd.models.Post;
import org.springframework.data.repository.CrudRepository;
public interface PostRepository extends CrudRepository<Post, Long> {
}

View File

@ -0,0 +1,9 @@
package com.example.sybd.repository;
import com.example.sybd.models.ServiceGroup;
import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface ServiceGroupRepository extends CrudRepository<ServiceGroup, Long> {
}

View File

@ -0,0 +1,10 @@
package com.example.sybd.repository;
import com.example.sybd.models.Service;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface ServiceRepository extends CrudRepository<Service, Long> {
}

View File

@ -0,0 +1,7 @@
package com.example.sybd.repository;
import com.example.sybd.models.Visit;
import org.springframework.data.repository.CrudRepository;
public interface VisitRepository extends CrudRepository<Visit, Long> {
}

View File

@ -0,0 +1,7 @@
package com.example.sybd.repository;
import com.example.sybd.models.Worker;
import org.springframework.data.repository.CrudRepository;
public interface WorkerRepository extends CrudRepository<Worker, Long> {
}

View File

@ -0,0 +1,66 @@
package com.example.sybd.services;
import com.example.sybd.models.Client;
import com.example.sybd.models.Post;
import com.example.sybd.repository.ClientRepository;
import com.example.sybd.utils.mappingUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class ClientService implements IService<Client, Long> {
private final ClientRepository clientRepository;
public ClientService(ClientRepository clientRepository) {
this.clientRepository = clientRepository;
}
public Client create(@NotNull String name,
@NotNull String secondName,
@NotNull String lastName,
@NotNull String telephone,
@NotNull String address) {
Client client = new Client();
client.setName(name);
client.setSecondName(secondName);
client.setLastName(lastName);
client.setAddress(address);
client.setTelephone(telephone);
return clientRepository.save(client);
}
@Override
public @NotNull List<Client> all() {
return mappingUtils.iterableToList(clientRepository.findAll());
}
@Override
public @Nullable Client get(Long id) {
return clientRepository.findById(id).orElse(null);
}
@Override
public @Nullable Client delete(Long id) {
Client client = clientRepository.findById(id).orElse(null);
if (client == null) return null;
clientRepository.deleteById(id);
return client;
}
@Override
public @Nullable Client update(Client other) {
Client client = clientRepository.findById(other.getId()).orElse(null);
if (client == null) return null;
client.setName(other.getName());
client.setSecondName(other.getSecondName());
client.setLastName(other.getLastName());
client.setAddress(other.getAddress());
client.setTelephone(other.getTelephone());
return clientRepository.save(client);
}
}

View File

@ -0,0 +1,54 @@
package com.example.sybd.services;
import com.example.sybd.models.ServiceGroup;
import com.example.sybd.repository.ServiceGroupRepository;
import com.example.sybd.utils.mappingUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class GroupServiceService implements IService<ServiceGroup, Long> {
private final ServiceGroupRepository serviceGroupRepository;
public GroupServiceService(ServiceGroupRepository serviceGroupRepository) {
this.serviceGroupRepository = serviceGroupRepository;
}
public ServiceGroup create(@NotNull String name) {
ServiceGroup serviceGroup = new ServiceGroup();
serviceGroup.setName(name);
return serviceGroupRepository.save(serviceGroup);
}
@Override
public @NotNull List<ServiceGroup> all() {
return mappingUtils.iterableToList(serviceGroupRepository.findAll());
}
@Override
public @Nullable ServiceGroup get(Long id) {
return serviceGroupRepository.findById(id).orElse(null);
}
@Override
public @Nullable ServiceGroup delete(Long id) {
ServiceGroup serviceGroup = serviceGroupRepository.findById(id).orElse(null);
if (serviceGroup == null)
return null;
serviceGroupRepository.deleteById(id);
return serviceGroup;
}
@Override
public @Nullable ServiceGroup update(ServiceGroup other) {
ServiceGroup serviceGroup = serviceGroupRepository.findById(other.getId()).orElse(null);
if (serviceGroup == null)
return null;
serviceGroup.setName(other.getName());
return serviceGroupRepository.save(serviceGroup);
}
}

View File

@ -0,0 +1,14 @@
package com.example.sybd.services;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.springframework.stereotype.Service;
import java.util.List;
public interface IService <type, typeId> {
@NotNull List<type> all();
@Nullable type get(typeId id);
@Nullable type delete(typeId id);
@Nullable type update(type other);
}

View File

@ -0,0 +1,65 @@
package com.example.sybd.services;
import com.example.sybd.models.Post;
import com.example.sybd.models.ServiceGroup;
import com.example.sybd.repository.PostRepository;
import com.example.sybd.utils.mappingUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class PostService implements IService<Post, Long> {
private final PostRepository postRepository;
private final GroupServiceService groupServiceService;
public PostService(PostRepository postRepository, GroupServiceService groupServiceService) {
this.postRepository = postRepository;
this.groupServiceService = groupServiceService;
}
public Post create(@NotNull String name, @NotNull Long group_id) {
ServiceGroup serviceGroup = groupServiceService.get(group_id);
if (serviceGroup == null)
return null;
Post out = new Post();
out.setName(name);
out.setGroup(serviceGroup);
return postRepository.save(out);
}
@Override
public @NotNull List<Post> all() {
return mappingUtils.iterableToList(postRepository.findAll());
}
@Override
public @Nullable Post get(Long id) {
return postRepository.findById(id).orElse(null);
}
@Override
public @Nullable Post delete(Long id) {
Post post = postRepository.findById(id).orElse(null);
if (post == null) return null;
postRepository.deleteById(id);
return post;
}
@Override
public @Nullable Post update(Post other) {
Post post = postRepository.findById(other.getId()).orElse(null);
if (post == null) return null;
if (other.getName() != null)
post.setName(other.getName());
if (other.getGroup() != null)
post.setGroup(other.getGroup());
return postRepository.save(post);
}
}

View File

@ -0,0 +1,66 @@
package com.example.sybd.services;
import com.example.sybd.models.Service;
import com.example.sybd.models.ServiceGroup;
import com.example.sybd.repository.ServiceRepository;
import com.example.sybd.utils.mappingUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.List;
@org.springframework.stereotype.Service
public class ServicesService implements IService<Service, Long> {
private final ServiceRepository serviceRepository;
private final GroupServiceService groupServiceService;
public ServicesService(ServiceRepository serviceRepository, GroupServiceService groupServiceService) {
this.serviceRepository = serviceRepository;
this.groupServiceService = groupServiceService;
}
public Service create(@NotNull String name, @NotNull Integer cost, @NotNull Long group_id) {
ServiceGroup serviceGroup = groupServiceService.get(group_id);
if (serviceGroup == null)
return null;
Service service = new Service();
service.setName(name);
service.setCost(cost);
service.setGroup(serviceGroup);
return serviceRepository.save(service);
}
@Override
public @NotNull List<Service> all() {
return mappingUtils.iterableToList(serviceRepository.findAll());
}
@Override
public @Nullable Service get(Long id) {
return serviceRepository.findById(id).orElse(null);
}
@Override
public @Nullable Service delete(Long id) {
Service service = serviceRepository.findById(id).orElse(null);
if (service == null)
return null;
serviceRepository.deleteById(id);
return service;
}
@Override
public @Nullable Service update(Service other) {
Service service = serviceRepository.findById(other.getId()).orElse(null);
if (service == null)
return null;
service.setName(other.getName());
service.setCost(other.getCost());
service.setGroup(other.getGroup());
return serviceRepository.save(service);
}
}

View File

@ -0,0 +1,88 @@
package com.example.sybd.services;
import com.example.sybd.models.Client;
import com.example.sybd.models.Service;
import com.example.sybd.models.Visit;
import com.example.sybd.models.Worker;
import com.example.sybd.repository.ClientRepository;
import com.example.sybd.repository.VisitRepository;
import com.example.sybd.utils.mappingUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.sql.Date;
import java.sql.Time;
import java.util.List;
@org.springframework.stereotype.Service
public class VisitService implements IService<Visit, Long> {
private final VisitRepository visitRepository;
private final ClientService clientService;
private final WorkerService workerService;
private final ServicesService servicesService;
public VisitService(VisitRepository visitRepository,
ClientService clientService,
WorkerService workerService,
ServicesService servicesService) {
this.visitRepository = visitRepository;
this.clientService = clientService;
this.workerService = workerService;
this.servicesService = servicesService;
}
public Visit create(@NotNull Long client_id,
@NotNull Long service_id,
@NotNull Long worker_id,
@NotNull Date date,
@NotNull Time time) {
Client client = clientService.get(client_id);
if (client == null)
return null;
Service service = servicesService.get(service_id);
if (service == null)
return null;
Worker worker = workerService.get(worker_id);
if (worker == null)
return null;
Visit visit = new Visit();
visit.setClient(client);
visit.setService(service);
visit.setWorker(worker);
visit.setDateVisit(date);
visit.setTime(time);
return visitRepository.save(visit);
}
@Override
public @NotNull List<Visit> all() {
return mappingUtils.iterableToList(visitRepository.findAll());
}
@Override
public @Nullable Visit get(Long id) {
return visitRepository.findById(id).orElse(null);
}
@Override
public @Nullable Visit delete(Long id) {
Visit visit = visitRepository.findById(id).orElse(null);
if (visit == null)
return null;
visitRepository.deleteById(id);
return visit;
}
@Override
public @Nullable Visit update(Visit other) {
Visit visit = visitRepository.findById(other.getId()).orElse(null);
if (visit == null)
return null;
visit.setEnded(other.isEnded());
return visitRepository.save(visit);
}
}

View File

@ -0,0 +1,60 @@
package com.example.sybd.services;
import com.example.sybd.models.Post;
import com.example.sybd.models.Worker;
import com.example.sybd.repository.WorkerRepository;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.stream.StreamSupport;
@Service
public class WorkerService implements IService<Worker, Long> {
private final WorkerRepository workerRepository;
private final PostService postService;
public WorkerService(WorkerRepository workerRepository,
PostService postService) {
this.workerRepository = workerRepository;
this.postService = postService;
}
public @Nullable Worker create(@NotNull String name,
@NotNull String secondName,
@NotNull String lastName,
@NotNull String telephone,
@NotNull String address,
@NotNull Long post_id) {
Post post = postService.get(post_id);
if (post == null) return null;
Worker out = new Worker();
out.setName(name);
out.setSecondName(secondName);
out.setLastName(lastName);
out.setTelephone(telephone);
out.setAddress(address);
return workerRepository.save(out);
}
@Override
public @NotNull List<Worker> all() {
return StreamSupport.stream(workerRepository.findAll().spliterator(), false).toList();
}
@Override
public @Nullable Worker get(Long aLong) {
return null;
}
@Override
public @Nullable Worker delete(Long aLong) {
return null;
}
@Override
public @Nullable Worker update(Worker other) {
return null;
}
}

View File

@ -0,0 +1,10 @@
package com.example.sybd.utils;
import java.util.List;
import java.util.stream.StreamSupport;
public class mappingUtils {
public static <T> List<T> iterableToList(Iterable<T> iterable) {
return StreamSupport.stream(iterable.spliterator(), false).toList();
}
}

View File

@ -0,0 +1,18 @@
#spring.datasource.url=jdbc:postgresql://192.168.56.101:5432/beautysaloon
#spring.datasource.username=postgres
#spring.datasource.password=posgtres
#
#spring.datasource.driver-class-name=org.postgresql.Driver
#spring.jpa.database=beautysaloon
#spring.jpa.database-platform=org.hibernate.dialect.PostgreSQL10Dialect
spring.thymeleaf.cache=false
spring.datasource.url=jdbc:postgresql://localhost:6666/beautySaloon
spring.datasource.username=postgres
spring.datasource.password=w12344321
spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect
spring.datasource.driver-class-name=org.postgresql.Driver
spring.jpa.hibernate.ddl-auto=validate
spring.jpa.properties.hibernate.globally_quoted_identifiers=true

View File

@ -0,0 +1,24 @@
<!DOCTYPE HTML>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>Spring Boot Thymeleaf Hello World Example</title>
<link rel="stylesheet" th:href="@{webjars/bootstrap/4.2.1/css/bootstrap.min.css}"/>
<link rel="stylesheet" th:href="@{/css/main.css}"/>
</head>
<body>
<main role="main" class="container">
<div class="starter-template">
<h1>Spring Boot Web Thymeleaf Example</h1>
<h2>
<span th:text="'Hello, ' + ${message}"></span>
</h2>
</div>
</main>
<script type="text/javascript" th:src="@{webjars/bootstrap/4.2.1/js/bootstrap.min.js}"></script>
</body>
</html>

View File

@ -0,0 +1,51 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css"
rel="stylesheet"
integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC"
crossorigin="anonymous">
</head>
<body>
<nav class="nav nav-pills flex-row p-2">
<a class="flex-fill text-sm-center nav-link" aria-current="page" href="/new">Новый сотрудник</a>
<a class="flex-fill text-sm-center nav-link" href="/visit">Создать визит</a>
<a class="flex-fill text-sm-center nav-link" href="/services">Услуги</a>
<select class="form-select form-select-sm w-25" aria-label="Сотдрудник">
<option th:each="worker : ${workers}" th:value="${worker.getId()}" th:text="${worker.getName()}"></option>
</select>
</nav>
<main class="mt-5 p-2">
<ul class="list-group">
<li th:each="visit : ${visits}" class="list-group-item">
<div
th:attr="class=${visit.isEnded() ? 'card border-0 bg-success text-white' : 'card border-0 bg-info'}"
>
<div class="card-header">
<h5>
Посещение #<span th:text="${visit.getId().toString()}"></span>
</h5>
</div>
<div class="card-body">
<h6 class="card-text">
<b>Клиент:</b> <span th:text="${visit.getClient().getFio()}"></span>
</h6>
<h6 class="card-text">
<b>Процедура:</b> <span th:text="${visit.getService().getName()}"></span>
</h6>
<p class="card-text">
<b>Дата:</b> <span th:text="${visit.getDateVisit().toString()}"></span>
<b>Время:</b> <span th:text="${visit.getTime().toString()}"></span>
</p>
</div>
<div class="card-footer">
<h6>Цена: <span th:text="${visit.getService().getCost()}"></span>руб.</h6>
</div>
</div>
</li>
</ul>
</main>
</body>
</html>

View File

@ -0,0 +1,20 @@
package com.example.sybd;
import com.example.sybd.repository.ServiceGroupRepository;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class SybdApplicationTests {
@Autowired
private ServiceGroupRepository serviceGroupRepository;
@Test
void contextLoads() {
Object a = serviceGroupRepository.findAll();
Assertions.assertNotNull(a);
}
}