2016-06-02 14:16:02 +02:00
|
|
|
// Copyright (C) 2015 Audrius Butkevicius and Contributors.
|
2015-09-07 09:21:23 +01:00
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"io/ioutil"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"net/url"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2016-08-23 08:43:27 +02:00
|
|
|
func poolHandler(pool string, uri *url.URL, mapping mapping) {
|
2015-09-21 22:33:29 +01:00
|
|
|
if debug {
|
|
|
|
log.Println("Joining", pool)
|
|
|
|
}
|
2015-09-07 09:21:23 +01:00
|
|
|
for {
|
2016-08-23 08:43:27 +02:00
|
|
|
uriCopy := *uri
|
|
|
|
uriCopy.Host = mapping.Address().String()
|
|
|
|
|
2015-09-07 09:21:23 +01:00
|
|
|
var b bytes.Buffer
|
|
|
|
json.NewEncoder(&b).Encode(struct {
|
|
|
|
URL string `json:"url"`
|
|
|
|
}{
|
2016-08-23 08:43:27 +02:00
|
|
|
uriCopy.String(),
|
2015-09-07 09:21:23 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
resp, err := http.Post(pool, "application/json", &b)
|
|
|
|
if err != nil {
|
2015-11-06 12:58:44 +00:00
|
|
|
log.Println("Error joining pool", pool, err)
|
2015-09-07 09:21:23 +01:00
|
|
|
} else if resp.StatusCode == 500 {
|
2015-12-07 11:11:01 +00:00
|
|
|
bs, err := ioutil.ReadAll(resp.Body)
|
|
|
|
if err != nil {
|
|
|
|
log.Println("Failed to join", pool, "due to an internal server error. Could not read response:", err)
|
2015-11-06 12:58:44 +00:00
|
|
|
} else {
|
2015-12-07 11:11:01 +00:00
|
|
|
log.Println("Failed to join", pool, "due to an internal server error:", string(bs))
|
2015-09-07 09:21:23 +01:00
|
|
|
}
|
2015-12-07 11:11:01 +00:00
|
|
|
resp.Body.Close()
|
2015-09-07 09:21:23 +01:00
|
|
|
} else if resp.StatusCode == 429 {
|
2015-11-06 12:58:44 +00:00
|
|
|
log.Println(pool, "under load, will retry in a minute")
|
2015-09-07 09:21:23 +01:00
|
|
|
time.Sleep(time.Minute)
|
|
|
|
continue
|
2016-08-23 08:43:27 +02:00
|
|
|
} else if resp.StatusCode == 401 {
|
2015-11-06 12:58:44 +00:00
|
|
|
log.Println(pool, "failed to join due to IP address not matching external address. Aborting")
|
2015-09-07 18:12:18 +01:00
|
|
|
return
|
2015-09-07 09:21:23 +01:00
|
|
|
} else if resp.StatusCode == 200 {
|
|
|
|
var x struct {
|
|
|
|
EvictionIn time.Duration `json:"evictionIn"`
|
|
|
|
}
|
|
|
|
err := json.NewDecoder(resp.Body).Decode(&x)
|
|
|
|
if err == nil {
|
|
|
|
rejoin := x.EvictionIn - (x.EvictionIn / 5)
|
2015-09-21 22:33:29 +01:00
|
|
|
log.Println("Joined", pool, "rejoining in", rejoin)
|
2015-09-07 09:21:23 +01:00
|
|
|
time.Sleep(rejoin)
|
|
|
|
continue
|
2015-11-06 12:58:44 +00:00
|
|
|
} else {
|
2015-09-21 22:33:29 +01:00
|
|
|
log.Println("Failed to deserialize response", err)
|
2015-09-07 09:21:23 +01:00
|
|
|
}
|
2015-11-06 12:58:44 +00:00
|
|
|
} else {
|
|
|
|
log.Println(pool, "unknown response type from server", resp.StatusCode)
|
2015-09-07 09:21:23 +01:00
|
|
|
}
|
|
|
|
time.Sleep(time.Hour)
|
|
|
|
}
|
|
|
|
}
|