Networking ---------- Part 0: Introduction -------------------- There are various ways of achieving a network in arching-kaos and some of them are documented here. The ones that are missing, either their are under testing, considered to be covered or not yet grasped. Part 1: Preassumptions ---------------------- This document assumes you somehow familiarized yourself with the scripts and their usage. Part 2: Networking via IPFS --------------------------- We need to mention here that when you install arching-kaos-tools, IPFS is also installed. Furthermore, a swarm key is downloaded and installed as well. This is used to connect to aknet swarm in IPFS. Hence, you 'll need some peers to connect to via IPFS. Ask for that in #arching-kaos over at IRC. See `SUPPORT` file as well. Other than that, you can make up yourself a swarm and express your creativity there. Part 3: Networking via Stellar Network -------------------------------------- Stellar Network is used as a peering system. If you own an address in XLM, you can store a named variable in your address. You 'll be required to "lock" 0.5XLM to persist the value you want. You'll be also required to trust ARCHINGKAOS asset if you want your content to be retrievable via https://arching-kaos.net and contribute with your creativity there. 3.1 Assumption -------------- We assume you already have a Stellar wallet and you also have direct access to your private key. This will be needed in case you don't use some wallet, compatible with https://laboratory.stellar.org/ which we will be using for connecting our arching-kaos configuration link (aka AKID) with our Stellar address. 3.2 Preparation --------------- Before we publish anything, we need to know what we need to publish and where. Issuing the command ``` ak config --get-ipns-key ``` will return to us the IPNS key that points to our current AKID. We will need this value for the next step 3.3 Publishing IPNS key to Stellar network ------------------------------------------ 1. Visit https://laboratory.stellar.org/#?network=public and go to the "Build transaction" option, 2. Enter your Stellar address in the Source Address field, 3. Click the "Fetch next sequence number for account starting with ..." button, 4. Scroll down to find the "Operation Type" and select from the dropdown menu the "Manage data" option, 5. Use as "Entry name": "config" (without the double quotes), 6. Paste the IPNS link we got from the previous section, in the "Entry value" field, 7. Scroll further down and click the "Sign in Transaction Signer" button, 8. Sign the transaction with your wallet or your private key, 9. Submit the transaction to the Stellar Network! Congratulations! You successfully published your IPNS reference to your AKID in the Stellar Network. 3.4 Open a trustline to ARCHINGKAOS ----------------------------------- To be able to post content on arching-kaos.net you will need to trust the asset ARCHINGKAOS issued by GB4QVKD6NW3CSNO5TNPARAWNPPXOPSSTKB35XCWB7PUNBIQTK3DVELB2. Build a transaction as described above, but instead of "Manage data" select "ChangeTrust" option. Set the information above in the appropriate fields, sign the transaction and submit it. Now, your contributions will appear at https://arching-kaos.net Part 4: Networking with CJDNS ----------------------------- CJDNS is a decentralized mesh networking alternative to the internet. It uses the fc00::/8 private space of IPv6 protocol. Your IPv6 derives from your public key where its private part is used to decrypt your incoming packets. Using CJDNS and arching-kaos-tools to netwok around is pretty easy but there are steps to make it work as well. Of course, you will need CJDNS to be running in the machine you want to network with/from. Furthermore, you will also need the cjdns-tools, laying under the tools folder in the cjdns repository to be in your PATH. You then can use the `ak network -s cjdns` to find other akdaemon(s) running in your relative neighbourhood. `dumpLinks` is used to retrieve the nodes in this area. You can find more intense scanning scripts around like `walk.sh` by ircerr which is able to reach the whole public network of cjdns. - http://hia.cjdns.ca/watchlist/c/walk.sh (seq) - http://hia.cjdns.ca/watchlist/c/walk2.sh (threaded) TODO: We should be storing the output on a relevant file so it can be reached by the API as well or ask for current known nodes without rescanning the network. Part 5: Update on networking ---------------------------- Great news everyone! `ak-network` is here: ``` $ ak network ak-network - AK Nettool ======================= Network tools Usage: -h, --help Prints this help message -c, --connect [ipfs|cjdns] Connect to network(s) -p, --peers [ipfs|cjdns|stellar] Outputs peers found -s, --scan [ipfs|cjdns|stellar] Scan network(s) for peers Bonus: CJDNS network scanning flags -s, --scan cjdns [-w|--whole] Scan using HIA's knowledge -s, --scan cjdns [-d|--dump] Scan using CJDNS' dumpLinks (default) ``` Though: ``` $ ak network --scan ipfs 20240707_065927 <ak-network> [ERROR] Not implemented: _ak_network_scan_ipfs ``` Which I think I should not try to do since we use `ak-config` as the key on IPFS to publish our `node_info` at and we can not guess keys just in case we found one with `node_info`. A work around could be to use the `self` key and publish there instead of `ak-config`. Previously, since we were using for `IPFS_REPO` the default directory, it was thought that the `self` key could be already in use. Now that we do have our own dedicated path for `IPFS_REPO`, it could be revisited. But, as mentioned in other places, we are about to drop IPFS in the future. Whichever comes first? TODO ^^ maybe