DEV Community

Karim
Karim

Posted on

Décentraliser son site Web avec IPFS, Pinata, Infura et Cloudflare

IPFS, InterPlanetary File System (ou système de fichier inter-planétaire) est un système distribué de fichiers pair à pair qui ne dépend pas de serveurs centralisés. Son but est de connecter un ensemble d'équipements informatiques avec le même système de fichiers. D'une certaine manière IPFS est similaire au World Wide Web, à la différence qu'il peut être vu comme un essaim BitTorrent (Swarm) unique, qui échange des objets au sein d'un dépôt Git.

https://ipfs.io/

En d'autres termes, IPFS fournit un modèle de stockage par blocs adressable par contenu de haute capacité, utilisant des hyperliens pour l'accès. Ceci forme un graphe orienté acyclique de Merkle généralisé. IPFS combine une table de hachage, un échange de blocs encouragé et un espace de noms auto-certifié. IPFS n'a pas de point unique de défaillance et les nœuds n'ont pas besoin de se faire mutuellement confiance ...

Pour cette expérience, je pars d'un template Next.js fourni par Cosmic JS =>

https://github.com/cosmicjs/nextjs-website-boilerplate

que je charge avec ses dépendances dans une petite instance Ubuntu 18.04 LTS qui tourne dans Hetzner Cloud :

Je peux tester que ce template fonctionne bien localement :

et c'est le cas :

Je crée un fichier next.config.js pour profiter de la génération de contenu statique avec le module export => https://nextjs.org/learn/excel/static-html-export

et je modifie le fichier package.json en conséquence :

Je peux alors générer du contenu statique à partir de ce template :

Je peux le tester pour vérifier que mon site web est opérationnel :

Je récupère le binaire go-ipfs depuis son dépôt sur GitHub :

https://github.com/ipfs/go-ipfs/releases

que je charge sur mon instance :

Petite configuration pour une exposition globale des endpoints :

Et je lance le démon IPFS :

Je peux charger mon contenu statique dans IPFS :

Et je vérifie dans le dashboard proposé par IPFS que c'est le cas :

Le site web apparait localement à partir du Hash du répertoire chargé sur le port TCP 8080 :

mais également sur l'IPFS Gateway :

Ou également à partir de ce Hash sur la passerelle Cloudflare :

https://developers.cloudflare.com/distributed-web/ipfs-gateway/

J'utilise ipfs-deploy maintenant : https://github.com/ipfs-shipyard/ipfs-deploy

que j'installe sur mon instance :

Je vais avec cet utilitaire charger ce site web sur Infura qui fournit un accès API instantané et évolutif aux réseaux Ethereum et IPFS pour y connecter son application gratuitement ! https://infura.io/

C'est le cas avec le contenu statique du template :

Je peux également le déployer sur Pinata qui fournit également un stockage décentralisé : https://pinata.cloud

J'utilise encore une fois ipfs-deploy avec le provider Pinata après inscription et récupération des identifiants à charger dans .env :

Le contenu statique est chargé :

et exposé :

Quelques liens complémentaires :

https://medium.com/pinata/how-to-easily-host-a-website-on-ipfs-9d842b5d6a01

https://towardsdatascience.com/decentralizing-your-website-f5bca765f9ed

https://gist.github.com/claus/1287f47b5fbaaea338ac8a04d02bf258

À suivre !

Top comments (0)