tpeer.go - tordam - A library for peer discovery inside the Tor network
 (HTM) git clone https://git.parazyd.org/tordam
 (DIR) Log
 (DIR) Files
 (DIR) Refs
 (DIR) README
 (DIR) LICENSE
       ---
       tpeer.go (1521B)
       ---
            1 // Copyright (c) 2017-2021 Ivan Jelincic <parazyd@dyne.org>
            2 //
            3 // This file is part of tordam
            4 //
            5 // This program is free software: you can redistribute it and/or modify
            6 // it under the terms of the GNU Affero General Public License as published by
            7 // the Free Software Foundation, either version 3 of the License, or
            8 // (at your option) any later version.
            9 //
           10 // This program is distributed in the hope that it will be useful,
           11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
           12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
           13 // GNU Affero General Public License for more details.
           14 //
           15 // You should have received a copy of the GNU Affero General Public License
           16 // along with this program. If not, see <https://www.gnu.org/licenses/>.
           17 
           18 package tordam
           19 
           20 import (
           21         "crypto/ed25519"
           22 )
           23 
           24 // Peer is the base struct for any peer in the network.
           25 type Peer struct {
           26         Pubkey     ed25519.PublicKey `json:"pubkey"`     // Peer's ed25519 public key
           27         Portmap    []string          `json:"portmap"`    // Peer's port map in Tor
           28         Nonce      string            `json:"nonce"`      // The nonce to be signed after announce init
           29         SelfRevoke string            `json:"selfrevoke"` // Our revoke key we use to update our data
           30         PeerRevoke string            `json:"peerrevoke"` // Peer's revoke key if they wish to update their data
           31         LastSeen   int64             `json:"lastseen"`   // Timestamp of last announce
           32         Trusted    int               `json:"trusted"`    // Trusted is int because of possible levels of trust
           33 }