yt-dlp-telegram-bot/params.go
2026-03-02 13:11:38 +08:00

167 lines
4.0 KiB
Go

package main
import (
"flag"
"fmt"
"os"
"strconv"
"strings"
"github.com/dustin/go-humanize"
"github.com/wader/goutubedl"
"golang.org/x/exp/slices"
)
type paramsType struct {
ApiID int
ApiHash string
BotToken string
AllowedUserIDs []int64
AdminUserIDs []int64
AllowedGroupIDs []int64
MaxSize int64
SaveDir string
}
var params paramsType
func (p *paramsType) Init() error {
// Further available environment variables:
// SESSION_FILE: path to session file
// SESSION_DIR: path to session directory, if SESSION_FILE is not set
var apiID string
flag.StringVar(&apiID, "api-id", "", "telegram api_id")
flag.StringVar(&p.ApiHash, "api-hash", "", "telegram api_hash")
flag.StringVar(&p.BotToken, "bot-token", "", "telegram bot token")
flag.StringVar(&goutubedl.Path, "yt-dlp-path", "", "yt-dlp path")
var allowedUserIDs string
flag.StringVar(&allowedUserIDs, "allowed-user-ids", "", "allowed telegram user ids")
var adminUserIDs string
flag.StringVar(&adminUserIDs, "admin-user-ids", "", "admin telegram user ids")
var allowedGroupIDs string
flag.StringVar(&allowedGroupIDs, "allowed-group-ids", "", "allowed telegram group ids")
var maxSize string
flag.StringVar(&maxSize, "max-size", "", "allowed max size of video files")
flag.Parse()
var err error
if apiID == "" {
apiID = os.Getenv("API_ID")
}
if apiID == "" {
return fmt.Errorf("api id not set")
}
p.ApiID, err = strconv.Atoi(apiID)
if err != nil {
return fmt.Errorf("invalid api_id")
}
if p.ApiHash == "" {
p.ApiHash = os.Getenv("API_HASH")
}
if p.ApiHash == "" {
return fmt.Errorf("api hash not set")
}
if p.BotToken == "" {
p.BotToken = os.Getenv("BOT_TOKEN")
}
if p.BotToken == "" {
return fmt.Errorf("bot token not set")
}
if goutubedl.Path == "" {
goutubedl.Path = os.Getenv("YTDLP_PATH")
}
if goutubedl.Path == "" {
goutubedl.Path = "yt-dlp"
}
if allowedUserIDs == "" {
allowedUserIDs = os.Getenv("ALLOWED_USERIDS")
}
sa := strings.Split(allowedUserIDs, ",")
for _, idStr := range sa {
if idStr == "" {
continue
}
id, err := strconv.ParseInt(idStr, 10, 64)
if err != nil {
return fmt.Errorf("allowed user ids contains invalid user ID: " + idStr)
}
p.AllowedUserIDs = append(p.AllowedUserIDs, id)
}
if adminUserIDs == "" {
adminUserIDs = os.Getenv("ADMIN_USERIDS")
}
sa = strings.Split(adminUserIDs, ",")
for _, idStr := range sa {
if idStr == "" {
continue
}
id, err := strconv.ParseInt(idStr, 10, 64)
if err != nil {
return fmt.Errorf("admin ids contains invalid user ID: " + idStr)
}
p.AdminUserIDs = append(p.AdminUserIDs, id)
if !slices.Contains(p.AllowedUserIDs, id) {
p.AllowedUserIDs = append(p.AllowedUserIDs, id)
}
}
if allowedGroupIDs == "" {
allowedGroupIDs = os.Getenv("ALLOWED_GROUPIDS")
}
sa = strings.Split(allowedGroupIDs, ",")
for _, idStr := range sa {
if idStr == "" {
continue
}
id, err := strconv.ParseInt(idStr, 10, 64)
if err != nil {
return fmt.Errorf("allowed group ids contains invalid group ID: " + idStr)
}
p.AllowedGroupIDs = append(p.AllowedGroupIDs, id)
}
if maxSize == "" {
maxSize = os.Getenv("MAX_SIZE")
}
if maxSize != "" {
b, err := humanize.ParseBigBytes(maxSize)
if err != nil {
return fmt.Errorf("invalid max size: %w", err)
}
p.MaxSize = b.Int64()
}
p.SaveDir = os.Getenv("SAVE_DIR")
if p.SaveDir == "" {
p.SaveDir = "/root/save_dir"
}
// Create save directory if it doesn't exist
if err := os.MkdirAll(p.SaveDir, 0755); err != nil {
return fmt.Errorf("couldn't create save directory: %w", err)
}
// Writing env. var YTDLP_COOKIES contents to a file.
// In case a docker container is used, the yt-dlp.conf points yt-dlp to this cookie file.
if cookies := os.Getenv("YTDLP_COOKIES"); cookies != "" {
f, err := os.Create("/tmp/ytdlp-cookies.txt")
if err != nil {
return fmt.Errorf("couldn't create cookies file: %w", err)
}
_, err = f.WriteString(cookies)
if err != nil {
return fmt.Errorf("couldn't write cookies file: %w", err)
}
f.Close()
}
return nil
}