unixSocket

protected open fun unixSocket(value: File): BuilderScopePort(source)

For a TorOption which can be configured to use Unix Sockets, containing the attribute TorOption.Attribute.UNIX_SOCKET.

Unix sockets should always be preferred over using a TCP port (especially for the TorOption.ControlPort and its alternative option names) as Unix Sockets are unaffected by whether the host TCP layer is constrained (e.g. airplane mode, or a VPN).

This sets the argument to the expressed file path, which will be formatted as unix:\"${file-path}\". The value passed is always sanitized via File.absoluteFile + File.normalize before applying final formatting.

e.g.

try {
    unixSocket("/path/to/my/ctrl.sock".toFile())
} catch(_: UnsupportedOperationException) {
    auto()
}

Throws

UnsupportedOperationException

when:

  • Is Windows (tor does not support Unix Sockets on windows).

  • Is Java 15 or below (Jvm only, Android is always available).

  • Configured path is too long.

  • Configured path is multiple lines.