Add feed retention configuration option. (#174)

This commit is contained in:
Kavin 2022-01-31 04:17:16 +00:00 committed by GitHub
parent 69504eb808
commit 8880a884c3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 27 additions and 23 deletions

View file

@ -26,6 +26,9 @@ COMPROMISED_PASSWORD_CHECK: true
# Disable Registration # Disable Registration
DISABLE_REGISTRATION: false DISABLE_REGISTRATION: false
# Feed Retention Time in Days
FEED_RETENTION: 30
# Hibernate properties # Hibernate properties
hibernate.connection.url: jdbc:postgresql://postgres:5432/piped hibernate.connection.url: jdbc:postgresql://postgres:5432/piped
hibernate.connection.driver_class: org.postgresql.Driver hibernate.connection.driver_class: org.postgresql.Driver

View file

@ -1,23 +1,23 @@
package me.kavin.piped; package me.kavin.piped;
import java.util.Collections; import io.activej.inject.Injector;
import java.util.List; import me.kavin.piped.consts.Constants;
import java.util.Timer; import me.kavin.piped.utils.DatabaseSessionFactory;
import java.util.TimerTask; import me.kavin.piped.utils.DownloaderImpl;
import java.util.concurrent.TimeUnit; import me.kavin.piped.utils.Multithreading;
import me.kavin.piped.utils.ResponseHelper;
import me.kavin.piped.utils.obj.db.PubSub;
import org.hibernate.Session; import org.hibernate.Session;
import org.hibernate.Transaction; import org.hibernate.Transaction;
import org.hibernate.query.Query; import org.hibernate.query.Query;
import org.schabi.newpipe.extractor.NewPipe; import org.schabi.newpipe.extractor.NewPipe;
import org.schabi.newpipe.extractor.localization.Localization; import org.schabi.newpipe.extractor.localization.Localization;
import io.activej.inject.Injector; import java.util.Collections;
import me.kavin.piped.utils.DatabaseSessionFactory; import java.util.List;
import me.kavin.piped.utils.DownloaderImpl; import java.util.Timer;
import me.kavin.piped.utils.Multithreading; import java.util.TimerTask;
import me.kavin.piped.utils.ResponseHelper; import java.util.concurrent.TimeUnit;
import me.kavin.piped.utils.obj.db.PubSub;
public class Main { public class Main {
@ -70,7 +70,7 @@ public class Main {
tr.begin(); tr.begin();
Query<?> query = s.createQuery("delete from Video where uploaded < :time").setParameter("time", Query<?> query = s.createQuery("delete from Video where uploaded < :time").setParameter("time",
System.currentTimeMillis() - TimeUnit.DAYS.toMillis(10)); System.currentTimeMillis() - TimeUnit.DAYS.toMillis(Constants.FEED_RETENTION));
System.out.println(String.format("Cleanup: Removed %o old videos", query.executeUpdate())); System.out.println(String.format("Cleanup: Removed %o old videos", query.executeUpdate()));

View file

@ -1,5 +1,13 @@
package me.kavin.piped.consts; package me.kavin.piped.consts;
import com.fasterxml.jackson.databind.ObjectMapper;
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenHashMap;
import me.kavin.piped.utils.PageMixin;
import org.apache.commons.lang3.StringUtils;
import org.schabi.newpipe.extractor.NewPipe;
import org.schabi.newpipe.extractor.Page;
import org.schabi.newpipe.extractor.StreamingService;
import java.io.FileReader; import java.io.FileReader;
import java.net.InetSocketAddress; import java.net.InetSocketAddress;
import java.net.ProxySelector; import java.net.ProxySelector;
@ -9,16 +17,6 @@ import java.net.http.HttpClient.Redirect;
import java.net.http.HttpClient.Version; import java.net.http.HttpClient.Version;
import java.util.Properties; import java.util.Properties;
import org.apache.commons.lang3.StringUtils;
import org.schabi.newpipe.extractor.NewPipe;
import org.schabi.newpipe.extractor.Page;
import org.schabi.newpipe.extractor.StreamingService;
import com.fasterxml.jackson.databind.ObjectMapper;
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenHashMap;
import me.kavin.piped.utils.PageMixin;
public class Constants { public class Constants {
public static final String USER_AGENT = "Mozilla/5.0 (Windows NT 10.0; rv:91.0) Gecko/20100101 Firefox/91.0"; public static final String USER_AGENT = "Mozilla/5.0 (Windows NT 10.0; rv:91.0) Gecko/20100101 Firefox/91.0";
@ -45,6 +43,8 @@ public class Constants {
public static final boolean DISABLE_REGISTRATION; public static final boolean DISABLE_REGISTRATION;
public static final int FEED_RETENTION;
public static final ObjectMapper mapper = new ObjectMapper().addMixIn(Page.class, PageMixin.class); public static final ObjectMapper mapper = new ObjectMapper().addMixIn(Page.class, PageMixin.class);
public static final Object2ObjectOpenHashMap<String, String> hibernateProperties = new Object2ObjectOpenHashMap<>(); public static final Object2ObjectOpenHashMap<String, String> hibernateProperties = new Object2ObjectOpenHashMap<>();
@ -66,6 +66,7 @@ public class Constants {
FRONTEND_URL = getProperty(prop, "FRONTEND_URL", "https://piped.kavin.rocks"); FRONTEND_URL = getProperty(prop, "FRONTEND_URL", "https://piped.kavin.rocks");
COMPROMISED_PASSWORD_CHECK = Boolean.parseBoolean(getProperty(prop, "COMPROMISED_PASSWORD_CHECK", "true")); COMPROMISED_PASSWORD_CHECK = Boolean.parseBoolean(getProperty(prop, "COMPROMISED_PASSWORD_CHECK", "true"));
DISABLE_REGISTRATION = Boolean.parseBoolean(getProperty(prop, "DISABLE_REGISTRATION", "false")); DISABLE_REGISTRATION = Boolean.parseBoolean(getProperty(prop, "DISABLE_REGISTRATION", "false"));
FEED_RETENTION = Integer.parseInt(getProperty(prop, "FEED_RETENTION", "30"));
System.getenv().forEach((key, value) -> { System.getenv().forEach((key, value) -> {
if (key.startsWith("hibernate")) if (key.startsWith("hibernate"))
hibernateProperties.put(key, value); hibernateProperties.put(key, value);