Astroport.ONE/README.md

24 KiB
Raw Blame History

Préambule - read this introduction in english -

Bienvenue dans l'équipe d'Astroport, le réseau pair-à-pair (P2P) révolutionnaire qui repousse les limites de la liberté d'information et d'interaction ! Si vous êtes un développeur passionné à la recherche d'un projet novateur et audacieux, alors vous êtes au bon endroit.

Astroport offre une plateforme sécurisée et décentralisée permettant le partage d'informations, en particulier de vidéos, via IPFS. Notre objectif est de contrer les restrictions de censure qui pourraient être imposées par les futures lois de fact-checking avancées par l'Union Européenne. Nous croyons fermement en la liberté d'expression et nous nous engageons à protéger cette valeur fondamentale.

Mais ce n'est pas tout ! Astroport va bien au-delà du simple partage d'informations. Notre plateforme vous permet également d'identifier les ressources autour de vous, qu'il s'agisse de nourriture, d'amis, de services ou de biens. Grâce à Astroport, vous serez en mesure de trouver et de partager les ressources nécessaires à votre vie quotidienne de manière simple et efficace.

Et ce n'est pas tout ! Nous souhaitons également intégrer un "build guide" à Astroport, inspiré par les célèbres livres de recettes de Minecraft. Vous pourrez utiliser ce guide pour apprendre à créer des objets réels, en utilisant les matériaux disponibles sur notre place de marché. Imaginez un tutoriel détaillé pour fabriquer des meubles, des objets de décoration, voire même des outils pratiques pour votre quotidien. Astroport met la créativité entre vos mains.

Nous nous sommes également associés à la monnaie libre Ğ1 et à sa place de marché, gchange.fr. Cela signifie que vous pourrez commander les matériaux nécessaires à la réalisation de vos projets directement depuis Astroport. Tout est à portée de clic, dans une seule et même application.

Rejoindre l'équipe d'Astroport, c'est contribuer à une cause qui va bien au-delà de la simple programmation. C'est faire partie d'un mouvement qui aspire à défendre les principes de liberté, de partage et de créativité. C'est travailler sur un projet qui a le potentiel de changer la façon dont nous interagissons avec l'information et les ressources qui nous entourent.

Alors, si vous êtes prêt à relever le défi et à participer à la construction d'un avenir où la censure n'a pas sa place, rejoignez-nous dès aujourd'hui et laissez votre empreinte sur le monde avec Astroport. Ensemble, nous pouvons libérer le potentiel de la technologie et créer un avenir plus ouvert pour tous.

PRESENTATION UPLANET BASH ENGINE FOR A CRYPTO PLAYGROUND

https://astroport.com

Avec cette technologie, nous devenons chacun hébergeur et fournisseur d'accès, souverain monétaire et médiatique. Avec cette technologie, nous établissons le "Crypto Département 96" dont la carte relie les territoires au delà des frontières et des pays.

Astroport ONE propulse un monde numérique fait de toiles confiances interconnectées

Astroport.ONE

Chaque Station "Astroport.ONE" est une ambassade numérique qui dialogue et se synchronise avec ses pairs. Les utilisateurs peuvent "déplacer leur compte". La dernière utilisée dans la journée devient "station officielle".

L'architecture attachée à chaque clef publiquesse déploie et en forme de "pétales de fleur" selon les cercles de confiance Ŋ1 et Ŋ2 et les flux de données produit par les clefs dérivées.

N.ONE.2

Contrat intelligent déclenchés par "G1Tag" (clefs dérivées) assure l'extraction les "G1MotsClefs" des Tiddlers "environnant".

Introduit dans UPlanet, inscrit dans le système de fichier interplanétaire, nos TiddlyWiki sont la base d'un système d'information planétaire Libre. Le contrat intelligent de base consiste à collecter les données produites par chaque TW pour les remonter au niveau de la couche d'information supérieure.

  • 0.01°: Les Tiddlers sont inscrit au niveau local et possèdent une signature (votre email). Chaque jour un processus en analyse les nouveaux pour vous informer de la détection de "doublons différents". Le "conflit" est résolu en
  • 0.1° : > 2 signatures
  • 1° : > 3 signatures
  • 10° : > 4 signatures
  • UPlanet : 5 signatures et plus.

Afin de déclencher lexécution de "contrat intelligent personnel", il vous suffit de créer un "voeu" (et de lui attribuer quelques Zen) A ce moment, "ASTROBOT" publiera les données relatives au Tag concerné sur une nouvelle "clef dérivée IPNS personnelle"

INSTALLATION (Linux Mint / Ubuntu / DEBIAN)

There is 2 methods one for server and one for Linux Mint desktop

SERVER : Using DOCKER (and MyOS)

the easiest way to automaticaly deploy and host Astroport.ONE services

# install minimal requirements
sudo apt install git docker make

# clone Astroport.ONE repo
git clone https://github.com/papiche/Astroport.ONE.git

cd Astroport.ONE
make
make install

If your computer is running 24/24, you can join our "Boostrap list" & officially become a TW UPlanet hoster

PLEASE REPORT ANY ISSUES

DESKTOP : Using install.sh script

Tested on "Linux Mint" (Debian like distro compatible), the hacker way for using & buidling new blockchain services ...

# install on system wide
# SOURCE GIT.P2P.LEGAL
bash <(wget -qO- https://git.p2p.legal/qo-op/Astroport.ONE/raw/branch/master/install.sh)

# SOURCE GITHUB
bash <(wget -qO- https://raw.githubusercontent.com/papiche/Astroport.ONE/master/install.sh)

PLEASE REPORT ANY ISSUES

Si tout s'est bien déroulé, vous devriez trouver ces processus en cours d'execution...

/usr/local/bin/ipfs daemon --enable-pubsub-experiment --enable-namesys-pubsub
/bin/bash /home/fred/.zen/G1BILLET/G1BILLETS.sh daemon
 \_ /bin/bash /home/fred/.zen/G1BILLET/G1BILLETS.sh daemon
   \_ nc -l -p 33101 -q 1
/bin/bash /home/fred/.zen/Astroport.ONE/12345.sh
 \_ /bin/bash /home/fred/.zen/Astroport.ONE/12345.sh
   \_ nc -l -p 1234 -q 1
/bin/bash /home/fred/.zen/Astroport.ONE/_12345.sh
 \_ nc -l -p 12345 -q 1

LANCEMENT

Après l'installation, vous devriez avoir 3 nouveaux raccourcis sur votre "Bureau"

  • "Astroport" qui ouvre le portail de votre Station : http://astroport.localhost:1234
  • "REC" qui permet d'enregistrer vos fichiers sur IPFS et publier leur Capusle dans votre TW
  • "G1BILLET" permet de créer des ZenCard et autres QRCodes utiles

Comment Gérer votre "Astroport" !

~/.zen/Astroport.ONE/command.sh

Permet la Gestion des PLAYER (et des G1VoeuX) en mode CLI

"BASH API" : "♥BOX"

http://astroport.localhost:1234

Une fois votre Station Astroport démarrée:

  • le port 1234 publie API (REPONSE PORT TCP 45780 45781 ( jusqu'à ... 45790 )

  • le port 12345 publie MAP(*) (CARTE DE L'ESSAIM - BOOSTRAP / STATIONS)

  • le port 33101 publie G1BILLETS (REPONSE PORT TCP 33102)

  • le port 8080, 4001 et 5001 sont ceux de la passerelle IPFS

Liste des ports à activer.

Pour ajouter votre Station à notre essaim, inscrivez l'IP de votre BOX dans le fichier ~/.zen/♥Box

exemple

frd@scorpio:~ $ cat ~/.zen/♥Box
86.210.184.173

⚠ API ASTROPORT = NETCAT SYSTEM ⚠

Astroport n'a pas besoin de serveur web pour fonctionner. Nous utilisons l'outil réseau le plus simple "netcat". Le fonctionnement donne accès à une "API BASH" (classée par le même nom que le premier paramètre GET reçu dans le répertoire API)

Les requêtes se font en HTTP GET sur le port 1234, le PORT de réponse se trouve dans la page chargée. Effectuez un regexp sur "url=ADRESSE:PORT" ou (♥‿‿♥) pour découvrir lequel.

Voici des exemples sur comment procéder.

RECUPERATION DU PORT DE REPONSE API : (♥‿‿♥)

CLI (BASH)

    # PLAYER COPIER "_URL_" FAVORITE
    curl -so ~/.zen/tmp/${MOATS}/astro.port "http://astroport.localhost:1234/?salt=0&pepper=0&g1pub=_URL_&email=${EMAIL}"

    TELETUBE=$(cat ~/.zen/tmp/${MOATS}/astro.port | grep "(♥‿‿♥)" | cut -d ':' -f 2 | cut -d '/' -f 3)
    TELEPORT=$(cat ~/.zen/tmp/${MOATS}/astro.port | grep "(♥‿‿♥)" | cut -d ':' -f 3 | cut -d '"' -f 1)

                sleep 30

    # RECUPERER SON JETON PLAYER
    curl -so ~/.zen/tmp/${MOATS}/astro.rep "http://$TELETUBE:$TELEPORT"

JS

Exemple :

var myURL = 'http://astroport.localhost:1234/?' + query;
async function fetchAstroport(myURL) {
      try {

         let one = await fetch(myURL); // Gets a promise
         var doc =  await one.text();
         var regex = /url='([^']+)/i; // Get response PORT
         var redirectURL = doc.match(regex)[1]

         console.log(redirectURL)

        setTimeout(function() {
                // let two = await fetch(redirectURL);
                // document.mydiv.innerHTML = await two.text(); // Replaces body with response
                window.open( redirectURL, "AstroTab");
        }, 5000);

      } catch (err) {
        console.log('Fetch error:' + err); // Error handling
      }
    }

Utilisez "astro.js"

    <script src="https://ipfs.asycn.io/ipfs/Qmae5v9zydax9u6C9ceDijURu5PYdd5avmv4NkenCw7RFv/astro.js"></script>

➤ PRIVATE ZONE (fonctionne sur toutes les Stations.)

/?salt=${SALT}&pepper=${PEPPER}&${APPNAME}=${WHAT}&${OBJ}=${VAL}...

Créer (ou téléporter) un PLAYER TW : OFFICIAL <3BOX :

GET /?salt=${SALT}&pepper=${PEPPER}&g1pub=${URLENCODEDURL}&email=${PLAYER}
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
g1pub string Required. Your prefered URL to copy video from
email email Required. Your email token

LOGOUT PLAYER (remove IPNS keys from Station)

GET /?salt=${SALT}&pepper=${PEPPER}&logout=${PLAYER}
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
logout string Required. Your email token

LOGIN PLAYER (Activate IPNS keys on Station)

GET /?salt=${SALT}&pepper=${PEPPER}&login=${PLAYER}
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
login string Required. Your email token

Définir le niveau ★ accordé à un "g1friend"

GET /?salt=${SALT}&pepper=${PEPPER}&friend=${G1PUB}&stars=${1:5}
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
friend string Required. G1PUB token of friend
stars number Required. Number between 1 to 5

Lire Messagerie de la base "GChange"

GET /?salt=${SALT}&pepper=${PEPPER}&messaging=on
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
messaging string Required. (on=json) output type

Conversion vers adresse IPNS

GET /?salt=${SALT}&pepper=${PEPPER}&getipns=on
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
getipns string Required on

AppName=testcraft : Enregistrer JSON

GET /?salt=${SALT}&pepper=${PEPPER}&testcraft=json&nodeid=_&dataid=$QRHASH
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
testcraft string Required AppNAME subcommand
${OBJ} ${VAL} depends on App

This IPFS object transfer needs that the client is using well configured WebRTC/IPFS relays Look for example in www/upload_to_astroport.html

    '/dns4/wrtc-star1.par.dwebops.pub/tcp/443/wss/p2p-webrtc-star',
    '/dns4/wrtc-star2.sjc.dwebops.pub/tcp/443/wss/p2p-webrtc-star'

Redirections

  • vers Gchange

/?salt=${SALT}&pepper=${PEPPER}&g1pub=on

  • vers TW

/?salt=${SALT}&pepper=${PEPPER}&g1pub=astro

Déclencher un Payement de Ğ1 à une G1PUB

GET /?salt=${SALT}&pepper=${PEPPER}&pay=1&g1pub=DsEx1pS33vzYZg4MroyBV9hCw98j1gtHEhwiZ5tK7ech
Parameter Type Description
salt string Required. Your passphrase one token
pepper string Required. Your passphrase two token
pay integer Required G1 AMOUNT
g1pub G1PUB Required destination "wallet key"

➤ PLAYER ZONE (disponible uniquement sur la Station qui héberge ${PLAYER})

/?player=${PLAYER}&${APPNAME}=${WHAT}&${OBJ}=${VAL}...

Exporter Tiddlers.json depuis son TW selon valeur des "tags" ( ici TAG=G1CopierYoutube)

GET /?player=${PLAYER}&moa=json&tag=G1CopierYoutube
Parameter Type Description
player string Required. Your EMAIL token
moa string Required APP = output format
tag ${VAL} TW filtering default G1CopierYoutube

Lancer la copie d'une URL (youtube | pdf ) par PLAYER dans son TW

GET /?player=${PLAYER}&youtube=URLENCODED
Parameter Type Description
player string Required. Your EMAIL token
youtube or pdf string Required URL kind = URL

➤ AMZQR : Create a QRCode with "amzqr"

/?amzqr=${URLENCODEDSTRING}&logo=${IMAGE}

Parameter Type Description
amzqr string Required the qrcode string
logo string Required ./images/${IMAGE}.png

check available "logo.png" in ./images

➤ UPLANET : Create Umap, AstroID & ZenCard for PLAYER (email)

/?uplanet=${PLAYER}&salt=${LAT}&pepper=${LON}&g1pub=${PASS}

Parameter Type Description
uplanet email Required Your EMAIL token
salt decimal Required LATITUDE with 2 decimals digits
pepper decimal Required LONGITUDE with 2 decimals digits
g1pub string Facultative choose Umap AstroID PASS

Create à Umap key (LAT/LON), then a PLAYER TW with GPS as Umap IPNS reference This API is used by OSM2IPFS code.

DEMO : https://ipfs.copylaradio.com/ipns/copylaradio.com

QRCODE (API SandBox)

GET /?qrcode=${G1PUB} | ${ASTRONAUTENS} | ${PGP_ASTROID_STRING}
Parameter Type Description
qrcode string Required. Your G1PUB or ASTRONAUTENS or PGP_ASTROID token

Look for details & extend as you like in ~/.zen/Astroport.ONE/API/QRCODE.sh

CODE BEHAVIOUR. monitor && rewards || fork signal

http://astroport.localhost:1234/?qrcode=G1G1Serie&tw=k51qzi5uqu5dgobi9ozzzvdftqfd3hd7a1488nzymky1edz8j779jov7sbemc0 redirect to http://ipfs.localhost:8080/ipns/k51qzi5uqu5din47zmnzk6tmk1tjqaeaj9pbb3qilmstbsf9uyc12qpdmigtd3/

http://astroport.localhost:1234/?qrcode=G1G1Serie&tw=k51qzi5uqu5dgobi9ozzzvdftqfd3hd7a1488nzymky1edz8j779jov7sbemc0&json redirect to pure "tag=" result json

  • Is G1PUB ... (FROM NEW ASTROID or empty G1BILLET)

    • If balance is "null" : Send 1 G1 (G1BILLET)
    • if GChange+ account exists : send 10 G1
    • if Cesium+ account exists : send 50 G1
  • Is ASTROID

    • decode with PASS and make operation (same functions as SALT API are available)

The Art of key derivation, chaining & use

In order to make (a little) clear how we use cryptography,

We choose to use "NaCl" (secret1 / secret) 2 key generation, so it is easy to understand Web3 mechanism.

(SECRET1/SECRET2) mixing

  • If PLAYER key is (SECRET1 / SECRET2) and G1PUB and EMAIL + TW
    • feed key (SECRET1 / SECRET2 G1PUB)
    • wishes keys are (SECRET2 / WishName EMAIL)
      • sub-wishes are (EMAIL / G1WishName G1PUB)
        • wish-billets are (EMAIL_dice_words / G1WishName G1PUB)

This way PLAYER TW capable of retrieving and never loose its data. It is writen into IPFS... So recreate the key anywhere makes you get your data from friends you shared it with.

Cross (G1PUB) keys

Between PlayerA (AG1PUB) & PlayerB (BG1PUB) obvious communication channel keys are existing :

(AG1PUB / AG1PUB) - A knock on the door (AG1PUB / BG1PUB) - From A to B channel (BG1PUB / AG1PUB) - From B to A channel (BG1PUB / BG1PUB) - B knock on the door

We can use this to implement protocols, for exemple : To ollow PlayerA / PlayerB to become friends

A write a KNOCK.AG1PUB file + signature using (BG1PUB / BG1PUB) keygen IPNS key, Then B reply with the same KNOCK at (AG1PUB / AG1PUB) address

A/B - B/A keys can be used as bidirectionnal encrypted data channels.

In a well formed IPFS swarm, we could even send video... Check code in /tools/streaming/

(LON / LAT) keys

NaCl keys can be initiated with GPS Geoloc and receive shared informations. Using the same A/B swapping method, any A place have also a communication channel with B place ;)

(COUNTRY / ZIP) keys

For a town key, we could use country code + ZIP code, ... etc Many public application can be easily addressed like that

As these keys are discoverable, the channel can be hijacked by anyone. So ASTROBOT while applying ScuttleButt replications will ".chain.ts" data and check for protocol respect.

Data can't be lost, but protocol chain can be break ! In case of some annoyance, we can monitor IPFS protocol to identify which IPFSNODEID key is acting badly and apply reaction based on DEFCON level (look into astrXbian code)

LOW RESSOURCE STATION CAN ACTIVATE LOW MODE (disable ipfs daemon)

~/.zen/Astroport.ONE/tools/cron_VRFY.sh LOW

sudo systemctl restart astroport.service
sudo systemctl restart g1billet.service

STATION : Show Station PLAYER's G1 investments levels

GET /?qrcode=station

STATION MAP & PLAYER DATA PROPAGATION

Chaque Station collecte et publie sur sa clef "self" (/ipns/$IPFSNODEID) les liens vers le cache de l'ensemble de l'essaim http://localhost:12345 renvoi un json

{
    "created" : "202304111854481040",
    "hostname" : "kitty.localhost",
    "myIP" : "192.168.1.14",
    "ipfsnodeid" : "12D3KooWK1ACupF7RD3MNvkBFU9Z6fX11pKRAR99WDzEUiYp5t8j",
    "astroport" : "http://192.168.1.14:1234",
    "g1station" : "http://ipfs.localhost:8080/ipns/12D3KooWK1ACupF7RD3MNvkBFU9Z6fX11pKRAR99WDzEUiYp5t8j",
    "g1swarm" : "http://ipfs.localhost:8080/ipns/k51qzi5uqu5djv0qz9wkl8i94opzm62csh56mnp9zove8i543e4vv4cy9gvr1o"
}

Parameter Description
created date de creation du document
hostname nom de la station
myIP adresse IP de la station
ipfsnodeid date de creation du document
astroport Lien vers l'API de la station
g1station Lien vers la carte PLAYER de la Station
g1swarm Lien vers la carte des cartes des Stations de l'essaim

Afin de propager la carte chaque Stations lors de son raffraichissement de cache demande aux Boostrap de la récupérer

STATION MAP UPSYNC : http://$nodeip:12345/?${GNODEID}=${IPFSNODEID}

20H12

Chaque jour, les ASTROBOTs captent les de leurs PLAYERs puis exécutent le protocole de synchronisation Ŋ1

20H12.sh

Ils analysent les données et extraient des flux json selon les G1Voeu présent dans chaque TW.

Le niveau informationnel de confiance exploré permet de proposer des alertes issues du niveau Ŋ2.

EXEMPLE DE FLUX TW :

TW FEEDS

IPFS : UN STOCKAGE INALTERABLE ET INTELLIGENT

[

"The Barefoot Architect" de Johan Van Lengen.

Lignes de commandes

ipfs ls Qme6a6RscGHTg4e1XsRrpRoNbfA6yojC6XNCBrS8nPSEox/
ipfs cat QmbfVUAyX6hsxTMAZY7MhvUmB3AkfLS7KqWihjGfu327yG > /tmp/vdoc.pub_the-barefoot-architect.pdf && xdg-open /tmp/vdoc.pub_the-barefoot-architect.pdf

Après un passage par ajouter_media.sh

Les données sont stockées dans des Tiddlers

Foret Enchantée - PROJET ASTROPORT.pdf

https://ipfs.copylaradio.com/ipfs/QmUtGpGeMZvwp47ftqebVmoFWCmvroy5wEtWsKvWvDWJpR


SIMULATIONS LOOPY

Simulateur Astronaute/Voeux

Essaim Astroport.ONE

Stargazers over time

Stargazers over time

CREDITS

This "digital art" structure is a selection of some of the most valuable Free & OpenSource Software I ever had in my hand. Credits is going to all the kindness and care provided to make valuable and secure software available for all

Did you ever dring a beer bought in G1 ?

You can pay me a beer or more by contributing to our OpenCollective https://opencollective.com/monnaie-libre#category-ABOUT

IPFS Ecosystem Directory Submission Form

https://airtable.com/appLWiIrg9SQaEtEq/shrjwvk9pAeAk0Ci7