2017-09-27 20:10:41 +02:00
|
|
|
package cmd
|
2017-09-15 13:58:54 +02:00
|
|
|
|
2017-09-16 00:13:13 +02:00
|
|
|
import (
|
2018-03-09 17:47:38 +01:00
|
|
|
"github.com/lbryio/lbry.go/errors"
|
2017-10-11 04:02:16 +02:00
|
|
|
sync "github.com/lbryio/lbry.go/ytsync"
|
2017-09-15 13:58:54 +02:00
|
|
|
|
2018-04-26 12:12:54 +02:00
|
|
|
"fmt"
|
|
|
|
"github.com/lbryio/lbry.go/util"
|
2017-09-16 00:13:13 +02:00
|
|
|
log "github.com/sirupsen/logrus"
|
2017-09-27 20:10:41 +02:00
|
|
|
"github.com/spf13/cobra"
|
2018-04-26 12:12:54 +02:00
|
|
|
"io/ioutil"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"strings"
|
2017-09-16 00:13:13 +02:00
|
|
|
)
|
|
|
|
|
2017-09-27 20:10:41 +02:00
|
|
|
func init() {
|
|
|
|
var ytSyncCmd = &cobra.Command{
|
2017-12-30 01:21:16 +01:00
|
|
|
Use: "ytsync <youtube_api_key> <lbry_channel_name> [<youtube_channel_id>]",
|
2017-09-27 20:10:41 +02:00
|
|
|
Args: cobra.RangeArgs(2, 3),
|
|
|
|
Short: "Publish youtube channel into LBRY network.",
|
|
|
|
Run: ytsync,
|
|
|
|
}
|
2017-10-11 02:53:11 +02:00
|
|
|
ytSyncCmd.Flags().BoolVar(&stopOnError, "stop-on-error", false, "If a publish fails, stop all publishing and exit")
|
|
|
|
ytSyncCmd.Flags().IntVar(&maxTries, "max-tries", defaultMaxTries, "Number of times to try a publish that fails")
|
2017-11-06 22:42:52 +01:00
|
|
|
ytSyncCmd.Flags().BoolVar(&takeOverExistingChannel, "takeover-existing-channel", false, "If channel exists and we don't own it, take over the channel")
|
2018-03-12 21:58:37 +01:00
|
|
|
ytSyncCmd.Flags().IntVar(&refill, "refill", 0, "Also add this many credits to the wallet")
|
2017-09-27 20:10:41 +02:00
|
|
|
RootCmd.AddCommand(ytSyncCmd)
|
2018-04-26 12:12:54 +02:00
|
|
|
slackToken := os.Getenv("SLACK_TOKEN")
|
|
|
|
if slackToken == "" {
|
|
|
|
log.Error("A slack token was not present in env vars! Slack messages disabled!")
|
|
|
|
} else {
|
|
|
|
util.InitSlack(os.Getenv("SLACK_TOKEN"))
|
|
|
|
}
|
2017-09-27 20:10:41 +02:00
|
|
|
}
|
|
|
|
|
2017-12-30 01:21:16 +01:00
|
|
|
const defaultMaxTries = 3
|
2017-09-27 01:48:10 +02:00
|
|
|
|
2017-09-16 00:13:13 +02:00
|
|
|
var (
|
2017-11-06 22:42:52 +01:00
|
|
|
stopOnError bool
|
|
|
|
maxTries int
|
|
|
|
takeOverExistingChannel bool
|
2018-03-12 21:58:37 +01:00
|
|
|
refill int
|
2017-09-16 00:13:13 +02:00
|
|
|
)
|
|
|
|
|
2018-04-26 12:12:54 +02:00
|
|
|
//PoC
|
|
|
|
func fetchChannels() {
|
|
|
|
url := "http://localhost:8080/yt/jobs"
|
|
|
|
payload := strings.NewReader("------WebKitFormBoundary7MA4YWxkTrZu0gW\r\nContent-Disposition: form-data; name=\"auth_token\"\r\n\r\n620280\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW--")
|
|
|
|
req, _ := http.NewRequest("POST", url, payload)
|
|
|
|
req.Header.Add("content-type", "multipart/form-data")
|
|
|
|
res, _ := http.DefaultClient.Do(req)
|
|
|
|
defer res.Body.Close()
|
|
|
|
body, _ := ioutil.ReadAll(res.Body)
|
|
|
|
fmt.Println(res)
|
|
|
|
fmt.Println(string(body))
|
|
|
|
}
|
|
|
|
|
2017-09-27 20:10:41 +02:00
|
|
|
func ytsync(cmd *cobra.Command, args []string) {
|
2017-10-11 04:02:16 +02:00
|
|
|
ytAPIKey := args[0]
|
2017-12-30 01:21:16 +01:00
|
|
|
lbryChannelName := args[1]
|
|
|
|
if string(lbryChannelName[0]) != "@" {
|
|
|
|
log.Errorln("LBRY channel name must start with an @")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
channelID := ""
|
2017-09-27 20:10:41 +02:00
|
|
|
if len(args) > 2 {
|
2017-12-30 01:21:16 +01:00
|
|
|
channelID = args[2]
|
2017-09-16 00:13:13 +02:00
|
|
|
}
|
|
|
|
|
2017-10-11 02:53:11 +02:00
|
|
|
if stopOnError && maxTries != defaultMaxTries {
|
|
|
|
log.Errorln("--stop-on-error and --max-tries are mutually exclusive")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if maxTries < 1 {
|
|
|
|
log.Errorln("setting --max-tries less than 1 doesn't make sense")
|
2017-10-04 16:31:03 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2017-10-11 04:02:16 +02:00
|
|
|
s := sync.Sync{
|
2017-11-06 22:42:52 +01:00
|
|
|
YoutubeAPIKey: ytAPIKey,
|
|
|
|
YoutubeChannelID: channelID,
|
|
|
|
LbryChannelName: lbryChannelName,
|
|
|
|
StopOnError: stopOnError,
|
|
|
|
MaxTries: maxTries,
|
|
|
|
ConcurrentVideos: 1,
|
|
|
|
TakeOverExistingChannel: takeOverExistingChannel,
|
2018-03-12 21:58:37 +01:00
|
|
|
Refill: refill,
|
2017-09-19 20:14:52 +02:00
|
|
|
}
|
|
|
|
|
2017-11-03 13:46:27 +01:00
|
|
|
err := s.FullCycle()
|
2017-12-30 01:21:16 +01:00
|
|
|
|
2017-09-16 00:13:13 +02:00
|
|
|
if err != nil {
|
2018-03-09 17:47:38 +01:00
|
|
|
log.Error(errors.FullTrace(err))
|
2017-09-16 00:13:13 +02:00
|
|
|
}
|
2017-09-15 13:58:54 +02:00
|
|
|
}
|