1
0
mirror of https://github.com/mxpv/podsync.git synced 2024-05-11 05:55:04 +00:00
mxpv-podsync/README.md

105 lines
3.1 KiB
Markdown
Raw Normal View History

2019-07-25 18:02:25 -07:00
# Podsync
![Podsync](docs/img/logo.png)
2019-11-16 00:36:38 -08:00
[![](https://github.com/mxpv/podsync/workflows/CI/badge.svg)](https://github.com/mxpv/podsync/actions?query=workflow%3ACI)
[![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/mxpv/podsync)](https://github.com/mxpv/podsync/releases)
2019-07-25 18:02:25 -07:00
[![Go Report Card](https://goreportcard.com/badge/github.com/mxpv/podsync)](https://goreportcard.com/report/github.com/mxpv/podsync)
2019-01-07 21:09:04 -08:00
[![Patreon](https://img.shields.io/badge/support-patreon-E6461A.svg)](https://www.patreon.com/podsync)
2019-11-16 00:36:38 -08:00
[![Twitter Follow](https://img.shields.io/twitter/follow/pod_sync?style=social)](https://twitter.com/pod_sync)
2019-11-13 21:14:52 -08:00
Podsync - is a simple, free service that lets you listen to any YouTube / Vimeo channels, playlists or user videos in
podcast format.
2019-11-13 21:14:52 -08:00
Podcast applications have a rich functionality for content delivery - automatic download of new episodes,
remembering last played position, sync between devices and offline listening. This functionality is not available
on YouTube and Vimeo. So the aim of Podsync is to make your life easier and enable you to view/listen to content on
any device in podcast client.
2019-11-13 21:14:52 -08:00
## Dependencies
If you're running the CLI as binary (e.g. not via Docker), you need to make sure that dependencies are available on
your system. Currently Podsync depends on `youtube-dl` and `ffmpeg`.
On Mac you can install those with `brew`:
```
brew install youtube-dl ffmpeg
```
## Access tokens
In order to query YouTube or Vimeo API you have to obtain an API token first.
- [How to get YouTube API key](https://elfsight.com/help/how-to-get-youtube-api-key/)
- [Generate an access token for Vimeo](https://developer.vimeo.com/api/guides/start#generate-access-token)
## Configuration example
```toml
[server]
port = 8080
data_dir = "/path/to/data/directory"
[tokens]
youtube = "{YOUTUBE_API_TOKEN}"
vimeo = "{VIMEO_API_TOKEN}"
[feeds]
[feeds.ID1]
url = "{FEED_URL}" # URL address of a channel, group, user, or playlist.
page_size = 50 # The number of episodes to query each update (keep in mind, that this might drain API token)
update_period = "12h" # How often query for updates, examples: "60m", "4h", "2h45m"
quality = "high" # or "low"
2019-11-13 23:12:41 -08:00
format = "video" # or "audio"
2019-11-13 21:14:52 -08:00
```
Episodes files will be kept at: `/path/to/data/directory/ID1`, feed will be accessible from: `http://localhost/ID1.xml`
2019-11-13 21:14:52 -08:00
If you want to hide Podsync behind reverse proxy like nginx, you can use `hostname` field:
```toml
[server]
port = 8080
hostname = "https://my.test.host:4443"
[feeds]
[feeds.ID1]
...
```
Server will be accessible from `http://localhost:8080`, but episode links will point to `https://my.test.host:4443/ID1/...`
2019-11-13 21:14:52 -08:00
## How to run
Run as binary:
```
$ ./podsync --config config.toml
```
Run via Docker:
```
$ docker pull mxpv/podsync:latest
$ docker run \
-p 8080:8080 \
-v $(pwd)/data:/app/data/ \
-v $(pwd)/config.toml:/app/config.toml \
mxpv/podsync:latest
```
Run via Docker Compose:
```
$ docker-compose up
```
## How to make a release
2019-11-13 20:43:47 -08:00
- Add and push version tag
```
$ git tag -a v0.1.0 -m "First release"
2019-11-13 20:49:25 -08:00
$ git push origin --tags
2019-11-13 20:43:47 -08:00
```
- Run GoReleaser at the root of your repository:
```
2019-11-23 13:54:29 -08:00
$ make release
2019-11-13 20:43:47 -08:00
```