summaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/files/DataBase.java49
-rw-r--r--src/main/java/files/Parse.java221
-rw-r--r--src/main/java/files/entity/TelegramUser.java43
-rw-r--r--src/main/resources/META-INF/persistence.xml20
4 files changed, 0 insertions, 333 deletions
diff --git a/src/main/java/files/DataBase.java b/src/main/java/files/DataBase.java
deleted file mode 100644
index d457d23..0000000
--- a/src/main/java/files/DataBase.java
+++ /dev/null
@@ -1,49 +0,0 @@
-package files;
-
-import com.pengrad.telegrambot.model.Update;
-import com.pengrad.telegrambot.model.User;
-
-import files.entity.TelegramUser;
-
-import javax.persistence.EntityManager;
-import javax.persistence.EntityManagerFactory;
-import javax.persistence.Persistence;
-import java.text.SimpleDateFormat;
-import java.util.Date;
-
-public class DataBase {
- public static EntityManager connectionCreate() {
- EntityManagerFactory entityManagerFactory = Persistence.createEntityManagerFactory("animarfo");
- return entityManagerFactory.createEntityManager();
- }
-
- public static void connectionDestroy(EntityManager entityManager) {
- entityManager.close();
- }
-
- public static boolean checkIfUserNotExists(Long telegramId) {
- EntityManager manager = connectionCreate();
- return (manager.find(TelegramUser.class, telegramId) == null);
- }
-
- public static void saveUser(Update update) {
- User user = update.message().from();
- Long telegramId = user.id();
- String fullName = user.firstName() + TelegramUser.checkIfHasLastName(user);
- Boolean isBot = user.isBot();
- String username = user.username();
- String date = new SimpleDateFormat("dd.MM.yyyy HH:mm:ss").format(new Date(update.message().date() * 1000L));
-
- if (DataBase.checkIfUserNotExists(telegramId)) {
- EntityManager entityManager = DataBase.connectionCreate();
-
- TelegramUser telegramUser = new TelegramUser(telegramId, username, isBot, fullName, date);
-
- entityManager.getTransaction().begin();
- entityManager.merge(telegramUser);
- entityManager.getTransaction().commit();
-
- DataBase.connectionDestroy(entityManager);
- }
- }
-}
diff --git a/src/main/java/files/Parse.java b/src/main/java/files/Parse.java
deleted file mode 100644
index 031e91e..0000000
--- a/src/main/java/files/Parse.java
+++ /dev/null
@@ -1,221 +0,0 @@
-package files;
-
-import org.jsoup.Jsoup;
-import org.jsoup.nodes.Document;
-import org.jsoup.nodes.Element;
-import org.jsoup.select.Elements;
-
-import java.io.IOException;
-import java.net.URL;
-import java.util.ArrayList;
-
-public class Parse {
- public static Document getPage(String url) throws IOException {
- return Jsoup.parse(new URL(url), 3000);
- }
-
- public static Anime[] getAnimeAtMainMenu(String page, String typeOfAnime) throws IOException {
- Element animeList = Parse.getPage(page).select("div[id=dle-content]").first();
- assert animeList != null;
- Elements namesTemp = animeList.select("div[class=th-title]");
- Elements descriptionsTemp = animeList.select("div[class=th-tip-text]");
- Elements yearsTemp = null;
- if (!typeOfAnime.equals("Ongoing")) yearsTemp = animeList.select("div[class=th-tip-meta fx-row fx-middle fx-start]");
-// Elements genresTemp = animeList.select("span[class=anime-genre d-none d-sm-inline]").select("a[class=mb-2 text-link-gray text-underline]");
- Elements seriesTemp = null;
- if (!typeOfAnime.equals("AnimeFilms")) {
- seriesTemp = animeList.select("div[class=th-title]");
- }
- Elements ratingsTemp = animeList.select("div[class=th-rating]");
- Elements imagesTemp = animeList.select("div[class=th-img img-resp-vert img-fit]");
- Elements urlsTemp = animeList.select("div[class=th-itemb]").select("a[class=th-in]");
-
- byte countOfAnime = (byte) namesTemp.size();
-
- ArrayList<String> names = new ArrayList<>();
- for (Element name : namesTemp) {
- if (!typeOfAnime.equals("AnimeFilms")) {
- String text = Jsoup.parse(String.valueOf(name)).text();
- int start = 0;
- int end = text.indexOf(" [");
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- names.add(String.valueOf(dst));
- } else {
- names.add(Jsoup.parse(String.valueOf(name)).text());
- }
- }
-
- ArrayList<String> descriptions = new ArrayList<>();
- for (Element description : descriptionsTemp) {
- descriptions.add(Jsoup.parse(String.valueOf(description)).text());
- }
-
- ArrayList<String> years = new ArrayList<>();
- if (!typeOfAnime.equals("Ongoing")) {
- for (Element year : yearsTemp) {
- Element yearTemp = year.child(0);
- years.add(Jsoup.parse(String.valueOf(yearTemp)).text());
- }
- }
-
- ArrayList<String> series = new ArrayList<>();
- if (!typeOfAnime.equals("AnimeFilms")) {
- for (Element oneSeries : seriesTemp) {
- String text = oneSeries.toString();
- int start = text.indexOf("из ") + 3;
- if (start == 2) start = text.indexOf("ИЗ ") + 3;
- int end = text.indexOf("]");
- if (start == 2) {
- start = text.indexOf("[") + 1;
- end = text.indexOf(" по") + 1;
- }
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- if (String.valueOf(dst).equals("ххх")) {
- start = text.indexOf("[") + 1;
- end = text.indexOf(" из") - 1;
- }
- series.add(String.valueOf(dst));
- }
- }
-
- ArrayList<String> ratings = new ArrayList<>();
- for (Element rating : ratingsTemp) {
- ratings.add(Jsoup.parse(String.valueOf(rating)).text());
- }
-
- ArrayList<String> images = new ArrayList<>();
- for (Element image : imagesTemp) {
- String text = image.toString();
- int start = text.indexOf("data-src=\"") + 11;
- int end = text.indexOf(".jpg") + 4;
- if (end == 3) {
- end = text.indexOf(".png") + 4;
- }
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- if (!String.valueOf(dst).contains("statics")) {
- images.add("https://online.anidub.com/" + String.valueOf(dst));
- } else {
- images.add("h" + String.valueOf(dst));
- }
- }
-
- ArrayList<String> urls = new ArrayList<>();
- for (Element url : urlsTemp) {
- String text = url.toString();
- int start = text.indexOf("href=\"") + 6;
- int end = text.indexOf("\">");
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- urls.add(String.valueOf(dst));
- }
-
- Anime[] anime = new Anime[countOfAnime];
- for (int i = 0; i < countOfAnime; i++) {
- if (typeOfAnime.equals("AnimeFilms")) {
- anime[i] = new Anime(names.get(i), descriptions.get(i), null, years.get(i), ratings.get(i), images.get(i), urls.get(i));
- } else if (typeOfAnime.equals("Ongoing")) {
- anime[i] = new Anime(names.get(i), descriptions.get(i), null, null, series.get(i), ratings.get(i), images.get(i), urls.get(i));
- } else {
- anime[i] = new Anime(names.get(i), descriptions.get(i), null, years.get(i), series.get(i), ratings.get(i), images.get(i), urls.get(i));
- }
- }
-
- return anime;
- }
-
- public static Anime[] getAnimeAtSearch(String page) throws IOException {
- Element animeList = Parse.getPage(page).select("div[class=animes-grid position-relative]").first();
- assert animeList != null;
- Elements namesTemp = animeList.select("div[class=h5 font-weight-normal mb-2 card-title text-truncate]").select("a");
- Elements descriptionsTemp = animeList.select("div[class=anime-small-description read-more-container]");
- Elements yearsTemp = animeList.select("span[class=anime-year]").select("a");
- Elements seriesTemp = animeList.select("div[class=th-title]");
- Elements maxSeriesTemp = animeList.select("div[class=th-title]");
- Elements ratingsTemp = animeList.select("div[class=th-rating]");
- Elements imagesTemp = animeList.select("div[class=anime-grid-lazy lazy]");
- Elements urlsTemp = animeList.select("div[class=h5 font-weight-normal mb-2 card-title text-truncate]").select("a");
-
- byte countOfAnime = (byte) namesTemp.size();
-
- ArrayList<String> names = new ArrayList<>();
- for (Element name : namesTemp) {
- names.add(Jsoup.parse(String.valueOf(name)).text());
- }
-
- ArrayList<String> descriptions = new ArrayList<>();
- for (Element description : descriptionsTemp) {
- descriptions.add(Jsoup.parse(String.valueOf(description)).text());
- }
-
- ArrayList<String> years = new ArrayList<>();
- for (Element year : yearsTemp) {
- years.add(Jsoup.parse(String.valueOf(year)).text());
- }
-
- ArrayList<String> series = new ArrayList<>();
- for (Element oneSeries : seriesTemp) {
- String text = oneSeries.toString();
- int start = text.indexOf("[") + 1;
- int end = text.indexOf(" из");
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- series.add(String.valueOf(dst));
- }
-
- ArrayList<String> maxSeries = new ArrayList<>();
- for (Element oneMaxSeries : maxSeriesTemp) {
- String text = oneMaxSeries.toString();
- int start = text.indexOf("из ") + 1;
- int end = text.indexOf("]");
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- maxSeries.add(String.valueOf(dst));
- }
-
- ArrayList<String> ratings = new ArrayList<>();
- for (Element rating : ratingsTemp) {
- ratings.add(Jsoup.parse(String.valueOf(rating)).text());
- }
-
- ArrayList<String> images = new ArrayList<>();
- for (Element image : imagesTemp) {
- String text = image.toString();
- int start = text.indexOf("data-original=") + 15;
- int end = text.indexOf(">") - 1;
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- images.add(String.valueOf(dst));
- }
-
- ArrayList<String> urls = new ArrayList<>();
- for (Element url : urlsTemp) {
- String text = url.toString();
- int start = text.indexOf("=\"") + 2;
- int end = text.indexOf("\" title") - 1;
- char[] dst = new char[end - start];
- text.getChars(start, end, dst, 0);
- urls.add(String.valueOf(dst));
- }
-
- Anime[] anime = new Anime[countOfAnime];
- for (int i = 0; i < countOfAnime; i++) {
- anime[i] = new Anime(names.get(i), null, null, years.get(i), series.get(i), ratings.get(i), images.get(i), urls.get(i));
- }
-
- return anime;
- }
-
- public static byte getAnimeAtSearchSize(String page) throws IOException {
- Element animeList = Parse.getPage(page).select("div[class=animes-grid position-relative]").first();
- assert animeList != null;
-
- if (animeList == null) return 0;
-
- Elements namesTemp = animeList.select("div[class=h5 font-weight-normal mb-2 card-title text-truncate]").select("a");
- byte countOfAnime = (byte) namesTemp.size();
- return countOfAnime;
- }
-} \ No newline at end of file
diff --git a/src/main/java/files/entity/TelegramUser.java b/src/main/java/files/entity/TelegramUser.java
deleted file mode 100644
index 5564a64..0000000
--- a/src/main/java/files/entity/TelegramUser.java
+++ /dev/null
@@ -1,43 +0,0 @@
-package files.entity;
-
-import com.pengrad.telegrambot.model.User;
-
-import javax.persistence.Entity;
-import javax.persistence.Id;
-
-@Entity
-public class TelegramUser {
- @Id
- private static Long id;
- private static String username;
- private static Boolean isBot;
- private static String fullName;
- private static String date;
-
- public TelegramUser() {}
-
- public TelegramUser(long id, String username, boolean isBot, String fullName, String date) {
- TelegramUser.id = id;
- TelegramUser.username = username;
- TelegramUser.isBot = isBot;
- TelegramUser.fullName = fullName;
- TelegramUser.date = date;
- }
-
- public static String checkIfHasLastName(User user) {
- String lastName = user.lastName();
- return (lastName != null) ? (" " + lastName) : ("");
- }
-
- public static Long getId() {
- return id;
- }
-
- public static String getUsername() {
- return username;
- }
-
- public static String getFullName() {
- return fullName;
- }
-}
diff --git a/src/main/resources/META-INF/persistence.xml b/src/main/resources/META-INF/persistence.xml
deleted file mode 100644
index 00cb84d..0000000
--- a/src/main/resources/META-INF/persistence.xml
+++ /dev/null
@@ -1,20 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<persistence xmlns="http://java.sun.com/xml/ns/persistence"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
- version="2.0">
-
- <persistence-unit name="animarfo" transaction-type="RESOURCE_LOCAL">
- <provider>org.hibernate.ogm.jpa.HibernateOgmPersistence</provider>
-
- <class>files.entity.TelegramUser</class>
-
- <properties>
- <property name="hibernate.ogm.datastore.provider" value="mongodb"/>
- <property name="hibernate.ogm.datastore.database" value="animarfo"/>
- <property name="hibernate.ogm.datastore.host" value="localhost"/>
- <property name="hibernate.ogm.datastore.create_database" value="true"/>
- </properties>
- </persistence-unit>
-
-</persistence> \ No newline at end of file