2017-08-08 13:58:51 +02:00
|
|
|
package dht
|
|
|
|
|
2018-12-30 06:24:14 +01:00
|
|
|
import (
|
2019-01-05 19:35:13 +01:00
|
|
|
"net"
|
2018-12-30 06:24:14 +01:00
|
|
|
"time"
|
2019-01-05 19:35:13 +01:00
|
|
|
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
|
|
|
"github.com/boramalper/magnetico/cmd/magneticod/dht/mainline"
|
2018-12-30 06:24:14 +01:00
|
|
|
)
|
2017-08-08 13:58:51 +02:00
|
|
|
|
|
|
|
type TrawlingManager struct {
|
|
|
|
// private
|
2019-05-15 14:18:42 +02:00
|
|
|
output chan Result
|
|
|
|
trawlingServices []*mainline.TrawlingService
|
|
|
|
indexingServices []*mainline.IndexingService
|
2017-08-08 13:58:51 +02:00
|
|
|
}
|
|
|
|
|
2019-01-05 19:35:13 +01:00
|
|
|
type Result interface {
|
|
|
|
InfoHash() [20]byte
|
|
|
|
PeerAddr() *net.TCPAddr
|
|
|
|
}
|
|
|
|
|
2019-05-15 14:18:42 +02:00
|
|
|
func NewTrawlingManager(tsAddrs []string, isAddrs []string, interval time.Duration) *TrawlingManager {
|
2017-08-08 13:58:51 +02:00
|
|
|
manager := new(TrawlingManager)
|
2019-01-05 19:35:13 +01:00
|
|
|
manager.output = make(chan Result, 20)
|
2017-08-08 13:58:51 +02:00
|
|
|
|
2019-05-15 14:18:42 +02:00
|
|
|
// Trawling Services
|
|
|
|
for _, addr := range tsAddrs {
|
|
|
|
service := mainline.NewTrawlingService(
|
2017-10-04 15:07:48 +02:00
|
|
|
addr,
|
2018-07-24 14:41:13 +02:00
|
|
|
2000,
|
2018-12-30 06:24:14 +01:00
|
|
|
interval,
|
2017-10-04 15:07:48 +02:00
|
|
|
mainline.TrawlingServiceEventHandlers{
|
2019-01-05 19:35:13 +01:00
|
|
|
OnResult: manager.onTrawlingResult,
|
2017-10-04 15:07:48 +02:00
|
|
|
},
|
2019-05-15 14:18:42 +02:00
|
|
|
)
|
|
|
|
manager.trawlingServices = append(manager.trawlingServices, service)
|
|
|
|
service.Start()
|
2017-08-08 13:58:51 +02:00
|
|
|
}
|
|
|
|
|
2019-05-15 14:18:42 +02:00
|
|
|
// Indexing Services
|
|
|
|
for _, addr := range isAddrs {
|
|
|
|
service := mainline.NewIndexingService(addr, 2 * time.Second, mainline.IndexingServiceEventHandlers{
|
|
|
|
OnResult: manager.onIndexingResult,
|
|
|
|
})
|
|
|
|
manager.indexingServices = append(manager.indexingServices, service)
|
2017-08-08 13:58:51 +02:00
|
|
|
service.Start()
|
|
|
|
}
|
|
|
|
|
|
|
|
return manager
|
|
|
|
}
|
|
|
|
|
2019-01-05 19:35:13 +01:00
|
|
|
func (m *TrawlingManager) onTrawlingResult(res mainline.TrawlingResult) {
|
|
|
|
select {
|
|
|
|
case m.output <- res:
|
|
|
|
default:
|
2019-05-15 14:18:42 +02:00
|
|
|
// TODO: should be a warn
|
|
|
|
zap.L().Debug("DHT manager output ch is full, result dropped!")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *TrawlingManager) onIndexingResult(res mainline.IndexingResult) {
|
|
|
|
select {
|
|
|
|
case m.output <- res:
|
|
|
|
default:
|
|
|
|
// TODO: should be a warn
|
|
|
|
zap.L().Debug("DHT manager output ch is full, idx result dropped!")
|
2019-01-05 19:35:13 +01:00
|
|
|
}
|
2017-08-08 13:58:51 +02:00
|
|
|
}
|
|
|
|
|
2019-01-05 19:35:13 +01:00
|
|
|
func (m *TrawlingManager) Output() <-chan Result {
|
2017-08-08 13:58:51 +02:00
|
|
|
return m.output
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *TrawlingManager) Terminate() {
|
2019-05-15 14:18:42 +02:00
|
|
|
for _, service := range m.trawlingServices {
|
2017-08-08 13:58:51 +02:00
|
|
|
service.Terminate()
|
|
|
|
}
|
|
|
|
}
|