Deploy a dapp on a decentralised cloud service(spheron).

January 1, 2024 (8mo ago)

Introduction

In this tutorial, we will be learning how to deploy a dapp built using celo composer on a decentalised cloud service called spheron protocol.

Prerequisites​

To start building, you’ll need a basic understanding of web development, Node (v12), yarn, and Git.

Celo Composer

The easiest way to get started with Celo Composer is using @celo/celo-composer . This CLI tool enables you to quickly start building dApps on Celo for multiple frameworks including React, React Native (w/o Expo), Flutter, and Angular. You can create the dApp using the default Composer templates provided by Celo. In our case, we will work with react, specifically NextJS. The stack included in celo composer:

Spheron Protocol

Spheron Protocol is an all-in-one decentralized platform for automating modern dapps.

They provide a frictionless developer experience to take care of the hard things: deploying instantly, scaling automatically, and serving personalized content on decentralized networks.

Let's start building:


Getting Started

  1. Bootstrap the application using this Celo Composer command.
npx @celo/celo-composer create
  1. Select React framework(NextJS)
NextJS
  1. Select react-celo as the web3 library
NextJS
  1. Select none for the smart contract framework since we’ll be working with the 0x Protocol API.
NextJS
  1. Select No for subgraph
NextJS
  1. Give a name to your project and you are done.
NextJS

Launch the app in your code editor then install the dependencies required in the project. In the root directory, run

yarn

//or

npm install

Upload Project to Github

  • Navigate to your repositories
NextJS
  • Give the repository a name.
NextJS
  • Click on create repository or press enter.
NextJS
  • Follow the guide to upload your project on github
NextJS

Deploying the App on Spheron

NextJS
  • Click "Sign Up” button
NextJS
  • Click "Continue with GitHub”
NextJS
  • Select an organisation of your choice.
NextJS
  • Click "New Project”
NextJS
  • Click "Github”
NextJS
  • Pick the github account.
NextJS
  • Click the "Search repository" field and search the repository that you want to deploy.
NextJS
  • Select "Filecoin" or "IPFS”
NextJS
  • Input the directory with react application which is "packages/react-app”
NextJS
  • Pick the Javascript framework i.e NextJS.
NextJS
  • Click "Deploy”
NextJS
  • Check the logs for the installation process.
NextJS

Testing the App

NextJS
  • Click "Connect”
NextJS
  • Click "MetaMask” or any other wallet of your choice.
NextJS

Conclusion

With the assistance of Spheron protocol, you have the capability to continue developing your application, and once you push your changes to GitHub, they are automatically deployed through your deployed link. This is made possible by the built-in CI/CD workflow.

Why choose Spheron Protocol

Here are reasons why you should use spheron to deploy your decentralised app:

  • Secure data storage: Spheron Protocol utilizes blockchain technology to provide secure and tamper-proof data storage. The data is distributed across the network and is protected by strong encryption and access controls, ensuring that it is only accessible to authorized parties.

  • Data privacy and ownership: With Spheron Protocol, users have full control and ownership of their data. They can choose who has access to their data and can revoke access at any time. This ensures that user privacy is protected and gives users the confidence to share their data on the platform.

  • Scalability: Spheron Protocol is designed to be highly scalable and can handle large volumes of data and transactions. This makes it suitable for a wide range of applications that require high performance and throughput.

  • Interoperability: Spheron Protocol is designed to be interoperable with other blockchain networks and protocols, making it easier for developers to integrate their apps with the platform.

  • Incentivization: Spheron Protocol provides incentives for users to participate in the network by offering rewards for contributing computing resources and validating transactions. This incentivizes users to help secure the network and ensure its reliability.

  • Lower costs: Spheron Protocol can help reduce the costs of data storage and management by eliminating the need for centralized servers and intermediaries. This can result in significant cost savings for businesses and organizations.

  • Community support: Spheron Protocol has an active and growing community of developers, users, and enthusiasts who are committed to building a decentralized data ecosystem. This community provides support, feedback, and resources to help developers build and deploy their decentralized apps on the platform.

  • Use cases: Spheron Protocol has a wide range of potential use cases in various industries such as healthcare, finance, supply chain management, and more. By deploying your decentralized app on Spheron Protocol, you can tap into this growing market and leverage the benefits of blockchain technology.

About the Author

I am Dennis Kimathi, a UI/UX designer, full-stack developer, and blockchain enthusiast. I have a strong passion for creating user-centered designs that are not only aesthetically pleasing but also efficient and intuitive to use. Over the years, I have honed my skills in developing web applications that are robust, scalable, and secure, thanks to my experience in full-stack development.

As a blockchain enthusiast, I am constantly exploring and learning about the potential of this technology and how it can be applied in various industries. I believe that blockchain has the potential to revolutionize the way we do things, from finance to healthcare and beyond. Its ability to provide decentralized, secure, and transparent systems has the potential to bring about significant changes that will benefit society.

Fun fact about me, i am into archeoastronomy.

Resources