Documentation ¶
Index ¶
- Constants
- Variables
- func CreateHubSignet(toolID string, securityLevel int) (private, public *jess.Signet, err error)
- func LanesEqual(a, b []*Lane) bool
- func MakeHubDBKey(mapName, hubID string) string
- func MakeHubMsgDBKey(mapName string, msgType MsgType, hubID string) string
- func QueryRawGossipMsgs(mapName string, msgType MsgType) (it *iterator.Iterator, err error)
- func RemoveHubAndMsgs(mapName string, hubID string) (err error)
- func SaveHubMsg(id string, mapName string, msgType MsgType, data []byte) error
- func SetNavigatorAccess(fn func(mapName, hubID string) *Hub)
- func SignHubMsg(msg []byte, env *jess.Envelope, enableTofu bool) ([]byte, error)
- func SortLanes(l []*Lane)
- type Announcement
- type Hub
- func ApplyAnnouncement(existingHub *Hub, data []byte, mapName string, scope Scope, selfcheck bool) (hub *Hub, known, changed bool, err error)
- func ApplyStatus(existingHub *Hub, data []byte, mapName string, scope Scope, selfcheck bool) (hub *Hub, known, changed bool, err error)
- func EnsureHub(r record.Record) (*Hub, error)
- func GetHub(mapName string, hubID string) (*Hub, error)
- func GetHubByKey(key string) (*Hub, error)
- func OpenHubMsg(hub *Hub, data []byte, mapName string, tofu bool) (msg []byte, sendingHub *Hub, known bool, err error)
- func ParseBootstrapHub(bootstrapTransport string, mapName string) (*Hub, error)
- func (h *Hub) AddLane(newLane *Lane) error
- func (h *Hub) GetInfo() *Announcement
- func (h *Hub) GetLaneTo(hubID string) *Lane
- func (h *Hub) GetMeasurements() *Measurements
- func (h *Hub) GetMeasurementsWithLockedHub() *Measurements
- func (h *Hub) GetSignet(id string, recipient bool) (*jess.Signet, error)
- func (h *Hub) GetStatus() *Status
- func (h *Hub) Name() string
- func (h *Hub) Obsolete() bool
- func (h *Hub) RemoveLane(hubID string) error
- func (h *Hub) Save() error
- func (h *Hub) SelectSignet() *jess.Signet
- func (h *Hub) String() string
- func (h *Hub) StringWithoutLocking() string
- func (h *Hub) Verified() bool
- type HubMsg
- type InfoOverride
- type Intel
- type Key
- type Lane
- type Measurements
- func (m *Measurements) Copy() *Measurements
- func (m *Measurements) Expired(ttl time.Duration) bool
- func (m *Measurements) GetCalculatedCost() (cost float32)
- func (m *Measurements) GetCapacity() (capacity int, measuredAt time.Time)
- func (m *Measurements) GetGeoProximity() (geoProximity float32)
- func (m *Measurements) GetLatency() (latency time.Duration, measuredAt time.Time)
- func (m *Measurements) IsPersisted() bool
- func (m *Measurements) SetCalculatedCost(cost float32)
- func (m *Measurements) SetCapacity(capacity int)
- func (m *Measurements) SetGeoProximity(geoProximity float32)
- func (m *Measurements) SetLatency(latency time.Duration)
- func (m *Measurements) Valid() bool
- type MsgType
- type ParsedIntel
- type RegionConfig
- type Scope
- type SingleTrustStore
- type Status
- type Transport
- type VirtualNetworkConfig
Constants ¶
const ( MsgTypeAnnouncement = "announcement" MsgTypeStatus = "status" )
Message Types.
const MaxCalculatedCost = 1000000
MaxCalculatedCost specifies the max calculated cost to be used for an unknown high cost.
const VersionOffline = "offline"
VersionOffline is a special version used to signify that the Hub has gone offline.
Variables ¶
var ( // ErrMissingInfo signifies that the hub is missing the HubAnnouncement. ErrMissingInfo = errors.New("hub is missing Announcement") // ErrMissingTransports signifies that the hub announcement did not specify any transports. ErrMissingTransports = errors.New("hub announcement is missing transports") // ErrMissingIPs signifies that the hub announcement did not specify any IPs. ErrMissingIPs = errors.New("hub announcement is missing IPs") // ErrTemporaryValidationError is returned when a validation error might be temporary. ErrTemporaryValidationError = errors.New("temporary validation error") // ErrOldData is returned when received data is outdated. ErrOldData = errors.New("") )
var BaselineCharset = regexp.MustCompile(
`^[` +
` !#()*+,\-\./0-9:=?@A-Z[\]^_a-z{|}~` +
`ŠŒŽšœžŸ¡¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿ` +
`]*$`,
)
BaselineCharset defines the permitted characters.
Functions ¶
func CreateHubSignet ¶
CreateHubSignet creates a signet with the correct ID for usage as a Hub Identity.
func LanesEqual ¶ added in v0.3.0
LanesEqual returns whether the given []*Lane are equal.
func MakeHubDBKey ¶ added in v0.3.0
MakeHubDBKey makes a hub db key.
func MakeHubMsgDBKey ¶ added in v0.3.0
MakeHubMsgDBKey makes a hub msg db key.
func QueryRawGossipMsgs ¶ added in v0.3.0
QueryRawGossipMsgs queries the database for raw gossip messages.
func RemoveHubAndMsgs ¶ added in v0.3.13
RemoveHubAndMsgs deletes a Hub and it's saved messages from the database.
func SaveHubMsg ¶ added in v0.3.0
SaveHubMsg saves a raw (and signed) message received by another Hub.
func SetNavigatorAccess ¶
SetNavigatorAccess sets a shortcut function to access hubs from the navigator instead of having go through the database. This also reduces the number of object in RAM and better caches parsed attributes.
func SignHubMsg ¶
SignHubMsg signs the given serialized hub msg with the given configuration.
Types ¶
type Announcement ¶ added in v0.3.0
type Announcement struct { // Primary Key // hash of public key // must be checked if it matches the public key ID string // via jess.LabeledHash // PublicKey *jess.Signet // PublicKey // if not part of signature // Signature *jess.Letter Timestamp int64 // Unix timestamp in seconds // Node Information Name string // name of the node Group string // person or organisation, who is in control of the node (should be same for all nodes of this person or organisation) ContactAddress string // contact possibility (recommended, but optional) ContactService string // type of service of the contact address, if not email // currently unused, but collected for later use Hosters []string // hoster supply chain (reseller, hosting provider, datacenter operator, ...) Datacenter string // datacenter will be bullshit checked // Network Location and Access // If node is behind NAT (or similar), IP addresses must be configured IPv4 net.IP // must be global and accessible IPv6 net.IP // must be global and accessible Transports []string // Policies - default permit Entry []string // {"+ ", "- *"} Exit []string // contains filtered or unexported fields }
Announcement is the main message type to publish Hub Information. This only changes if updated manually.
func (*Announcement) Copy ¶ added in v0.3.0
func (a *Announcement) Copy() (*Announcement, error)
Copy returns a deep copy of the Announcement.
func (*Announcement) EntryPolicy ¶ added in v0.4.3
func (a *Announcement) EntryPolicy() endpoints.Endpoints
EntryPolicy returns the Hub's entry policy.
func (*Announcement) Equal ¶ added in v0.3.0
func (a *Announcement) Equal(b *Announcement) bool
Equal returns whether the given Announcements are equal.
func (*Announcement) ExitPolicy ¶ added in v0.4.3
func (a *Announcement) ExitPolicy() endpoints.Endpoints
ExitPolicy returns the Hub's exit policy.
type Hub ¶
type Hub struct { sync.Mutex record.Base ID string PublicKey *jess.Signet Map string Info *Announcement Status *Status Measurements *Measurements FirstSeen time.Time VerifiedIPs bool InvalidInfo bool InvalidStatus bool // contains filtered or unexported fields }
Hub represents a network node in the SPN.
func ApplyAnnouncement ¶ added in v0.3.0
func ApplyAnnouncement(existingHub *Hub, data []byte, mapName string, scope Scope, selfcheck bool) (hub *Hub, known, changed bool, err error)
ApplyAnnouncement applies the announcement to the Hub if it passes all the checks. If no Hub is provided, it is loaded from the database or created.
func ApplyStatus ¶ added in v0.3.0
func ApplyStatus(existingHub *Hub, data []byte, mapName string, scope Scope, selfcheck bool) (hub *Hub, known, changed bool, err error)
ApplyStatus applies a status update if it passes all the checks.
func GetHubByKey ¶ added in v0.3.0
GetHubByKey returns a hub by its raw DB key.
func OpenHubMsg ¶
func OpenHubMsg(hub *Hub, data []byte, mapName string, tofu bool) (msg []byte, sendingHub *Hub, known bool, err error)
OpenHubMsg opens a signed hub msg and verifies the signature using the provided hub or the local database. If TOFU is enabled, the signature is always accepted, if valid.
func ParseBootstrapHub ¶ added in v0.3.0
ParseBootstrapHub parses a bootstrap hub.
func (*Hub) GetInfo ¶ added in v0.3.0
func (h *Hub) GetInfo() *Announcement
GetInfo returns the hub info.
func (*Hub) GetMeasurements ¶ added in v0.3.13
func (h *Hub) GetMeasurements() *Measurements
GetMeasurements returns the hub measurements. This method should always be used instead of direct access.
func (*Hub) GetMeasurementsWithLockedHub ¶ added in v0.3.13
func (h *Hub) GetMeasurementsWithLockedHub() *Measurements
GetMeasurementsWithLockedHub returns the hub measurements. The caller must hold the lock to Hub. This method should always be used instead of direct access.
func (*Hub) GetSignet ¶
GetSignet returns the public key identified by the given ID from the Hub Status.
func (*Hub) Name ¶ added in v0.3.0
Name returns a human-readable version of a Hub's name. This name will likely consist of two parts: the given name and the ending of the ID to make it unique.
func (*Hub) RemoveLane ¶ added in v0.3.0
RemoveLane removes a Lane from the Hub Status.
func (*Hub) SelectSignet ¶
SelectSignet selects the public key to use for initiating connections to that Hub.
func (*Hub) StringWithoutLocking ¶ added in v0.3.0
StringWithoutLocking returns a human-readable representation of the Hub without locking it.
type HubMsg ¶
type HubMsg struct { record.Base sync.Mutex ID string Map string Type MsgType Data []byte Received int64 }
HubMsg stores raw Hub messages.
type InfoOverride ¶ added in v0.3.13
type InfoOverride struct { // ContinentCode overrides the continent code of the geoip data. ContinentCode string // CountryCode overrides the country code of the geoip data. CountryCode string // Coordinates overrides the geo coordinates code of the geoip data. Coordinates *geoip.Coordinates // ASN overrides the Autonomous System Number of the geoip data. ASN uint // ASOrg overrides the Autonomous System Organization of the geoip data. ASOrg string }
InfoOverride holds data to overide hub info information.
type Intel ¶ added in v0.3.0
type Intel struct { // BootstrapHubs is list of transports that also contain an IP and the Hub's ID. BootstrapHubs []string // TrustedHubs is a list of Hub IDs that are specially designated for more sensitive tasls, such as handling unencrypted traffic. TrustedHubs []string // DiscontinuedHubs is a list of Hub IDs that have been discontinued and should be marked as offline and removed. DiscontinuedHubs []string // AdviseOnlyTrustedHubs advises to only use trusted Hubs regardless of intended purpose. AdviseOnlyTrustedHubs bool // AdviseOnlyTrustedHomeHubs advises to only use trusted Hubs for Home Hubs. AdviseOnlyTrustedHomeHubs bool // AdviseOnlyTrustedDestinationHubs advises to only use trusted Hubs for Destination Hubs. AdviseOnlyTrustedDestinationHubs bool // HubAdvisory always affects all Hubs. HubAdvisory []string // HomeHubAdvisory is only taken into account when selecting a Home Hub. HomeHubAdvisory []string // DestinationHubAdvisory is only taken into account when selecting a Destination Hub. DestinationHubAdvisory []string // InfoOverrides is used to override certain Hub information. InfoOverrides map[string]*InfoOverride // Regions defines regions to assist network optimization. Regions []*RegionConfig // VirtualNetworks holds network configurations for virtual cloud networks. VirtualNetworks []*VirtualNetworkConfig // contains filtered or unexported fields }
Intel holds a collection of various security related data collections on Hubs.
func ParseIntel ¶ added in v0.3.0
ParseIntel parses Hub intelligence data.
func (*Intel) ParseAdvisories ¶ added in v0.3.0
ParseAdvisories parses all advisory endpoint lists.
func (*Intel) Parsed ¶ added in v0.3.0
func (i *Intel) Parsed() *ParsedIntel
Parsed returns the collection of parsed intel data.
type Key ¶ added in v0.3.0
Key represents a semi-ephemeral public key used for 0-RTT connection establishment.
type Lane ¶ added in v0.3.0
type Lane struct { // ID is the Hub ID of the peer. ID string // Capacity designates the available bandwidth between these Hubs. // It is specified in bit/s. Capacity int // Lateny designates the latency between these Hubs. // It is specified in nanoseconds. Latency time.Duration }
Lane represents a connection to another Hub.
type Measurements ¶ added in v0.3.13
type Measurements struct { sync.Mutex // Latency designates the latency between these Hubs. // It is specified in nanoseconds. Latency time.Duration // LatencyMeasuredAt holds when the latency was measured. LatencyMeasuredAt time.Time // Capacity designates the available bandwidth between these Hubs. // It is specified in bit/s. Capacity int // CapacityMeasuredAt holds when the capacity measurement expires. CapacityMeasuredAt time.Time // CalculatedCost stores the calculated cost for direct access. // It is not set automatically, but needs to be set when needed. CalculatedCost float32 // GeoProximity stores an approximation of the geolocation proximity. // The value is between 0 (other side of the world) and 100 (same location). GeoProximity float32 // contains filtered or unexported fields }
Measurements holds various measurements relating to a Hub. Fields may not be accessed directly.
func NewMeasurements ¶ added in v0.3.13
func NewMeasurements() *Measurements
NewMeasurements returns a new measurements struct.
func (*Measurements) Copy ¶ added in v0.3.13
func (m *Measurements) Copy() *Measurements
Copy returns a copy of the measurements.
func (*Measurements) Expired ¶ added in v0.3.13
func (m *Measurements) Expired(ttl time.Duration) bool
Expired returns whether any of the measurements has expired - calculated with the given TTL.
func (*Measurements) GetCalculatedCost ¶ added in v0.3.13
func (m *Measurements) GetCalculatedCost() (cost float32)
GetCalculatedCost returns the calculated cost. The calculated cost is not set automatically, but needs to be set when needed.
func (*Measurements) GetCapacity ¶ added in v0.3.13
func (m *Measurements) GetCapacity() (capacity int, measuredAt time.Time)
GetCapacity returns the capacity and when it expires. The capacity is measued in bit/s.
func (*Measurements) GetGeoProximity ¶ added in v0.3.15
func (m *Measurements) GetGeoProximity() (geoProximity float32)
GetGeoProximity returns the geolocation proximity.
func (*Measurements) GetLatency ¶ added in v0.3.13
func (m *Measurements) GetLatency() (latency time.Duration, measuredAt time.Time)
GetLatency returns the latency and when it expires.
func (*Measurements) IsPersisted ¶ added in v0.3.13
func (m *Measurements) IsPersisted() bool
IsPersisted return whether changes to the measurements have been persisted.
func (*Measurements) SetCalculatedCost ¶ added in v0.3.13
func (m *Measurements) SetCalculatedCost(cost float32)
SetCalculatedCost sets the calculated cost to the given value. The calculated cost is not set automatically, but needs to be set when needed.
func (*Measurements) SetCapacity ¶ added in v0.3.13
func (m *Measurements) SetCapacity(capacity int)
SetCapacity sets the capacity to the given value. The capacity is measued in bit/s.
func (*Measurements) SetGeoProximity ¶ added in v0.3.15
func (m *Measurements) SetGeoProximity(geoProximity float32)
SetGeoProximity sets the geolocation proximity to the given value.
func (*Measurements) SetLatency ¶ added in v0.3.13
func (m *Measurements) SetLatency(latency time.Duration)
SetLatency sets the latency to the given value.
func (*Measurements) Valid ¶ added in v0.3.13
func (m *Measurements) Valid() bool
Valid returns whether there is a valid value .
type ParsedIntel ¶ added in v0.3.0
type ParsedIntel struct { // HubAdvisory always affects all Hubs. HubAdvisory endpoints.Endpoints // HomeHubAdvisory is only taken into account when selecting a Home Hub. HomeHubAdvisory endpoints.Endpoints // DestinationHubAdvisory is only taken into account when selecting a Destination Hub. DestinationHubAdvisory endpoints.Endpoints }
ParsedIntel holds a collection of parsed intel data.
type RegionConfig ¶ added in v0.3.18
type RegionConfig struct { // ID is the internal identifier of the region. ID string // Name is a human readable name of the region. Name string // MemberPolicy specifies a list for including members. MemberPolicy []string // RegionalMinLanes specifies how many lanes other regions should build // to this region. RegionalMinLanes int // RegionalMinLanesPerHub specifies how many lanes other regions should // build to this region, per Hub in this region. // This value will usually be below one. RegionalMinLanesPerHub float64 // RegionalMaxLanesOnHub specifies how many lanes from or to another region may be // built on one Hub per region. RegionalMaxLanesOnHub int // SatelliteMinLanes specifies how many lanes satellites (Hubs without // region) should build to this region. SatelliteMinLanes int // SatelliteMinLanesPerHub specifies how many lanes satellites (Hubs without // region) should build to this region, per Hub in this region. // This value will usually be below one. SatelliteMinLanesPerHub float64 // InternalMinLanesOnHub specifies how many lanes every Hub should create // within the region at minimum. InternalMinLanesOnHub int // InternalMaxHops specifies the max hop constraint for internally optimizing // the region. InternalMaxHops int }
RegionConfig holds the configuration of a region.
type SingleTrustStore ¶
SingleTrustStore is a simple truststore that always returns the same Signet.
type Status ¶ added in v0.3.0
type Status struct { Timestamp int64 // Version holds the current software version of the Hub. Version string // Routing Information Keys map[string]*Key // public keys (with type) Lanes []*Lane // Connections to other Hubs. // Load describes max(CPU, Memory) in percent, averaged over at least 15 // minutes. Load is published in fixed steps only. Load int }
Status is the message type used to update changing Hub Information. Changes are made automatically.
type Transport ¶
Transport represents a "endpoint" that others can connect to. This allows for use of different protocols, ports and infrastructure integration.
func ParseTransport ¶
ParseTransport parses a transport definition.
type VirtualNetworkConfig ¶ added in v0.3.18
type VirtualNetworkConfig struct { // Name is a human readable name of the virtual network. Name string // Force forces the use of the mapped IP addresses after the Hub's IPs have been verified. Force bool // Mapping maps Hub IDs to internal IP addresses. Mapping map[string]net.IP }
VirtualNetworkConfig holds configuration of a virtual network that binds multiple Hubs together.