Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
61 changes: 61 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
# See https://www.dartlang.org/guides/libraries/private-files

# IntelliJ related
*.iml
*.ipr
*.iws
.idea/


*.html
*.css
*.rss
*.mvn

*target

# Flutter/Dart/Pub related
**/doc/api/
**/ios/Flutter/.last_build_id
.dart_tool/
.flutter-plugins
.flutter-plugins-dependencies
.packages
.pub-cache/
.pub/
/build/


# Files and directories created by pub
.dart_tool/
.packages
build/

# Android Studio will place build artifacts here
/android/app/debug
/android/app/profile
/android/app/release

### Firebase ###
**/node_modules/*
**/.firebaserc

### Firebase Patch ###
.runtimeconfig.json
.firebase/

# If you're building an application, you may want to check-in your pubspec.lock
pubspec.lock

# Directory created by dartdoc
# If you don't generate documentation locally you can remove this line.
doc/api/

# Avoid committing generated Javascript files:
*.dart.js
*.info.json # Produced by the --dump-info flag.
*.js # When generated by dart2js. Don't specify *.js if your
# project includes source files written in JavaScript.
*.js_
*.js.deps
*.js.map
5 changes: 3 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
# Databases

# Lab 5

JDBC Maven Hibernate JPA
4 changes: 4 additions & 0 deletions lombok.config
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
config.stopBubbling = true
lombok.addLombokGeneratedAnnotation = true
lombok.anyConstructor.addConstructorProperties = true
lombok.addNullAnnotations = <flavor>
138 changes: 138 additions & 0 deletions pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.mkruchok</groupId>
<artifactId>DB5MK</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<url>https://github.com/MKruchok/Databases/tree/lab_5</url>
</properties>

<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-pmd-plugin</artifactId>
<version>3.13.0</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-checkstyle-plugin</artifactId>
<version>3.1.2</version>
<dependencies>
<dependency>
<groupId>com.puppycrawl.tools</groupId>
<artifactId>checkstyle</artifactId>
<version>10.2</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-site-plugin</artifactId>
<version>3.7.1</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-project-info-reports-plugin</artifactId>
<version>3.3.0</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-pmd-plugin</artifactId>
<version>3.13.0</version>
</plugin>
<plugin>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs-maven-plugin</artifactId>
<version>4.4.1</version>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.5.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.24</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.29</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>5.6.8.Final</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.36</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.11</version>
</dependency>
<dependency>
<groupId>com.puppycrawl.tools</groupId>
<artifactId>checkstyle</artifactId>
<version>10.2</version>
</dependency>
<dependency>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs</artifactId>
<version>4.7.0</version>
</dependency>
</dependencies>
<reporting>
<plugins>
<plugin>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs-maven-plugin</artifactId>
<version>4.4.1</version>
<configuration>
<excludeFilterFile>spotbugs-exclude.xml</excludeFilterFile>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-checkstyle-plugin</artifactId>
<version>3.1.2</version>
<configuration>
<configLocation>google_checks.xml</configLocation>
</configuration>
<reportSets>
<reportSet>
<reports>
<report>checkstyle</report>
</reports>
</reportSet>
</reportSets>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-pmd-plugin</artifactId>
<version>3.13.0</version>
</plugin>
</plugins>
</reporting>
</project>
11 changes: 11 additions & 0 deletions spotbugs-exclude.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<FindBugsFilter>
<!-- may expose internal configuration by storing -->
<!-- externally mutable object (Timestamps)-->
<Match>
<Bug pattern="EI_EXPOSE_REP2"/>
</Match>
<Match>
<Bug pattern="EI_EXPOSE_REP"/>
</Match>
</FindBugsFilter>
22 changes: 22 additions & 0 deletions src/main/java/com/mkruchok/App.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package com.mkruchok;

import com.mkruchok.view.View;
import org.hibernate.Session;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public final class App {
static final Logger LOGGER = LoggerFactory.getLogger(App.class);

public static void main(final String[] args) {
System.err.close();
System.setErr(System.out);
try (Session ignored = HibernateUtil.getSession()) {
LOGGER.info("Test session established. ");
new View().show();
} catch (Exception ex) {
LOGGER.warn("Test session failed.");
LOGGER.error(ex.toString());
}
}
}
30 changes: 30 additions & 0 deletions src/main/java/com/mkruchok/HibernateUtil.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package com.mkruchok;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class HibernateUtil {
static final Logger LOGGER = LoggerFactory.getLogger(HibernateUtil.class);
private static final SessionFactory SESSION_FACTORY;

static {
try {
SESSION_FACTORY = new Configuration().configure().buildSessionFactory();
} catch (Exception ex) {
LOGGER.warn("SessionFactory init failed.");
LOGGER.error(ex.toString());
throw new ExceptionInInitializerError(ex);
}
}

public static SessionFactory getSessionFactory() {
return SESSION_FACTORY;
}

public static Session getSession() {
return SESSION_FACTORY.openSession();
}
}
22 changes: 22 additions & 0 deletions src/main/java/com/mkruchok/controller/AbstractController.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package com.mkruchok.controller;

import java.sql.SQLException;
import java.util.List;

public interface AbstractController<E> {

List<E> findAll() throws SQLException;

default E findById(Integer id) {
return null;
}

default void create(E entity) {
}

default void update(Integer id, E entity) {
}

default void delete(Integer id) {
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
package com.mkruchok.controller.implementation;


import com.mkruchok.controller.AbstractController;
import com.mkruchok.model.dao.implementation.AbstractDaoImpl;
import java.util.List;

public abstract class AbstractControllerImpl<E> implements AbstractController<E> {
public abstract AbstractDaoImpl<E> getDao();

@Override
public final List<E> findAll() {
return (List<E>) getDao().findAll();
}

@Override
public final E findById(final Integer id) {
return getDao().findById(id);
}

@Override
public final void create(final E object) {
getDao().create(object);
}

@Override
public final void update(final Integer id, E object) {
getDao().update(id, object);
}

@Override
public final void delete(final Integer id) {
getDao().delete(id);
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.mkruchok.controller.implementation;

import com.mkruchok.model.dao.implementation.AbstractDaoImpl;
import com.mkruchok.model.dao.implementation.DeviceDao;
import com.mkruchok.model.entity.Device;

public final class DeviceController extends AbstractControllerImpl<Device> {

private final DeviceDao deviceDao = new DeviceDao();

@Override
public AbstractDaoImpl<Device> getDao() {
return deviceDao;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.mkruchok.controller.implementation;

import com.mkruchok.model.dao.implementation.AbstractDaoImpl;
import com.mkruchok.model.dao.implementation.DevicesGroupDao;
import com.mkruchok.model.entity.DevicesGroup;


public final class DevicesGroupController extends AbstractControllerImpl<DevicesGroup> {
private final DevicesGroupDao devicesGroupDao = new DevicesGroupDao();

@Override
public AbstractDaoImpl<DevicesGroup> getDao() {
return devicesGroupDao;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.mkruchok.controller.implementation;

import com.mkruchok.model.dao.implementation.AbstractDaoImpl;
import com.mkruchok.model.dao.implementation.HubDao;
import com.mkruchok.model.entity.Hub;

public final class HubController extends AbstractControllerImpl<Hub> {

private final HubDao hubDao = new HubDao();

@Override
public AbstractDaoImpl<Hub> getDao() {
return hubDao;
}
}
Loading