Compare commits
4 Commits
54aaa80f23
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| c6d1a8d455 | |||
| c8745e1f60 | |||
| ac4b0ef47b | |||
| 879b33d385 |
@@ -2,7 +2,5 @@ scope:
|
|||||||
allow: [info, web, rutracker, prescene, stb, metal-archives, console]
|
allow: [info, web, rutracker, prescene, stb, metal-archives, console]
|
||||||
default: console
|
default: console
|
||||||
mail:
|
mail:
|
||||||
amok.space:
|
|
||||||
dial-tls: mail.amok.space:993
|
|
||||||
kplus.net.ua:
|
kplus.net.ua:
|
||||||
dial-tls: s21.thehost.com.ua:993
|
dial-tls: s21.thehost.com.ua:993
|
||||||
@@ -73,6 +73,6 @@ groups:
|
|||||||
- HiTE
|
- HiTE
|
||||||
- RPO
|
- RPO
|
||||||
- MEOWZiK
|
- MEOWZiK
|
||||||
# - STONERD
|
- STONERD
|
||||||
- TR
|
- TR
|
||||||
- W4GN3R
|
- W4GN3R
|
||||||
|
|||||||
@@ -1,16 +1,16 @@
|
|||||||
role: console
|
role: console
|
||||||
stb:
|
stb:
|
||||||
endpoint: stb@amok.space
|
endpoint: stb@kplus.net.ua
|
||||||
#mailboxes: ["INBOX"]
|
mailboxes: ["INBOX"]
|
||||||
#mailboxes: ["INBOX", "Junk Mail", "Done"]
|
#mailboxes: ["INBOX", "Junk Mail", "Done"]
|
||||||
mailboxes: ["Junk Mail"]
|
#mailboxes: ["Junk Mail"]
|
||||||
#mailboxes: ["Done"]
|
#mailboxes: ["Done"]
|
||||||
search-criteria: ["Your Share The Brutality digest", "noreply@sharethebrutality.info"]
|
search-criteria: ["Your Share The Brutality digest", "noreply@sharethebrutality.info"]
|
||||||
move-processed-to-mailbox:
|
move-processed-to-mailbox:
|
||||||
succeed: Processed/Succeed
|
succeed: Succeed
|
||||||
#succeed: Done
|
#succeed: Done
|
||||||
failed: Processed/Failed
|
failed: Failed
|
||||||
suspicious: Processed/Suspicious
|
suspicious: Suspicious
|
||||||
sender:
|
sender:
|
||||||
mailbox: noreply
|
mailbox: noreply
|
||||||
host: sharethebrutality.info
|
host: sharethebrutality.info
|
||||||
|
|||||||
2
install.sh
Normal file
2
install.sh
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
env GOBIN=/usr/local/bin go install ./cmd
|
||||||
@@ -24,7 +24,7 @@ Commands:
|
|||||||
-section -s Select section e.g.: rutracker, bandcamp etc.
|
-section -s Select section e.g.: rutracker, bandcamp etc.
|
||||||
|
|
||||||
The Go runtime version: %s
|
The Go runtime version: %s
|
||||||
Report bugs to https://git.amok.space/yevhen/resource-scraper/issues`
|
Report bugs to https://git.kplus.net.ua/yevhen/resource-scraper/issues`
|
||||||
|
|
||||||
const (
|
const (
|
||||||
version = "0.1"
|
version = "0.1"
|
||||||
|
|||||||
@@ -68,8 +68,12 @@ func (s *EmailService) Login() {
|
|||||||
|
|
||||||
err := s.client.Login(s.User, s.pass).Wait()
|
err := s.client.Login(s.User, s.pass).Wait()
|
||||||
if s.CheckErr("Login", err) {
|
if s.CheckErr("Login", err) {
|
||||||
|
fmt.Println("========================================")
|
||||||
|
fmt.Println(err.Error())
|
||||||
|
fmt.Println("========================================")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
s.success(s.User + " logged")
|
s.success(s.User + " logged")
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -117,6 +121,7 @@ func (s *EmailService) ListMessages(mailboxes []string, criteria *imap.SearchCri
|
|||||||
}
|
}
|
||||||
|
|
||||||
messages, err := s.client.Fetch(seqSet, fetchOptions).Collect()
|
messages, err := s.client.Fetch(seqSet, fetchOptions).Collect()
|
||||||
|
|
||||||
if s.CheckErr("Fetch", err) {
|
if s.CheckErr("Fetch", err) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@@ -176,7 +181,9 @@ func (s *EmailService) MoveMessageToMailbox(msg *client.FetchMessageBuffer, stat
|
|||||||
movable.AddNum(msg.SeqNum)
|
movable.AddNum(msg.SeqNum)
|
||||||
mailbox := viper.GetStringMapString("stb.move-processed-to-mailbox")
|
mailbox := viper.GetStringMapString("stb.move-processed-to-mailbox")
|
||||||
wait, err := s.client.Move(movable, mailbox[status]).Wait()
|
wait, err := s.client.Move(movable, mailbox[status]).Wait()
|
||||||
|
|
||||||
if s.CheckErr("Moving to archive", err) {
|
if s.CheckErr("Moving to archive", err) {
|
||||||
|
fmt.Println("Error moving to mail:", mailbox[status], "Error:", err.Error())
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -44,7 +44,7 @@ func (s *Prescene) GetPage(pageNumbers []string) ([]model.ExternalSources, error
|
|||||||
endpoint += fmt.Sprintf(viper.GetString(constant.CfgKeyEndpointNext), t)
|
endpoint += fmt.Sprintf(viper.GetString(constant.CfgKeyEndpointNext), t)
|
||||||
}
|
}
|
||||||
|
|
||||||
//doc, err := parser.HTMLSourceFromURL("https://mdb.amok.space/$/scnlog.html")
|
//doc, err := parser.HTMLSourceFromURL("https://mdb.kplus.net.ua /$/scnlog.html")
|
||||||
if result, err := parseUrl(endpoint, s.db); err == nil {
|
if result, err := parseUrl(endpoint, s.db); err == nil {
|
||||||
entries = append(entries, result...)
|
entries = append(entries, result...)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -47,13 +47,10 @@ func (s *ShareTheBrutality) GetMail(email string) ([]model.ExternalSources, *mai
|
|||||||
//now := carbon.Now()
|
//now := carbon.Now()
|
||||||
s.EmailService.ListMessages(viper.GetStringSlice(mailboxes), searchCriteria)
|
s.EmailService.ListMessages(viper.GetStringSlice(mailboxes), searchCriteria)
|
||||||
//box.CreateMailbox("INBOX/Processed")
|
//box.CreateMailbox("INBOX/Processed")
|
||||||
//s.EmailService.CreateMailbox("Processed")
|
|
||||||
//s.EmailService.CreateMailbox("Succeed")
|
//s.EmailService.CreateMailbox("Succeed")
|
||||||
//s.EmailService.CreateMailbox("Processed/Succeed")
|
//s.EmailService.DeleteMailbox("Succeed")
|
||||||
//s.EmailService.DeleteMailbox("Processed")
|
|
||||||
//s.EmailService.CreateMailbox("Processed/Failed")
|
s.EmailService.MailboxesList()
|
||||||
//s.EmailService.CreateMailbox("Processed/Suspicious")
|
|
||||||
//s.EmailService.MailboxesList()
|
|
||||||
|
|
||||||
entries := s.Processing(viper.GetStringMapString(fmt.Sprintf("%s.sender", s.scope)))
|
entries := s.Processing(viper.GetStringMapString(fmt.Sprintf("%s.sender", s.scope)))
|
||||||
|
|
||||||
@@ -144,7 +141,7 @@ func (s *ShareTheBrutality) Processing(sender map[string]string) []model.Externa
|
|||||||
entries = append(entries, es)
|
entries = append(entries, es)
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println(entries)
|
//fmt.Println(entries)
|
||||||
//os.Exit(0)
|
//os.Exit(0)
|
||||||
|
|
||||||
result, status := _table.BatchInsertOnDuplicate(entries, s.db, columns)
|
result, status := _table.BatchInsertOnDuplicate(entries, s.db, columns)
|
||||||
|
|||||||
@@ -67,6 +67,11 @@ func BatchInsertOnDuplicate(entries []model.ExternalSources, db *sqlx.DB, column
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (f *ExternalSources) GetTypeIds(entries []model.ExternalSources, db *sqlx.DB) []int {
|
func (f *ExternalSources) GetTypeIds(entries []model.ExternalSources, db *sqlx.DB) []int {
|
||||||
|
if len(entries) == 0 {
|
||||||
|
fmt.Printf("Entries are empty")
|
||||||
|
return nil // або логування помилки
|
||||||
|
}
|
||||||
|
|
||||||
var typeIds []int
|
var typeIds []int
|
||||||
ids := thither.FieldValueToStrSlice(entries, "TypeId")
|
ids := thither.FieldValueToStrSlice(entries, "TypeId")
|
||||||
query := fmt.Sprintf("SELECT type_id FROM %s WHERE `type` = '%s' AND type_id IN (%s) LIMIT %d", constant.ExternalSourcesTable, entries[0].Type, strings.Join(ids, ","), len(ids))
|
query := fmt.Sprintf("SELECT type_id FROM %s WHERE `type` = '%s' AND type_id IN (%s) LIMIT %d", constant.ExternalSourcesTable, entries[0].Type, strings.Join(ids, ","), len(ids))
|
||||||
|
|||||||
Reference in New Issue
Block a user