Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
550ce91a7f | ||
|
|
9d8f561b54 | ||
|
|
e12299ac20 | ||
|
|
29ae26153f | ||
|
|
8109bb3fa0 | ||
|
|
27605997c1 |
@@ -2,6 +2,7 @@ package broker
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"local/truckstop/config"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -37,7 +38,8 @@ func (j JobLocation) String() string {
|
|||||||
|
|
||||||
func (j Job) FormatMultilineText() string {
|
func (j Job) FormatMultilineText() string {
|
||||||
return fmt.Sprintf(
|
return fmt.Sprintf(
|
||||||
"--- %s => %s ---\nPickup: %s\nDropoff: %s\nNotes: %d lbs, %d miles, %s",
|
"--- %s: %s => %s ---\nPickup: %s\nDropoff: %s\nNotes: %d lbs, %d miles, %s",
|
||||||
|
config.Get().Name,
|
||||||
j.Pickup.State,
|
j.Pickup.State,
|
||||||
j.Dropoff.State,
|
j.Dropoff.State,
|
||||||
j.Pickup.String(),
|
j.Pickup.String(),
|
||||||
|
|||||||
@@ -146,7 +146,7 @@ func (ntg NTGVision) _search(states []config.State) (io.ReadCloser, error) {
|
|||||||
if resp.StatusCode != http.StatusOK {
|
if resp.StatusCode != http.StatusOK {
|
||||||
b, _ := ioutil.ReadAll(resp.Body)
|
b, _ := ioutil.ReadAll(resp.Body)
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
if resp.StatusCode > 400 && resp.StatusCode < 404 {
|
if resp.StatusCode > 400 && resp.StatusCode < 500 && resp.StatusCode != 404 && resp.StatusCode != 410 {
|
||||||
return nil, ErrNoAuth
|
return nil, ErrNoAuth
|
||||||
}
|
}
|
||||||
return nil, fmt.Errorf("bad status searching ntg: %d: %s", resp.StatusCode, b)
|
return nil, fmt.Errorf("bad status searching ntg: %d: %s", resp.StatusCode, b)
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
{
|
{
|
||||||
|
"Name": "pa",
|
||||||
"Interval": {
|
"Interval": {
|
||||||
"OK": "6h0m0s",
|
"OK": "6h0m0s",
|
||||||
"Error": "6h"
|
"Error": "6h",
|
||||||
|
"Email": "15m"
|
||||||
},
|
},
|
||||||
"States": [
|
"States": [
|
||||||
"GA"
|
"GA"
|
||||||
|
|||||||
@@ -10,7 +10,9 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Config struct {
|
type Config struct {
|
||||||
|
Name string
|
||||||
Interval struct {
|
Interval struct {
|
||||||
|
Email Duration
|
||||||
OK Duration
|
OK Duration
|
||||||
Error Duration
|
Error Duration
|
||||||
}
|
}
|
||||||
|
|||||||
21
main.go
21
main.go
@@ -21,16 +21,15 @@ var stateFinder = regexp.MustCompile(`[A-Za-z]+`)
|
|||||||
func main() {
|
func main() {
|
||||||
lock := &sync.Mutex{}
|
lock := &sync.Mutex{}
|
||||||
go func() {
|
go func() {
|
||||||
c := time.NewTicker(time.Minute)
|
for {
|
||||||
for range c.C {
|
time.Sleep(config.Get().Interval.Email.Get())
|
||||||
if !config.Get().EmailerEnabled {
|
if config.Get().EmailerEnabled {
|
||||||
continue
|
lock.Lock()
|
||||||
|
if err := email(); err != nil {
|
||||||
|
log.Print(err)
|
||||||
|
}
|
||||||
|
lock.Unlock()
|
||||||
}
|
}
|
||||||
lock.Lock()
|
|
||||||
if err := email(); err != nil {
|
|
||||||
log.Print(err)
|
|
||||||
}
|
|
||||||
lock.Unlock()
|
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
if err := _main(); err != nil {
|
if err := _main(); err != nil {
|
||||||
@@ -111,12 +110,15 @@ func _main() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func _mainOne() error {
|
func _mainOne() error {
|
||||||
|
log.Println("config.refreshing...")
|
||||||
if err := config.Refresh(); err != nil {
|
if err := config.Refresh(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
log.Println("once...")
|
||||||
if err := once(); err != nil {
|
if err := once(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
log.Println("/_mainOne")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,6 +139,7 @@ func once() error {
|
|||||||
if err := sendJob(jobs[i]); err != nil {
|
if err := sendJob(jobs[i]); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
log.Println("sent job", jobs[i])
|
||||||
if err := config.Get().DB().Set(jobs[i].ID, []byte(`sent`)); err != nil {
|
if err := config.Get().DB().Set(jobs[i].ID, []byte(`sent`)); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,8 +3,13 @@ todo:
|
|||||||
subtasks:
|
subtasks:
|
||||||
- banlist criteria like vendors, brokers, metadata
|
- banlist criteria like vendors, brokers, metadata
|
||||||
- quiet hours
|
- quiet hours
|
||||||
- setup pa on element
|
- setup ma on element
|
||||||
|
- accept states via element for one system
|
||||||
|
- set up copy for caleb, broc
|
||||||
done:
|
done:
|
||||||
|
- setup pa on element
|
||||||
|
- configurable email interval
|
||||||
|
- jitter on intervals, including dedicated err span
|
||||||
- email doesnt get all matches
|
- email doesnt get all matches
|
||||||
- send jobs
|
- send jobs
|
||||||
- read jobs
|
- read jobs
|
||||||
|
|||||||
Reference in New Issue
Block a user