This project demonstrates how to migrate the front page of the HTTPS Status Cats website to Web3.Storage. The script downloads the HTML source, images, and CSS from the website, adjusts the paths, and prepares the files for manual upload to Web3.Storage.
This project involves the following steps:
- Download the front page HTML, images, and CSS from the HTTPS Status Cats website.
- Adjust the paths in the HTML to ensure that images and CSS are correctly referenced.
- Prepare the files for manual upload to Web3.Storage.
- Manually upload the files to Web3.Storage.
- Node.js and npm installed on your machine. You can download and install them from Node.js official website.
- Access to the Web3.Storage console and an existing space where you can upload files.
- Clone the repository:
git clone https://github.com/hakierka/http-cat-to-web3storage.git cd http-cat-to-web3storage
- Install the required dependencies:
npm install axios cheerio
We use axios to download HTML content and cheerio to parse the HTML and extract image and CSS links.
- Run the script to download HTML and assets:
node migrate_http_cat_to_web3storage.js
- The script will:
- Download the HTML content of the HTTPS Status Cats website.
- Parse the HTML to find and download image and CSS files.
- Adjust the paths in the index.html file to ensure all assets are correctly referenced.
- Save the files locally.
- Sign and log in to the Web3.Storage console.
- Create and Navigate to your space.
- Use the "Upload" feature to manually upload the index.html, image files, and CSS files you downloaded.
- Follow the prompts to complete the upload process.
You can access the uploaded content via the following URL: https://bafybeica2wh4dx3jo6o2xzu5tm5jqweo6svki4jlzqhaiw3yvj5kmqueqm.ipfs.w3s.link/
- Single Upload as a Directory: Easier management, consistent structure, and single URL for all assets, but larger uploads can be slower and more prone to failure.
- Separate Uploads for Each File: More granular control, easier to retry individual uploads if they fail, but more complex management with each file having its own URL.