···11+Creative Commons Legal Code
22+33+CC0 1.0 Universal
44+55+ CREATIVE COMMONS CORPORATION IS NOT A LAW FIRM AND DOES NOT PROVIDE
66+ LEGAL SERVICES. DISTRIBUTION OF THIS DOCUMENT DOES NOT CREATE AN
77+ ATTORNEY-CLIENT RELATIONSHIP. CREATIVE COMMONS PROVIDES THIS
88+ INFORMATION ON AN "AS-IS" BASIS. CREATIVE COMMONS MAKES NO WARRANTIES
99+ REGARDING THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS
1010+ PROVIDED HEREUNDER, AND DISCLAIMS LIABILITY FOR DAMAGES RESULTING FROM
1111+ THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS PROVIDED
1212+ HEREUNDER.
1313+1414+Statement of Purpose
1515+1616+The laws of most jurisdictions throughout the world automatically confer
1717+exclusive Copyright and Related Rights (defined below) upon the creator
1818+and subsequent owner(s) (each and all, an "owner") of an original work of
1919+authorship and/or a database (each, a "Work").
2020+2121+Certain owners wish to permanently relinquish those rights to a Work for
2222+the purpose of contributing to a commons of creative, cultural and
2323+scientific works ("Commons") that the public can reliably and without fear
2424+of later claims of infringement build upon, modify, incorporate in other
2525+works, reuse and redistribute as freely as possible in any form whatsoever
2626+and for any purposes, including without limitation commercial purposes.
2727+These owners may contribute to the Commons to promote the ideal of a free
2828+culture and the further production of creative, cultural and scientific
2929+works, or to gain reputation or greater distribution for their Work in
3030+part through the use and efforts of others.
3131+3232+For these and/or other purposes and motivations, and without any
3333+expectation of additional consideration or compensation, the person
3434+associating CC0 with a Work (the "Affirmer"), to the extent that he or she
3535+is an owner of Copyright and Related Rights in the Work, voluntarily
3636+elects to apply CC0 to the Work and publicly distribute the Work under its
3737+terms, with knowledge of his or her Copyright and Related Rights in the
3838+Work and the meaning and intended legal effect of CC0 on those rights.
3939+4040+1. Copyright and Related Rights. A Work made available under CC0 may be
4141+protected by copyright and related or neighboring rights ("Copyright and
4242+Related Rights"). Copyright and Related Rights include, but are not
4343+limited to, the following:
4444+4545+ i. the right to reproduce, adapt, distribute, perform, display,
4646+ communicate, and translate a Work;
4747+ ii. moral rights retained by the original author(s) and/or performer(s);
4848+iii. publicity and privacy rights pertaining to a person's image or
4949+ likeness depicted in a Work;
5050+ iv. rights protecting against unfair competition in regards to a Work,
5151+ subject to the limitations in paragraph 4(a), below;
5252+ v. rights protecting the extraction, dissemination, use and reuse of data
5353+ in a Work;
5454+ vi. database rights (such as those arising under Directive 96/9/EC of the
5555+ European Parliament and of the Council of 11 March 1996 on the legal
5656+ protection of databases, and under any national implementation
5757+ thereof, including any amended or successor version of such
5858+ directive); and
5959+vii. other similar, equivalent or corresponding rights throughout the
6060+ world based on applicable law or treaty, and any national
6161+ implementations thereof.
6262+6363+2. Waiver. To the greatest extent permitted by, but not in contravention
6464+of, applicable law, Affirmer hereby overtly, fully, permanently,
6565+irrevocably and unconditionally waives, abandons, and surrenders all of
6666+Affirmer's Copyright and Related Rights and associated claims and causes
6767+of action, whether now known or unknown (including existing as well as
6868+future claims and causes of action), in the Work (i) in all territories
6969+worldwide, (ii) for the maximum duration provided by applicable law or
7070+treaty (including future time extensions), (iii) in any current or future
7171+medium and for any number of copies, and (iv) for any purpose whatsoever,
7272+including without limitation commercial, advertising or promotional
7373+purposes (the "Waiver"). Affirmer makes the Waiver for the benefit of each
7474+member of the public at large and to the detriment of Affirmer's heirs and
7575+successors, fully intending that such Waiver shall not be subject to
7676+revocation, rescission, cancellation, termination, or any other legal or
7777+equitable action to disrupt the quiet enjoyment of the Work by the public
7878+as contemplated by Affirmer's express Statement of Purpose.
7979+8080+3. Public License Fallback. Should any part of the Waiver for any reason
8181+be judged legally invalid or ineffective under applicable law, then the
8282+Waiver shall be preserved to the maximum extent permitted taking into
8383+account Affirmer's express Statement of Purpose. In addition, to the
8484+extent the Waiver is so judged Affirmer hereby grants to each affected
8585+person a royalty-free, non transferable, non sublicensable, non exclusive,
8686+irrevocable and unconditional license to exercise Affirmer's Copyright and
8787+Related Rights in the Work (i) in all territories worldwide, (ii) for the
8888+maximum duration provided by applicable law or treaty (including future
8989+time extensions), (iii) in any current or future medium and for any number
9090+of copies, and (iv) for any purpose whatsoever, including without
9191+limitation commercial, advertising or promotional purposes (the
9292+"License"). The License shall be deemed effective as of the date CC0 was
9393+applied by Affirmer to the Work. Should any part of the License for any
9494+reason be judged legally invalid or ineffective under applicable law, such
9595+partial invalidity or ineffectiveness shall not invalidate the remainder
9696+of the License, and in such case Affirmer hereby affirms that he or she
9797+will not (i) exercise any of his or her remaining Copyright and Related
9898+Rights in the Work or (ii) assert any associated claims and causes of
9999+action with respect to the Work, in either case contrary to Affirmer's
100100+express Statement of Purpose.
101101+102102+4. Limitations and Disclaimers.
103103+104104+ a. No trademark or patent rights held by Affirmer are waived, abandoned,
105105+ surrendered, licensed or otherwise affected by this document.
106106+ b. Affirmer offers the Work as-is and makes no representations or
107107+ warranties of any kind concerning the Work, express, implied,
108108+ statutory or otherwise, including without limitation warranties of
109109+ title, merchantability, fitness for a particular purpose, non
110110+ infringement, or the absence of latent or other defects, accuracy, or
111111+ the present or absence of errors, whether or not discoverable, all to
112112+ the greatest extent permissible under applicable law.
113113+ c. Affirmer disclaims responsibility for clearing rights of other persons
114114+ that may apply to the Work or any use thereof, including without
115115+ limitation any person's Copyright and Related Rights in the Work.
116116+ Further, Affirmer disclaims responsibility for obtaining any necessary
117117+ consents, permissions or other rights required for any use of the
118118+ Work.
119119+ d. Affirmer understands and acknowledges that Creative Commons is not a
120120+ party to this document and has no duty or obligation with respect to
121121+ this CC0 or use of the Work.
+3
README.md
···11+# composition
22+33+a collection of docker-compose related stuff, mainly service configs
+57
i2pd-tools/Dockerfile
···11+# Use the official Debian stable slim image
22+FROM debian:stable-slim AS base
33+44+# prevent interactive prompts during package installation
55+ARG DEBIAN_FRONTEND=noninteractive
66+77+# Install dependencies
88+RUN apt-get update && apt-get install -y --no-install-recommends \
99+ libboost-dev \
1010+ libboost-chrono-dev \
1111+ libboost-date-time-dev \
1212+ libboost-filesystem-dev \
1313+ libboost-program-options-dev \
1414+ libboost-system-dev \
1515+ libboost-thread-dev \
1616+ libssl-dev \
1717+ zlib1g-dev
1818+1919+FROM base AS builder
2020+2121+# Install build dependencies
2222+RUN apt-get install -y --no-install-recommends \
2323+ make \
2424+ gcc g++
2525+2626+# Copy sources into the layer
2727+COPY . /opt/i2pd-tools
2828+WORKDIR /opt/i2pd-tools
2929+3030+# Build all the tools
3131+RUN make -j"$(nproc)"
3232+3333+FROM base
3434+3535+# Copy binaries to base layer
3636+COPY --from=builder \
3737+ /opt/i2pd-tools/autoconf \
3838+ /opt/i2pd-tools/keygen \
3939+ /opt/i2pd-tools/keyinfo \
4040+ /opt/i2pd-tools/famtool \
4141+ /opt/i2pd-tools/i2pbase64 \
4242+ /opt/i2pd-tools/regaddr \
4343+ /opt/i2pd-tools/regaddralias \
4444+ /opt/i2pd-tools/routerinfo \
4545+ /opt/i2pd-tools/vain \
4646+ /opt/i2pd-tools/b33address \
4747+ /opt/i2pd-tools/offlinekeys \
4848+ /opt/i2pd-tools/regaddr_3ld \
4949+ /opt/i2pd-tools/verifyhost \
5050+ /opt/i2pd-tools/x25519 \
5151+ /usr/local/bin/
5252+5353+WORKDIR /data
5454+5555+# Drop into a shell by default so you can run any tool interactively
5656+CMD ["bash"]
5757+
+21
i2pd-tools/README.md
···11+# i2pd-tools
22+33+this is a Dockerfile for [i2pd-tools](https://github.com/purplei2p/i2pd-tools), mainly to use with `vain`.
44+55+to build, first clone the i2pd-tools repo:
66+77+```
88+git clone --recursive https://github.com/purplei2p/i2pd-tools
99+```
1010+1111+then:
1212+1313+```
1414+docker build -t melontini/i2pd-tools .
1515+```
1616+1717+now you can run, for example, `vain` to get a vanity address:
1818+1919+```
2020+docker run --rm -it -v "$PWD":/data melontini/i2pd-tools:latest vain hawk2
2121+```
+14
i2pd/README.md
···11+# i2pd
22+33+based on the https://hub.docker.com/r/purplei2p/i2pd image. this doesn't require host networking, but this config uses it anyway because it's easier.
44+55+if you're facing permission issues, before starting, make the data dir world writable.
66+77+```
88+mkdir -p ./data
99+chmod -R 777 ./data
1010+```
1111+1212+check and modify i2pd.conf and tunnels.conf before starting the service! enables ssh access over i2p on port 22 by default!
1313+1414+learn more about i2p https://geti2p.net/en/ and i2pd https://i2pd.website/
···11+## Configuration file for a typical i2pd user
22+## See https://i2pd.readthedocs.io/en/latest/user-guide/configuration/
33+## for more options you can use in this file.
44+55+## Lines that begin with "## " try to explain what's going on. Lines
66+## that begin with just "#" are disabled commands: you can enable them
77+## by removing the "#" symbol.
88+99+## Tunnels config file
1010+## Default: ~/.i2pd/tunnels.conf or /var/lib/i2pd/tunnels.conf
1111+# tunconf = /var/lib/i2pd/tunnels.conf
1212+1313+## Tunnels config files path
1414+## Use that path to store separated tunnels in different config files.
1515+## Default: ~/.i2pd/tunnels.d or /var/lib/i2pd/tunnels.d
1616+# tunnelsdir = /var/lib/i2pd/tunnels.d
1717+1818+## Path to certificates used for verifying .su3, families
1919+## Default: ~/.i2pd/certificates or /var/lib/i2pd/certificates
2020+# certsdir = /var/lib/i2pd/certificates
2121+2222+## Where to write pidfile (default: /run/i2pd.pid, not used in Windows)
2323+# pidfile = /run/i2pd.pid
2424+2525+## Logging configuration section
2626+## By default logs go to stdout with level 'info' and higher
2727+## For Windows OS by default logs go to file with level 'warn' and higher
2828+##
2929+## Logs destination (valid values: stdout, file, syslog)
3030+## * stdout - print log entries to stdout
3131+## * file - log entries to a file
3232+## * syslog - use syslog, see man 3 syslog
3333+# log = file
3434+## Path to logfile (default: autodetect)
3535+# logfile = /var/log/i2pd/i2pd.log
3636+## Log messages above this level (debug, info, *warn, error, critical, none)
3737+## If you set it to none, logging will be disabled
3838+# loglevel = warn
3939+## Write full CLF-formatted date and time to log (default: write only time)
4040+# logclftime = true
4141+4242+## Daemon mode. Router will go to background after start. Ignored on Windows
4343+## (default: true)
4444+# daemon = true
4545+4646+## Specify a family, router belongs to (default - none)
4747+# family =
4848+4949+## Network interface to bind to
5050+## Updates address4/6 options if they are not set
5151+# ifname =
5252+## You can specify different interfaces for IPv4 and IPv6
5353+# ifname4 =
5454+# ifname6 =
5555+5656+## Local address to bind transport sockets to
5757+## Overrides host option if:
5858+## For ipv4: if ipv4 = true and nat = false
5959+## For ipv6: if 'host' is not set or ipv4 = true
6060+# address4 =
6161+# address6 =
6262+6363+## External IPv4 or IPv6 address to listen for connections
6464+## By default i2pd sets IP automatically
6565+## Sets published NTCP2v4/SSUv4 address to 'host' value if nat = true
6666+## Sets published NTCP2v6/SSUv6 address to 'host' value if ipv4 = false
6767+# host = 1.2.3.4
6868+6969+## Port to listen for connections
7070+## By default i2pd picks random port. You MUST pick a random number too,
7171+## don't just uncomment this
7272+# port = 60668
7373+7474+## Enable communication through ipv4 (default: true)
7575+ipv4 = true
7676+## Enable communication through ipv6 (default: false)
7777+ipv6 = true
7878+7979+## Bandwidth configuration
8080+## L limit bandwidth to 32 KB/sec, O - to 256 KB/sec, P - to 2048 KB/sec,
8181+## X - unlimited
8282+## Default is L (regular node) and X if floodfill mode enabled.
8383+## If you want to share more bandwidth without floodfill mode, uncomment
8484+## that line and adjust value to your possibilities. Value can be set to
8585+## integer in kilobytes, it will apply that limit and flag will be used
8686+## from next upper limit (example: if you set 4096 flag will be X, but real
8787+## limit will be 4096 KB/s). Same can be done when floodfill mode is used,
8888+## but keep in mind that low values may be negatively evaluated by Java
8989+## router algorithms.
9090+# bandwidth = L
9191+## Max % of bandwidth limit for transit. 0-100 (default: 100)
9292+# share = 100
9393+9494+## Router will not accept transit tunnels, disabling transit traffic completely
9595+## (default: false)
9696+# notransit = true
9797+9898+## Router will be floodfill (default: false)
9999+## Note: that mode uses much more network connections and CPU!
100100+# floodfill = true
101101+102102+[ntcp2]
103103+## Enable NTCP2 transport (default: true)
104104+# enabled = true
105105+## Publish address in RouterInfo (default: true)
106106+# published = true
107107+## Port for incoming connections (default is global port option value)
108108+# port = 4567
109109+110110+[ssu2]
111111+## Enable SSU2 transport (default: true)
112112+# enabled = true
113113+## Publish address in RouterInfo (default: true)
114114+# published = true
115115+## Port for incoming connections (default is global port option value)
116116+# port = 4567
117117+118118+[http]
119119+## Web Console settings
120120+## Enable the Web Console (default: true)
121121+# enabled = true
122122+## Address and port service will listen on (default: 127.0.0.1:7070)
123123+# address = 127.0.0.1
124124+# port = 7070
125125+## Path to web console (default: /)
126126+# webroot = /
127127+## Enable Web Console authentication (default: false)
128128+## You should not use Web Console via public networks without additional encryption.
129129+## HTTP authentication is not encryption layer!
130130+# auth = true
131131+# user = i2pd
132132+# pass = changeme
133133+## Select webconsole language
134134+## Currently supported english (default), afrikaans, armenian, chinese, czech, french,
135135+## german, italian, polish, portuguese, russian, spanish, turkish, turkmen, ukrainian
136136+## and uzbek languages
137137+# lang = english
138138+139139+[httpproxy]
140140+## Enable the HTTP proxy (default: true)
141141+enabled = false
142142+## Address and port service will listen on (default: 127.0.0.1:4444)
143143+# address = 127.0.0.1
144144+# port = 4444
145145+## Optional keys file for proxy local destination (default: http-proxy-keys.dat)
146146+# keys = http-proxy-keys.dat
147147+## Enable address helper for adding .i2p domains with "jump URLs" (default: true)
148148+## You should disable this feature if your i2pd HTTP Proxy is public,
149149+## because anyone could spoof the short domain via addresshelper and forward other users to phishing links
150150+# addresshelper = true
151151+## Address of a proxy server inside I2P, which is used to visit regular Internet
152152+# outproxy = http://false.i2p
153153+## httpproxy section also accepts I2CP parameters, like "inbound.length" etc.
154154+155155+[socksproxy]
156156+## Enable the SOCKS proxy (default: true)
157157+enabled = false
158158+## Address and port service will listen on (default: 127.0.0.1:4447)
159159+# address = 127.0.0.1
160160+# port = 4447
161161+## Optional keys file for proxy local destination (default: socks-proxy-keys.dat)
162162+# keys = socks-proxy-keys.dat
163163+## Socks outproxy. Example below is set to use Tor for all connections except i2p
164164+## Enable using of SOCKS outproxy (works only with SOCKS4, default: false)
165165+# outproxy.enabled = false
166166+## Address and port of outproxy
167167+# outproxy = 127.0.0.1
168168+# outproxyport = 9050
169169+## socksproxy section also accepts I2CP parameters, like "inbound.length" etc.
170170+171171+[sam]
172172+## Enable the SAM bridge (default: true)
173173+# enabled = false
174174+## Address and ports service will listen on (default: 127.0.0.1:7656, udp: 7655)
175175+# address = 127.0.0.1
176176+# port = 7656
177177+# portudp = 7655
178178+179179+[bob]
180180+## Enable the BOB command channel (default: false)
181181+# enabled = false
182182+## Address and port service will listen on (default: 127.0.0.1:2827)
183183+# address = 127.0.0.1
184184+# port = 2827
185185+186186+[i2cp]
187187+## Enable the I2CP protocol (default: false)
188188+# enabled = false
189189+## Address and port service will listen on (default: 127.0.0.1:7654)
190190+# address = 127.0.0.1
191191+# port = 7654
192192+193193+[i2pcontrol]
194194+## Enable the I2PControl protocol (default: false)
195195+# enabled = false
196196+## Address and port service will listen on (default: 127.0.0.1:7650)
197197+# address = 127.0.0.1
198198+# port = 7650
199199+## Authentication password (default: itoopie)
200200+# password = itoopie
201201+202202+[precomputation]
203203+## Enable or disable elgamal precomputation table
204204+## By default, enabled on i386 hosts
205205+# elgamal = true
206206+207207+[upnp]
208208+## Enable or disable UPnP: automatic port forwarding (enabled by default in WINDOWS, ANDROID)
209209+# enabled = false
210210+## Name i2pd appears in UPnP forwardings list (default: I2Pd)
211211+# name = I2Pd
212212+213213+[meshnets]
214214+## Enable connectivity over the Yggdrasil network (default: false)
215215+# yggdrasil = true
216216+## You can bind address from your Yggdrasil subnet 300::/64
217217+## The address must first be added to the network interface
218218+# yggaddress =
219219+220220+[reseed]
221221+## Options for bootstrapping into I2P network, aka reseeding
222222+## Enable reseed data verification (default: true)
223223+verify = true
224224+## URLs to request reseed data from, separated by comma
225225+## Default: "mainline" I2P Network reseeds
226226+# urls = https://reseed.i2p-projekt.de/,https://i2p.mooo.com/netDb/,https://netdb.i2p2.no/
227227+## Reseed URLs through the Yggdrasil, separated by comma
228228+# yggurls = http://[324:71e:281a:9ed3::ace]:7070/
229229+## Path to local reseed data file (.su3) for manual reseeding
230230+# file = /path/to/i2pseeds.su3
231231+## or HTTPS URL to reseed from
232232+# file = https://legit-website.com/i2pseeds.su3
233233+## Path to local ZIP file or HTTPS URL to reseed from
234234+# zipfile = /path/to/netDb.zip
235235+## If you run i2pd behind a proxy server, set proxy server for reseeding here
236236+## Should be http://address:port or socks://address:port
237237+# proxy = http://127.0.0.1:8118
238238+## Minimum number of known routers, below which i2pd triggers reseeding (default: 25)
239239+# threshold = 25
240240+241241+[addressbook]
242242+## AddressBook subscription URL for initial setup
243243+## Default: reg.i2p at "mainline" I2P Network
244244+# defaulturl = http://shx5vqsw7usdaunyzr2qmes2fq37oumybpudrd4jjj4e4vk4uusa.b32.i2p/hosts.txt
245245+## Optional subscriptions URLs, separated by comma
246246+# subscriptions = http://reg.i2p/hosts.txt,http://identiguy.i2p/hosts.txt,http://stats.i2p/cgi-bin/newhosts.txt
247247+248248+[limits]
249249+## Maximum active transit sessions (default: 10000)
250250+## This value is doubled if floodfill mode is enabled!
251251+# transittunnels = 10000
252252+## Limit number of open file descriptors (0 - use system limit)
253253+# openfiles = 0
254254+## Maximum size of corefile in Kb (0 - use system limit)
255255+# coresize = 0
256256+257257+[trust]
258258+## Enable explicit trust options. (default: false)
259259+# enabled = true
260260+## Make direct I2P connections only to routers in specified Family.
261261+# family = MyFamily
262262+## Make direct I2P connections only to routers specified here. Comma separated list of base64 identities.
263263+# routers =
264264+## Should we hide our router from other routers? (default: false)
265265+# hidden = true
266266+267267+[exploratory]
268268+## Exploratory tunnels settings with default values
269269+# inbound.length = 2
270270+# inbound.quantity = 3
271271+# outbound.length = 2
272272+# outbound.quantity = 3
273273+274274+[persist]
275275+## Save peer profiles on disk (default: true)
276276+# profiles = true
277277+## Save full addresses on disk (default: true)
278278+# addressbook = true
279279+
···11+# yggdrasil
22+33+based on the https://hub.docker.com/r/jauderho/yggdrasil-go image. this doesn't work with podman due to networling stuff. ygg requires /dev/tun and net admin to route traffic to the daemon.
44+55+the included config file enables NodeInfoPrivacy and changes AdminListen to tcp instead of a socket.
66+77+learn more about the yggdrasil router here: https://yggdrasil-network.github.io/
···11+{
22+ # Your private key. DO NOT share this with anyone!
33+ PrivateKey: CHANGE_ME
44+55+ # List of outbound peer connection strings (e.g. tls://a.b.c.d:e or
66+ # socks://a.b.c.d:e/f.g.h.i:j). Connection strings can contain options,
77+ # see https://yggdrasil-network.github.io/configurationref.html#peers.
88+ # Yggdrasil has no concept of bootstrap nodes - all network traffic
99+ # will transit peer connections. Therefore make sure to only peer with
1010+ # nearby nodes that have good connectivity and low latency. Avoid adding
1111+ # peers to this list from distant countries as this will worsen your
1212+ # node's connectivity and performance considerably.
1313+ Peers: [
1414+ ADD_PEERS_HERE
1515+ ]
1616+1717+ # List of connection strings for outbound peer connections in URI format,
1818+ # arranged by source interface, e.g. { "eth0": [ "tls://a.b.c.d:e" ] }.
1919+ # You should only use this option if your machine is multi-homed and you
2020+ # want to establish outbound peer connections on different interfaces.
2121+ # Otherwise you should use "Peers".
2222+ InterfacePeers: {}
2323+2424+ # Listen addresses for incoming connections. You will need to add
2525+ # listeners in order to accept incoming peerings from non-local nodes.
2626+ # This is not required if you wish to establish outbound peerings only.
2727+ # Multicast peer discovery will work regardless of any listeners set
2828+ # here. Each listener should be specified in URI format as above, e.g.
2929+ # tls://0.0.0.0:0 or tls://[::]:0 to listen on all interfaces.
3030+ Listen: [
3131+3232+ ]
3333+3434+ AdminListen: tcp://localhost:9001
3535+3636+ # Configuration for which interfaces multicast peer discovery should be
3737+ # enabled on. Regex is a regular expression which is matched against an
3838+ # interface name, and interfaces use the first configuration that they
3939+ # match against. Beacon controls whether or not your node advertises its
4040+ # presence to others, whereas Listen controls whether or not your node
4141+ # listens out for and tries to connect to other advertising nodes. See
4242+ # https://yggdrasil-network.github.io/configurationref.html#multicastinterfaces
4343+ # for more supported options.
4444+ MulticastInterfaces: [
4545+ {
4646+ Regex: .*
4747+ Beacon: true
4848+ Listen: true
4949+ Password: ""
5050+ }
5151+ ]
5252+5353+ # List of peer public keys to allow incoming peering connections
5454+ # from. If left empty/undefined then all connections will be allowed
5555+ # by default. This does not affect outgoing peerings, nor does it
5656+ # affect link-local peers discovered via multicast.
5757+ # WARNING: THIS IS NOT A FIREWALL and DOES NOT limit who can reach
5858+ # open ports or services running on your machine!
5959+ AllowedPublicKeys: []
6060+6161+ # Local network interface name for TUN adapter, or "auto" to select
6262+ # an interface automatically, or "none" to run without TUN.
6363+ IfName: auto
6464+6565+ # Maximum Transmission Unit (MTU) size for your local TUN interface.
6666+ # Default is the largest supported size for your platform. The lowest
6767+ # possible value is 1280.
6868+ IfMTU: 65535
6969+7070+ # By default, nodeinfo contains some defaults including the platform,
7171+ # architecture and Yggdrasil version. These can help when surveying
7272+ # the network and diagnosing network routing problems. Enabling
7373+ # nodeinfo privacy prevents this, so that only items specified in
7474+ # "NodeInfo" are sent back if specified.
7575+ NodeInfoPrivacy: true
7676+7777+ # Optional nodeinfo. This must be a { "key": "value", ... } map
7878+ # or set as null. This is entirely optional but, if set, is visible
7979+ # to the whole network on request.
8080+ NodeInfo: {
8181+ }
8282+}