Skip to content

alexballas/go2tv

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation


Go2TV logo


Go Report Card Release Version Tests

Build for ARMv6 (32-bit) Build for ARMv8 (64-bit) Build for Android Build for Linux Build for MacOS Intel Build for MacOS Apple Silicon Build for Windows

Cast your media files to UPnP/DLNA Media Renderers and Smart TVs.

GUI mode

CLI mode

Parameters

$ go2tv -h
Usage of go2tv:
  -l    List all available UPnP/DLNA Media Renderer models and URLs.
  -s string
        Local path to the subtitles file.
  -t string
        Cast to a specific UPnP/DLNA Media Renderer URL.
  -tc
        Use ffmpeg to transcode input video file.
  -u string
        HTTP URL to the media file. URL streaming does not support seek operations. (Triggers the CLI mode)
  -v string
        Local path to the video/audio file. (Triggers the CLI mode)
  -version
        Print version.

Allowed media files in the GUI

  • mp4, avi, mkv, mpeg, mov, webm, m4v, mpv, mp3, flac, wav, jpg, jpeg, png

This is a GUI only limitation.

Build requirements and dependencies

  • Go v1.23+
  • ffmpeg (optional)

Build using Docker

Since the repo provides a Dockerfile, you can build a Go2TV Docker image and run it with just Docker installed (no build requirements and deps above needed). Also, no Git repo cloning is needed (Docker will do it behind the scenes). Just issue:

$ docker build --force-rm [--pull] -t go2tv github.com/alexballas/go2tv#main

Notice the branch name after the #, as the above will build main. You can also build devel if you want to build the latest code. Usage under Docker is outside this document's scope, check Docker docs for more information, specially volume mounts and networking. x11docker might come handy to run GUI mode, although it's not tested, since main Docker usage is CLI.

Running using Docker

Example:

$ xhost +local:docker  # Allows Docker containers to connect to the X server
$ docker run -it --network host -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix go2tv go2tv

Quick Start

Download the app here https://github.com/alexballas/Go2TV/releases/latest. A single executable. No installation or external dependencies.

Transcoding (ffmpeg required)

Go2TV supports live video transcoding, if ffmpeg is installed. When transcoding, SEEK operations are not available. Transcoding offers the maximum compatibility with the various file formats and devices. Only works with video files. Note: The Flatpak version of Go2TV bundles ffmpeg.

MKV/MP4 Subtitle Selection Support (ffmpeg required)

Go2TV also supports selecting subtitles for video files that have embedded subtitle tracks. This functionality requires ffmpeg to be installed. You can choose the desired subtitle track when casting your media files, enhancing your viewing experience on UPnP/DLNA Media Renderers and Smart TVs.

MacOS potential issues

If you get the "cannot be opened because the developer cannot be verified" error, you can apply the following workaround.

  • Control-click the app icon, then choose Open from the shortcut menu.
  • Click Open.

If you get the "go2tv is damaged and can't be opened. You should move it to the Bin." error you can apply the following workaround.

  • Launch Terminal and then issue the following command: xattr -cr /path/to/go2tv.app.

Tested on

  • Samsung UE50JU6400
  • Samsung UE65KS7000
  • Android - BubbleUPnP app

Author

Alexandros Ballas [email protected]