config
This commit is contained in:
parent
f5d370e3e0
commit
d545e76bfa
3
.gitignore
vendored
3
.gitignore
vendored
@ -1 +1,2 @@
|
|||||||
log.txt
|
log.txt
|
||||||
|
config.yml
|
61
DeleteArr.go
61
DeleteArr.go
@ -8,6 +8,8 @@ import (
|
|||||||
"path/filepath"
|
"path/filepath"
|
||||||
"slices"
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
"gopkg.in/yaml.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type GotifyMessage struct {
|
type GotifyMessage struct {
|
||||||
@ -25,15 +27,49 @@ type MediaFiles struct {
|
|||||||
Arr string
|
Arr string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *MediaFiles) SendGotify(message string, arr string) {
|
type Config struct {
|
||||||
|
Gotify struct {
|
||||||
|
Enabled bool `yaml:"enabled"`
|
||||||
|
ServerURL string `yaml:"server_url"`
|
||||||
|
Token string `yaml:"token"`
|
||||||
|
} `yaml:"gotify"`
|
||||||
|
General struct {
|
||||||
|
RootFolders []string `yaml:"root_folders"`
|
||||||
|
} `yaml:"general"`
|
||||||
|
}
|
||||||
|
|
||||||
http.PostForm("https://gotify.rouggy.com/message?token=AKMj5SsZblmpAJ_",
|
func NewConfig(configPath string) (*Config, error) {
|
||||||
|
// Create config structure
|
||||||
|
config := &Config{}
|
||||||
|
|
||||||
|
// Open config file
|
||||||
|
file, err := os.Open(configPath)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer file.Close()
|
||||||
|
|
||||||
|
// Init new YAML decode
|
||||||
|
d := yaml.NewDecoder(file)
|
||||||
|
|
||||||
|
// Start YAML decoding from file
|
||||||
|
if err := d.Decode(&config); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return config, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MediaFiles) SendGotify(message string, arr string, cfg *Config) {
|
||||||
|
|
||||||
|
http.PostForm(cfg.Gotify.ServerURL+"/message?token="+cfg.Gotify.Token,
|
||||||
url.Values{"message": {message}, "title": {"Deleting Media from " + arr}, "priority": {"10"}})
|
url.Values{"message": {message}, "title": {"Deleting Media from " + arr}, "priority": {"10"}})
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *MediaFiles) IsInFolder() {
|
func (m *MediaFiles) IsInFolder(cfg *Config) {
|
||||||
folderList := []string{"Movies", "4K-Movies", "Series", "4K-Series", "Kids", "Animes"}
|
folderList := cfg.General.RootFolders
|
||||||
|
// []string{"Movies", "4K-Movies", "Series", "4K-Series", "Kids", "Animes"}
|
||||||
|
|
||||||
SplitFolder := strings.Split(m.SourcePath, "/")
|
SplitFolder := strings.Split(m.SourcePath, "/")
|
||||||
LastFolder := SplitFolder[len(SplitFolder)-2]
|
LastFolder := SplitFolder[len(SplitFolder)-2]
|
||||||
@ -54,9 +90,9 @@ func (m *MediaFiles) IsInFolder() {
|
|||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
||||||
// os.Setenv("radarr_moviefile_sourcepath", "/mnt/Multimedia/Download/PostProcess/Movies/Butchers.Crossing.2023.MULTi.1080p.WEB.x264-FW.mkv")
|
os.Setenv("radarr_moviefile_sourcepath", "/mnt/Multimedia/Download/PostProcess/Movies/Butchers.Crossing.2023.MULTi.1080p.WEB.x264-FW.mkv")
|
||||||
// os.Setenv("radarr_moviefile_sourcefolder", "/mnt/Multimedia/Download/PostProcess/Movies")
|
os.Setenv("radarr_moviefile_sourcefolder", "/mnt/Multimedia/Download/PostProcess/Movies")
|
||||||
// os.Setenv("radarr_eventtype", "Download")
|
os.Setenv("radarr_eventtype", "Download")
|
||||||
// os.Setenv("EventType", "Test")
|
// os.Setenv("EventType", "Test")
|
||||||
|
|
||||||
if os.Getenv("radarr_eventtype") == "Test" || os.Getenv("sonarr_eventtype") == "Test" {
|
if os.Getenv("radarr_eventtype") == "Test" || os.Getenv("sonarr_eventtype") == "Test" {
|
||||||
@ -70,6 +106,13 @@ func main() {
|
|||||||
}
|
}
|
||||||
exPath := filepath.Dir(ex)
|
exPath := filepath.Dir(ex)
|
||||||
|
|
||||||
|
configPath := filepath.Join(exPath, "config.yml")
|
||||||
|
|
||||||
|
cfg, err := NewConfig(configPath)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
f, err := os.OpenFile(exPath+"/log.txt", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
|
f, err := os.OpenFile(exPath+"/log.txt", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("error opening file: %v", err)
|
log.Fatalf("error opening file: %v", err)
|
||||||
@ -102,7 +145,7 @@ func main() {
|
|||||||
m.Arr = "Sonarr"
|
m.Arr = "Sonarr"
|
||||||
}
|
}
|
||||||
|
|
||||||
m.IsInFolder()
|
m.IsInFolder(cfg)
|
||||||
|
|
||||||
if m.InFolder {
|
if m.InFolder {
|
||||||
|
|
||||||
@ -143,6 +186,6 @@ func main() {
|
|||||||
log.Printf("Deleting the file %v", m.SourcePath)
|
log.Printf("Deleting the file %v", m.SourcePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
m.SendGotify("Deleting Source Path"+m.SourcePath, m.Arr)
|
m.SendGotify("Deleting Source Path"+m.SourcePath, m.Arr, cfg)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
gotify:
|
gotify:
|
||||||
enabled: false
|
enabled: false
|
||||||
server_url: "https://gotify.url.com"
|
server_url: https://gotify.rouggy.com
|
||||||
token: ""
|
token:
|
||||||
general:
|
general:
|
||||||
root_folders: ["Movies", "4K-Movies", "Series", "4K-Series", "Kids"]
|
root_folders:
|
||||||
|
- Movies
|
||||||
|
- 4K-Movies
|
||||||
|
- Series
|
||||||
|
- 4K-Series
|
||||||
|
- Kids
|
2
go.mod
2
go.mod
@ -1,3 +1,5 @@
|
|||||||
module git.rouggy.com/DeleteArr
|
module git.rouggy.com/DeleteArr
|
||||||
|
|
||||||
go 1.21.4
|
go 1.21.4
|
||||||
|
|
||||||
|
require gopkg.in/yaml.v2 v2.4.0 // indirect
|
||||||
|
3
go.sum
Normal file
3
go.sum
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
|
gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
|
||||||
|
gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
|
Loading…
x
Reference in New Issue
Block a user