ev/app/peerfinder/ev-request.go

243 lines
5.6 KiB
Go
Raw Normal View History

2022-08-23 21:24:13 -06:00
package peerfinder
import (
"bytes"
"encoding/json"
2022-10-25 20:37:59 -06:00
"fmt"
2022-08-23 21:24:13 -06:00
"net/netip"
"strconv"
"time"
"github.com/oklog/ulid"
2023-02-26 22:33:01 -07:00
"go.sour.is/ev/pkg/es/event"
"go.sour.is/ev/pkg/set"
2022-08-23 21:24:13 -06:00
)
2022-11-20 10:28:50 -07:00
type Request struct {
2022-10-30 09:18:08 -06:00
event.AggregateRoot
2022-11-20 10:28:50 -07:00
RequestID string `json:"req_id"`
RequestIP string `json:"req_ip"`
Hidden bool `json:"hide,omitempty"`
Created time.Time `json:"req_created"`
2022-12-19 10:50:38 -07:00
Family int `json:"family"`
2022-10-30 09:18:08 -06:00
2022-12-19 10:50:38 -07:00
Responses []*Response `json:"responses"`
peers set.Set[string]
initial *RequestSubmitted
2022-10-30 09:18:08 -06:00
}
var _ event.Aggregate = (*Request)(nil)
2022-11-20 10:28:50 -07:00
2022-10-30 09:18:08 -06:00
func (a *Request) ApplyEvent(lis ...event.Event) {
for _, e := range lis {
2022-11-20 10:28:50 -07:00
switch e := e.(type) {
2022-10-30 09:18:08 -06:00
case *RequestSubmitted:
2023-04-02 16:45:17 -06:00
a.RequestID = e.EventMeta().EventID.String()
2022-10-30 09:18:08 -06:00
a.RequestIP = e.RequestIP
a.Hidden = e.Hidden
2022-11-20 10:28:50 -07:00
a.Created = ulid.Time(e.EventMeta().EventID.Time())
2022-12-19 10:50:38 -07:00
a.Family = e.Family()
a.initial = e
2022-10-30 09:18:08 -06:00
case *ResultSubmitted:
2022-12-19 10:50:38 -07:00
if a.peers == nil {
a.peers = set.New[string]()
}
if a.peers.Has(e.PeerID) {
continue
}
a.peers.Add(e.PeerID)
a.Responses = append(a.Responses, &Response{
2022-11-20 10:28:50 -07:00
PeerID: e.PeerID,
ScriptVersion: e.PeerVersion,
Latency: e.Latency,
Jitter: e.Jitter,
MinRTT: e.MinRTT,
MaxRTT: e.MaxRTT,
Sent: e.Sent,
Received: e.Received,
Unreachable: e.Unreachable,
Created: ulid.Time(e.EventMeta().EventID.Time()),
})
2022-10-30 09:18:08 -06:00
}
}
}
2022-12-19 10:50:38 -07:00
func (a *Request) MarshalEnviron() ([]byte, error) {
return a.initial.MarshalEnviron()
}
func (a *Request) CreatedString() string {
return a.Created.Format("2006-01-02 15:04:05")
}
type ListRequest []*Request
func (lis ListRequest) Len() int {
return len(lis)
}
func (lis ListRequest) Less(i, j int) bool {
return lis[i].Created.Before(lis[j].Created)
}
func (lis ListRequest) Swap(i, j int) {
lis[i], lis[j] = lis[j], lis[i]
}
2022-10-30 09:18:08 -06:00
type Response struct {
2022-11-20 10:28:50 -07:00
Peer *Peer `json:"peer"`
PeerID string `json:"-"`
ScriptVersion string `json:"peer_scriptver"`
Latency float64 `json:"res_latency"`
Jitter float64 `json:"res_jitter,omitempty"`
MaxRTT float64 `json:"res_maxrtt,omitempty"`
MinRTT float64 `json:"res_minrtt,omitempty"`
Sent int `json:"res_sent,omitempty"`
Received int `json:"res_recv,omitempty"`
Unreachable bool `json:"unreachable,omitempty"`
Created time.Time `json:"res_created"`
2022-10-30 09:18:08 -06:00
}
2022-12-19 10:50:38 -07:00
type ListResponse []*Response
func (lis ListResponse) Len() int {
return len(lis)
}
func (lis ListResponse) Less(i, j int) bool {
if lis[j].Latency == 0.0 && lis[i].Latency > 0.0 {
return true
}
if lis[i].Latency == 0.0 && lis[j].Latency > 0.0 {
2022-12-19 10:50:38 -07:00
return false
}
2023-03-18 19:55:24 -06:00
return lis[j].Latency >= lis[i].Latency
}
func (lis ListResponse) Swap(i, j int) {
lis[i], lis[j] = lis[j], lis[i]
}
2022-10-30 09:18:08 -06:00
type RequestSubmitted struct {
2023-04-02 16:45:17 -06:00
event.IsEvent
2022-08-23 21:24:13 -06:00
RequestIP string `json:"req_ip"`
Hidden bool `json:"hide,omitempty"`
}
2022-10-30 09:18:08 -06:00
func (r *RequestSubmitted) StreamID() string {
2022-08-23 21:24:13 -06:00
return r.EventMeta().GetEventID()
}
2022-10-30 09:18:08 -06:00
func (r *RequestSubmitted) RequestID() string {
2022-08-23 21:24:13 -06:00
return r.EventMeta().GetEventID()
}
2022-10-30 09:18:08 -06:00
func (r *RequestSubmitted) Created() time.Time {
2022-08-23 21:24:13 -06:00
return r.EventMeta().Created()
}
2022-10-30 09:18:08 -06:00
func (r *RequestSubmitted) CreatedString() string {
2022-08-23 21:24:13 -06:00
return r.Created().Format("2006-01-02 15:04:05")
}
2022-10-30 09:18:08 -06:00
func (r *RequestSubmitted) Family() int {
2022-08-23 21:24:13 -06:00
if r == nil {
return 0
}
ip, err := netip.ParseAddr(r.RequestIP)
switch {
case err != nil:
return 0
case ip.Is4():
return 1
default:
return 2
}
}
2022-12-19 10:50:38 -07:00
func (r *RequestSubmitted) String() string {
2023-04-02 16:45:17 -06:00
return fmt.Sprint(r.EventMeta().EventID, r.RequestIP, r.Hidden, r.CreatedString())
2022-12-19 10:50:38 -07:00
}
2022-08-23 21:24:13 -06:00
2022-10-30 09:18:08 -06:00
var _ event.Event = (*RequestSubmitted)(nil)
2022-08-23 21:24:13 -06:00
2022-10-30 09:18:08 -06:00
func (e *RequestSubmitted) MarshalBinary() (text []byte, err error) {
2022-08-23 21:24:13 -06:00
return json.Marshal(e)
}
2022-10-30 09:18:08 -06:00
func (e *RequestSubmitted) UnmarshalBinary(b []byte) error {
2022-08-23 21:24:13 -06:00
return json.Unmarshal(b, e)
}
2022-10-30 09:18:08 -06:00
func (e *RequestSubmitted) MarshalEnviron() ([]byte, error) {
2022-08-23 21:24:13 -06:00
if e == nil {
return nil, nil
}
var b bytes.Buffer
b.WriteString("REQ_ID=")
b.WriteString(e.RequestID())
b.WriteRune('\n')
b.WriteString("REQ_IP=")
b.WriteString(e.RequestIP)
b.WriteRune('\n')
b.WriteString("REQ_FAMILY=")
if family := e.Family(); family > 0 {
b.WriteString(strconv.Itoa(family))
}
b.WriteRune('\n')
b.WriteString("REQ_CREATED=")
b.WriteString(e.CreatedString())
b.WriteRune('\n')
return b.Bytes(), nil
}
2022-10-30 09:18:08 -06:00
type ResultSubmitted struct {
2023-04-02 16:45:17 -06:00
event.IsEvent
2022-08-23 21:24:13 -06:00
RequestID string `json:"req_id"`
PeerID string `json:"peer_id"`
PeerVersion string `json:"peer_version"`
Latency float64 `json:"latency,omitempty"`
2022-11-20 10:28:50 -07:00
Jitter float64 `json:"jitter,omitempty"`
MaxRTT float64 `json:"maxrtt,omitempty"`
MinRTT float64 `json:"minrtt,omitempty"`
Sent int `json:"res_sent,omitempty"`
Received int `json:"res_recv,omitempty"`
Unreachable bool `json:"unreachable,omitempty"`
2022-08-23 21:24:13 -06:00
}
2022-10-30 09:18:08 -06:00
func (r *ResultSubmitted) Created() time.Time {
2023-04-02 16:45:17 -06:00
return r.EventMeta().Created()
2022-08-23 21:24:13 -06:00
}
2022-10-30 09:18:08 -06:00
var _ event.Event = (*ResultSubmitted)(nil)
2022-08-23 21:24:13 -06:00
2022-10-30 09:18:08 -06:00
func (e *ResultSubmitted) MarshalBinary() (text []byte, err error) {
2022-08-23 21:24:13 -06:00
return json.Marshal(e)
}
2022-10-30 09:18:08 -06:00
func (e *ResultSubmitted) UnmarshalBinary(b []byte) error {
2022-08-23 21:24:13 -06:00
return json.Unmarshal(b, e)
}
2022-10-30 09:18:08 -06:00
func (e *ResultSubmitted) String() string {
2022-10-25 20:37:59 -06:00
return fmt.Sprintf("id: %s\npeer: %s\nversion: %s\nlatency: %0.4f", e.RequestID, e.PeerID, e.PeerVersion, e.Latency)
}
2022-12-19 10:50:38 -07:00
type RequestTruncated struct {
RequestID string
2023-04-02 16:45:17 -06:00
event.IsEvent
2022-12-19 10:50:38 -07:00
}
var _ event.Event = (*RequestTruncated)(nil)
func (e *RequestTruncated) MarshalBinary() (text []byte, err error) {
return json.Marshal(e)
}
func (e *RequestTruncated) UnmarshalBinary(b []byte) error {
return json.Unmarshal(b, e)
}
func (e *RequestTruncated) String() string {
return fmt.Sprintf("request truncated id: %s\n", e.RequestID)
}