Unify socket_binding and socket_permissions

This commit is contained in:
Caian Benedicto
2024-12-14 06:53:30 -03:00
parent 5f8130fd03
commit 48d2250024
3 changed files with 12 additions and 21 deletions

View File

@@ -249,13 +249,15 @@ Kemal.config.app_name = "Invidious"
Kemal.run do |config|
if CONFIG.socket_binding
if File.exists?(CONFIG.socket_binding.not_nil!)
File.delete(CONFIG.socket_binding.not_nil!)
socket_binding = CONFIG.socket_binding.not_nil!
if File.exists?(socket_binding)
File.delete(socket_binding)
end
# Create a socket and set its desired permissions
server = UNIXServer.new(CONFIG.socket_binding.not_nil!)
perms = CONFIG.socket_permissions.to_i(base: 8)
File.chmod(CONFIG.socket_binding.not_nil!, perms)
tokens = socket_binding.rpartition(',')
server = UNIXServer.new(tokens[0])
perms = tokens[2].to_i(base: 8)
File.chmod(tokens[0], perms)
config.server.not_nil!.bind server
else
Kemal.config.host_binding = Kemal.config.host_binding != "0.0.0.0" ? Kemal.config.host_binding : CONFIG.host_binding

View File

@@ -138,10 +138,8 @@ class Config
property port : Int32 = 3000
# Host to bind (overridden by command line argument)
property host_binding : String = "0.0.0.0"
# Make Invidious listen on a UNIX socket instead of a TCP port - Example: /tmp/invidious.sock
# Path and permissions to make Invidious listen on a UNIX socket instead of a TCP port - Example: /tmp/invidious.sock,777
property socket_binding : String? = nil
# Permissions of the listening socket in octal
property socket_permissions : String = "777"
# Pool size for HTTP requests to youtube.com and ytimg.com (each domain has a separate pool of `pool_size`)
property pool_size : Int32 = 100
# HTTP Proxy configuration