tconfig.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
       ---
       tconfig.go (1570B)
       ---
            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         "net"
           23 )
           24 
           25 // Config is the configuration structure, to be filled by library user.
           26 type Config struct {
           27         Listen  *net.TCPAddr // Local listen address for the JSON-RPC server
           28         TorAddr *net.TCPAddr // Tor SOCKS5 proxy address, filled by SpawnTor()
           29         Datadir string       // Path to data directory
           30         Portmap []string     // The peer's portmap, to be mapped in the Tor HS
           31 }
           32 
           33 // SignKey is an ed25519 private key, to be assigned by library user.
           34 var SignKey ed25519.PrivateKey
           35 
           36 // Onion is the library user's something.onion:port identifier. It can be read
           37 // from the datadir once Tor is spawned.
           38 var Onion string
           39 
           40 // Cfg is the global config structure, to be filled by library user.
           41 var Cfg = Config{}
           42 
           43 // Peers is the global map of peers
           44 var Peers = map[string]Peer{}