mirror of
https://github.com/kieraneglin/pinchflat.git
synced 2026-01-23 02:24:24 +00:00
* Added a command for updating yt-dlp * Added a yt-dlp update worker to run daily * Added a new file that runs post-boot when the app is ready to serve requests; put yt-dlp updater in there * Updated config to expose the current env globally; updated startup tasks to not run in test env * Removes unneeded test code
168 lines
6.8 KiB
Elixir
168 lines
6.8 KiB
Elixir
import Config
|
|
require Logger
|
|
|
|
# config/runtime.exs is executed for all environments, including
|
|
# during releases. It is executed after compilation and before the
|
|
# system starts, so it is typically used to load production configuration
|
|
# and secrets from environment variables or elsewhere. Do not define
|
|
# any compile-time configuration in here, as it won't be applied.
|
|
# The block below contains prod specific runtime configuration.
|
|
|
|
# ## Using releases
|
|
#
|
|
# If you use `mix release`, you need to explicitly enable the server
|
|
# by passing the PHX_SERVER=true when you start it:
|
|
#
|
|
# PHX_SERVER=true bin/pinchflat start
|
|
#
|
|
# Alternatively, you can use `mix phx.gen.release` to generate a `bin/server`
|
|
# script that automatically sets the env var above.
|
|
if System.get_env("PHX_SERVER") do
|
|
config :pinchflat, PinchflatWeb.Endpoint, server: true
|
|
end
|
|
|
|
config :pinchflat,
|
|
basic_auth_username: System.get_env("BASIC_AUTH_USERNAME"),
|
|
basic_auth_password: System.get_env("BASIC_AUTH_PASSWORD")
|
|
|
|
arch_string = to_string(:erlang.system_info(:system_architecture))
|
|
|
|
system_arch =
|
|
cond do
|
|
String.contains?(arch_string, "arm") -> "arm"
|
|
String.contains?(arch_string, "aarch") -> "arm"
|
|
String.contains?(arch_string, "x86") -> "x86"
|
|
true -> "unknown"
|
|
end
|
|
|
|
config :pinchflat, Pinchflat.Repo,
|
|
load_extensions: [
|
|
Path.join([:code.priv_dir(:pinchflat), "repo", "extensions", "sqlean-linux-#{system_arch}", "sqlean"])
|
|
]
|
|
|
|
# Some users may want to increase the number of workers that use yt-dlp to improve speeds
|
|
# Others may want to decrease the number of these workers to lessen the chance of an IP ban
|
|
{yt_dlp_worker_count, _} = Integer.parse(System.get_env("YT_DLP_WORKER_CONCURRENCY", "2"))
|
|
# Used to set the cron for the yt-dlp update worker. The reason for this is
|
|
# to avoid all instances of PF updating yt-dlp at the same time, which 1)
|
|
# could result in rate limiting and 2) gives me time to react if an update
|
|
# breaks something
|
|
%{hour: current_hour, minute: current_minute} = DateTime.utc_now()
|
|
|
|
config :pinchflat, Oban,
|
|
queues: [
|
|
default: 10,
|
|
fast_indexing: yt_dlp_worker_count,
|
|
media_collection_indexing: yt_dlp_worker_count,
|
|
media_fetching: yt_dlp_worker_count,
|
|
remote_metadata: yt_dlp_worker_count,
|
|
local_data: 8
|
|
],
|
|
plugins: [
|
|
# Keep old jobs for 30 days for display in the UI
|
|
{Oban.Plugins.Pruner, max_age: 30 * 24 * 60 * 60},
|
|
{Oban.Plugins.Cron,
|
|
crontab: [
|
|
{"#{current_minute} #{current_hour} * * *", Pinchflat.YtDlp.UpdateWorker},
|
|
{"0 1 * * *", Pinchflat.Downloading.MediaRetentionWorker},
|
|
{"0 2 * * *", Pinchflat.Downloading.MediaQualityUpgradeWorker}
|
|
]}
|
|
]
|
|
|
|
if config_env() == :prod do
|
|
# Various paths. These ones shouldn't be tweaked if running in Docker
|
|
media_path = System.get_env("MEDIA_PATH", "/downloads")
|
|
config_path = System.get_env("CONFIG_PATH", "/config")
|
|
db_path = System.get_env("DATABASE_PATH", Path.join([config_path, "db", "pinchflat.db"]))
|
|
log_path = System.get_env("LOG_PATH", Path.join([config_path, "logs", "pinchflat.log"]))
|
|
metadata_path = System.get_env("METADATA_PATH", Path.join([config_path, "metadata"]))
|
|
extras_path = System.get_env("EXTRAS_PATH", Path.join([config_path, "extras"]))
|
|
tmpfile_path = System.get_env("TMPFILE_PATH", Path.join([System.tmp_dir!(), "pinchflat", "data"]))
|
|
# This one can be changed if you want
|
|
tz_data_path = System.get_env("TZ_DATA_PATH", Path.join([extras_path, "elixir_tz_data"]))
|
|
# For running PF as a podcast host on self-hosted environments
|
|
expose_feed_endpoints = String.length(System.get_env("EXPOSE_FEED_ENDPOINTS", "")) > 0
|
|
# For testing alternate journal modes (see issue #137)
|
|
journal_mode = String.to_existing_atom(System.get_env("JOURNAL_MODE", "wal"))
|
|
# For running PF in a subdirectory via a reverse proxy
|
|
base_route_path = System.get_env("BASE_ROUTE_PATH", "/")
|
|
enable_ipv6 = String.length(System.get_env("ENABLE_IPV6", "")) > 0
|
|
enable_prometheus = String.length(System.get_env("ENABLE_PROMETHEUS", "")) > 0
|
|
|
|
config :logger, level: String.to_existing_atom(System.get_env("LOG_LEVEL", "debug"))
|
|
|
|
config :pinchflat,
|
|
yt_dlp_executable: System.find_executable("yt-dlp"),
|
|
apprise_executable: System.find_executable("apprise"),
|
|
media_directory: media_path,
|
|
metadata_directory: metadata_path,
|
|
extras_directory: extras_path,
|
|
tmpfile_directory: tmpfile_path,
|
|
dns_cluster_query: System.get_env("DNS_CLUSTER_QUERY"),
|
|
expose_feed_endpoints: expose_feed_endpoints,
|
|
# This is configured in application.ex
|
|
timezone: "UTC",
|
|
log_path: log_path,
|
|
base_route_path: base_route_path
|
|
|
|
config :tzdata, :data_dir, tz_data_path
|
|
|
|
config :pinchflat, Pinchflat.Repo,
|
|
database: db_path,
|
|
journal_mode: journal_mode
|
|
|
|
config :pinchflat, Pinchflat.PromEx, disabled: !enable_prometheus
|
|
|
|
# The secret key base is used to sign/encrypt cookies and other secrets.
|
|
# A default value is used in config/dev.exs and config/test.exs but you
|
|
# want to use a different value for prod and you most likely don't want
|
|
# to check this value into version control, so we use an environment
|
|
# variable instead.
|
|
secret_key_base =
|
|
if System.get_env("SECRET_KEY_BASE") do
|
|
System.get_env("SECRET_KEY_BASE")
|
|
else
|
|
if System.get_env("RUN_CONTEXT") == "selfhosted" do
|
|
# Using the default SECRET_KEY_BASE in a conventional production environment
|
|
# is dangerous. Please set the SECRET_KEY_BASE environment variable if you're
|
|
# deploying this to an internet-facing server. If you're running this in a
|
|
# private network, it's likely safe to use the default value. If you want
|
|
# to be extra safe, run `mix phx.gen.secret` and set the SECRET_KEY_BASE
|
|
# environment variable to the output of that command.
|
|
|
|
"ZkuQMStdmUzBv+gO3m3XZrtQW76e+AX3QIgTLajw3b/HkTLMEx+DOXr2WZsSS+n8"
|
|
else
|
|
raise """
|
|
environment variable SECRET_KEY_BASE is missing.
|
|
You can generate one by calling: mix phx.gen.secret
|
|
"""
|
|
end
|
|
end
|
|
|
|
config :pinchflat, PinchflatWeb.Endpoint,
|
|
http: [
|
|
# Enable IPv6 and bind on all interfaces.
|
|
# Set it to {0, 0, 0, 0, 0, 0, 0, 1} for local network only access.
|
|
# See the documentation on https://hexdocs.pm/plug_cowboy/Plug.Cowboy.html
|
|
# for details about using IPv6 vs IPv4 and loopback vs public addresses.
|
|
ip: if(enable_ipv6, do: {0, 0, 0, 0, 0, 0, 0, 0}, else: {0, 0, 0, 0}),
|
|
port: String.to_integer(System.get_env("PORT") || "4000")
|
|
],
|
|
url: [path: base_route_path],
|
|
secret_key_base: secret_key_base
|
|
|
|
config :pinchflat, :logger, [
|
|
{:handler, :file_log, :logger_std_h,
|
|
%{
|
|
config: %{
|
|
type: :file,
|
|
file: String.to_charlist(log_path),
|
|
filesync_repeat_interval: 5000,
|
|
file_check: 5000,
|
|
max_no_files: 5,
|
|
max_no_bytes: 10_000_000
|
|
},
|
|
formatter: Logger.Formatter.new()
|
|
}}
|
|
]
|
|
end
|