Compare commits

...

2 Commits

Author SHA1 Message Date
Dmitry Isaenko 218fa6553e Add postgresql support to pom, create sample stack 4 docker 2024-01-15 21:08:44 +03:00
Dmitry Isaenko abec14663e Correct UI 2024-01-15 21:04:28 +03:00
16 changed files with 104 additions and 42 deletions

6
.gitignore vendored
View File

@ -1,3 +1,5 @@
postgres/docker-compose.yml
docker/deloyment-example/files/library/*
docker/deloyment-example/files/postgresql/*
docker/deloyment-example/files/root/*
target/
lib/
lib/

12
.vscode/launch.json vendored
View File

@ -2,13 +2,23 @@
"configurations": [
{
"type": "java",
"name": "Spring Boot-MarinescoApplication<marinesco>",
"name": "Marinesco DEV",
"request": "launch",
"cwd": "${workspaceFolder}",
"mainClass": "ru.redrise.marinesco.MarinescoApplication",
"projectName": "marinesco",
"args": "",
"envFile": "${workspaceFolder}/.env"
},
{
"type": "java",
"name": "Marinesco PROD",
"request": "launch",
"cwd": "${workspaceFolder}",
"mainClass": "ru.redrise.marinesco.MarinescoApplication",
"projectName": "marinesco",
"args": "--spring.profiles.active=prod",
"envFile": "${workspaceFolder}/.env"
}
]
}

View File

@ -0,0 +1,5 @@
### How to
1. Place `marinesco.jar` to `files/root/`. Rename artifact if needed.
2. Extract `inpx`-file-containing folder into `files/library/`
3. Optionally remove `pgadmin` section from `docker-compose.yml` file
4. Run via `docker compose up`

View File

@ -0,0 +1,9 @@
FROM openjdk:21-jdk-slim
ENV TZ=Europe/Moscow
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
WORKDIR /root
CMD java -jar marinesco.jar

View File

@ -0,0 +1,34 @@
version: '3.1'
services:
marinesco:
build: ./build
image: loper:marinesco
links:
- postgres
ports:
- 80:8080
volumes:
- ./files/root:/root
- ./files/library:/library
environment:
- SPRING_PROFILES_ACTIVE=prod
logging:
driver: syslog
postgres:
image: postgres
volumes:
- ./files/postgresql:/var/lib/postgresql
environment:
- POSTGRES_USER=mari
- POSTGRES_PASSWORD=example
- POSTGRES_DB=marinesco
pgadmin:
image: dpage/pgadmin4
links:
- postgres
ports:
- 3334:80
environment:
- PGADMIN_DEFAULT_EMAIL=root@srv.lan
- PGADMIN_DEFAULT_PASSWORD=example

View File

@ -80,6 +80,12 @@
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<scope>runtime</scope>
</dependency>
</dependencies>
<build>

View File

@ -5,17 +5,12 @@ import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import lombok.extern.slf4j.Slf4j;
@Slf4j
@Controller
@RequestMapping("/")
public class RootController {
@GetMapping
public String getPage(@ModelAttribute("search") String text) {
// TODO: SEARCH PAGE + CONTROLLER
log.info(text);
return "root";
}
}

View File

@ -1,4 +1,4 @@
package ru.redrise.marinesco;
package ru.redrise.marinesco.library;
import java.util.List;
@ -10,8 +10,6 @@ import org.springframework.web.bind.annotation.RequestMapping;
import ru.redrise.marinesco.data.AuthorRepository;
import ru.redrise.marinesco.data.BookRepository;
import ru.redrise.marinesco.library.Author;
import ru.redrise.marinesco.library.Book;
@Controller
@RequestMapping("/author")

View File

@ -1,4 +1,4 @@
package ru.redrise.marinesco;
package ru.redrise.marinesco.library;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
@ -7,7 +7,6 @@ import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import ru.redrise.marinesco.data.BookRepository;
import ru.redrise.marinesco.library.Book;
@Controller
@RequestMapping("/book")

View File

@ -134,22 +134,23 @@ public class InpxScanner implements Runnable {
}
private void parseInp(File inpxFile) throws Exception {
/*
log.warn("REMOVE TEMPORARY SOLUTION - BREAKER");
log.warn("REMOVE TEMPORARY SOLUTION - BREAKER");
log.warn("REMOVE TEMPORARY SOLUTION - BREAKER");
boolean breaker = false;
*/
try (ZipInputStream zipInputStream = new ZipInputStream(new FileInputStream(inpxFile))) {
ZipEntry zipEntry = zipInputStream.getNextEntry();
while (zipEntry != null) {
if (zipEntry.getName().toLowerCase().endsWith(".inp")) {
// *
/*
if (breaker) {
zipEntry = zipInputStream.getNextEntry();
continue;
}
breaker = true;//
breaker = true;
// */
byte[] content = inpToByteArray(zipInputStream, zipEntry.getSize());
parseInpContent(content, zipEntry.getName());

View File

@ -0,0 +1,21 @@
spring:
thymeleaf:
cache: true
datasource:
driver-class-name: org.postgresql.Driver
url: jdbc:postgresql://postgres:5432/marinesco
username: mari
password: example
jpa:
properties:
hibernate:
database-platform: org.hibernate.dialect.PostgreSQL94Dialect
hibernate:
ddl-auto: update
logging:
level:
org:
springframework: INFO
marinesco:
library:
filesLocation: "/library"

View File

@ -156,12 +156,11 @@ header {
color: #74bfbd;
}
.header_entry_link:link {
color: #74bfbd;
}
.header_entry_link:link,
.header_entry_link:visited {
color: #74bfbd;
}
.header_entry_link:hover {
color: #b6a795;
}
@ -175,10 +174,6 @@ header {
margin-right: 10px;
}
a.entry {
text-decoration: none;
}
.header_title {
font-size: 1.5em;
}
@ -262,9 +257,6 @@ button:hover {
text-shadow: -1px -1px 0 #1e1e1e, 1px -1px 0 #1e1e1e, -1px 1px 0 #1e1e1e, 1px 1px 0 #1e1e1e;
color: #74bfbd;
}
.copy_link:hover {
color: #b6a795;
}
/* error */
.error {

View File

@ -21,7 +21,7 @@
<a th:href="${'/author/' + author.id}" th:text="${author.authorName}"></a>
</div>
<br />
<span th:each="genre : ${book.genres}" th:text="${(genre.humanReadableDescription == '' ? genre.genreId : genre.humanReadableDescription) + '&nbsp;&nbsp;'}"></span>
<span th:each="genre : ${book.genres}" th:text="${((genre.humanReadableDescription == null || genre.humanReadableDescription == '') ? genre.genreId : genre.humanReadableDescription) + '&nbsp;&nbsp;'}"></span>
<p>
<a th:href="${'/download/?container=' + book.container + '&file=' + book.fsFileName}"
th:text="${'Download ' + book.fileExtension + ' (' + book.fileSizeForHumans + ')'}"></a>

View File

@ -7,10 +7,8 @@
<body>
<div class="footer" th:fragment="footer">
<div class="container">
<footer class="inner_footer">
<a class="entry" href="https://redrise.ru">
<div class="copy_link">&copy; 2023-2024 Dmitry Isaenko</div>
</a>
<footer class="inner_footer copy_link">
<a class="header_entry_link" href="https://redrise.ru">&copy; 2023-2024 Dmitry Isaenko</a>
</footer>
</div>
</div>

View File

@ -14,9 +14,7 @@
<div class="block_inner">
<ul class="ul_right_block">
<li class="li_header_block">
<a class="entry" href="/login" th:href="@{/login}">
<span class="header_entry header_entry_link">Sign in</span>
</a>
<a class="header_entry header_entry_link" href="/login" th:href="@{/login}">Sign in</a>
</li>
</ul>
</div>
@ -53,9 +51,7 @@
<span class="header_entry">|</span>
</li>
<li class="li_header_block">
<a class="entry" href="/logout">
<span class="header_entry header_entry_link">Logout</span>
</a>
<a class="header_entry header_entry_link" href="/logout">Logout</a>
<form style="visibility: hidden" id="form" method="post" action="#" th:action="@{/logout}"></form>
</li>
</ul>

View File

@ -12,11 +12,7 @@
<div class="page">
<div th:replace="~{fragments/header :: ${#authorization.expression('isAuthenticated()')} ? 'header-auth' : 'header-anon'}"></div>
<div class="container base">
<br /><a href="/book/59992766">/book/59992766</a>
<br /><a href="/author/1">/author/1</a>
<br /><a href="/h2">H2</a>
<br />
Welcome
</div>
</div>
<div th:replace="~{fragments/footer :: 'footer'}"></div>