Using Mac OS
How to set up a local development environment using Mac OS.
Before building with Kotani Pay, you need to set up a development environment to make sure you have the proper tools to build an application. This setup includes a combination of general development tools and Celo specific tools.
Web2 Prerequisites
Xcode
Xcode is Apple's integrated development environment for macOS, used to develop software for macOS, iOS, iPadOS, watchOS, and tvOS.
While Xcode falls under the Celo Prerequisites, Xcode takes a long time to download, which is why it is first on this list. It's best to start this download first, or even start downloading it before going to bed (depending on your internet connection).
Node, NPM and NVM
Node
Node is a JavaScript runtime that allows you to execute JS code outside a web browser. It is an open-source server environment and runs on various platforms.
NPM
npm
stands for Node Package Manager and is the world's largest software registry. npm is what you'll use for installing published JS packages. npm comes bundled with Node, so you won't need to install it separately.
NVM
nvm
stands for Node Version Manager. Different projects often require different versions of Node, and nvm makes it easy to switch between those versions. This is recommended if you plan to develop a lot of JS-based applications and npm also recommends nvm. For Windows users, there are nodist and nvm-windows.
Install Node and npm via nvm
Verify the installation by running:
which should output nvm.
You can now install Node with nvm install <version>
. Celo requires using Node v12.x, so you need to install and use that specific version.
Homebrew
Homebrew is a way of managing packages on macOS.
Install Homebrew
Get the latest packages
Celo Prerequisites
Truffle
Since the Celo Blockchain has shared ancestry with Ethereum and maintains full EVM compatibility, you can use Ethereum tools to develop Celo applications. Truffle is a development framework for Ethereum and assists with writing your contracts, testing, and deploying.
Similar to how you might use a framework like React instead of vanilla JavaScript, you can use Truffle to abstract away a lot of the imperative details from Solidity (the language used to write smart contracts).
Install Truffle Version 5.4.0
Celo works best with truffle version 5.4.0. Install this specific version using the command below.
If you have worked with Truffle in the past, you may have installed a version that is incompatible with Celo. Use the commands below to uninstall your current version so that you can install truffle version 5.4.0.
Check Truffle Location
Remove Existing Installation
Last updated