Censorship-resistant, tamper-proof and privacy compliant cloud solution, open-source, fully decentralized and built on top of InterPlanetary File System (IPFS)
hexa is a fully decentralized and open-source cloud solution which replace traditional cloud providers having centralized governance, cumbersome infrastructure, inadequate security and privacy measures with users datasets.
hexa is build on top of IPFS and inherits all the features of Blockchain Technology to emerge as an immutable, censorship-resistant, tamper-proof and privacy complient with user dataset.
hexa integrat IPFS Core powered by Filecoin to enable users to store, manage and share their datas in a decentralized way. Few of the core value propositions are:
-
Increased User Adoption: Providing a smooth and intuitive process with seamless user experience to store, manage and share datas in a decentralized way will increase the adoption of IPFS and Filecoin.
-
Real-world utility: hexa provide a real-world utility for censorship-resistant, tamper-proof and privacy complient cloud solution by providing multi services composition that allow users to manage datas with total privacy and security controls of access by using Encryption and Decryption technologies to increase data acces security.
File Management
- Create folder
- Delete folder
- Rename folder
- Move folder
- List files from folder
- Search files in folder
- Upload files to specific folder
- Download file
- Delete file
- Rename file
- Move file
- Share copy file with public url link
- Download page for public IPFS hosted file
- Share copy file with custom access controls
- Notify user from shared encrypted file
- Preview file in app
NFTs Management
- List NFTs from connected wallet
- Preview NFTs detail information
- Search NFTs by name
- Filter NFTs by chain
Tokens Management
- List tokens from connected wallet
- List tokens from others wallet (watch mode)
- Get realtime tokens price
- Display tokens price 24h change in percents
Others
- EVM chain support
- Authentication with email support
- Shared file Notifications
- Data encryption with EIP-2844 standard
- Files access control with wallet address
- Desktop & cross platform support using PWA technology
- Define IPFS service with user API Key
- IFPS Core Browser implementation of the IPFS protocol to manage files storage and retrieval to IPFS network
- Pinata Default pinning CID service to pin files to IPFS network
- Web3.storage Alternative pinning CID service available and configurable with user API Key
- Ceramic Decentralized database to manage storage metadata files and user profile data
- XMTP Decentralized messaging service to manage in app notifications and messaging
- Ceramic 3id Connect Decentralized authentication service to manage user identity and Cryptography Access Control
- Ethersjs Ethereum SDK to manage Web3 wallet connection and account management
- Magic.link SDK to onboard users to web3 apps
- Covalent Unified API bringing visibility to billions Web3 data points
- Valist Software distribution tool to manage releases and updates hosted on IPFS
hexa is a web application that can be used in any modern browser.
You can also install hexa as a desktop application using Progressive Web App (PWA) technology by click install
icon from browser url section or from options
section of your browser. You can find more informations about PWA installation and specification here.
Distribution link to install hexa PWA application: https://hexaonelabs.github.io/hexa/
- Clone the hexa repository
- Install dependencies using NodeJS and NPM
- Install Nx Workspace CLI to manage workspace project
- Provide environment variables in
.env
file (seeEnvironment Variables
section) - Run developpment server using
nx serve
command will open the hexa application in the browser - This project was generated using Nx Workspace.
- Run
nx build:browser
to build the hexa application for the browser as PWA.
The build artifacts will be stored in the dist/
directory.
hexa is deployed automatically using Github Actions. Every commit to the main
branch will trigger a new deployment.
- Run
npm run docs:browser
to generate the appplication documentation
The documentation will be generate in the dist/
directory. Open the dist/compodoc/browser/index.html
file in browser to see the documentation as website.
Environment variables are set in the .env
file in the root of the project. The following file .env.example
at the root of the project contains the list of environment variables used in the project with example values.
Environment variables can be update for each mode. Go to the environment
folder and update the environment.{MODE}.ts
file to change the environment variables for the desired mode.
Thanks for taking the time to help out and improve the project! π
The following is a set of guidelines for contributions and may change over time. Feel free to suggest improvements to this document in a pull request!
See CONTRIBUTING.md
Project is Open Source and available under the MIT License.
-
@fazionico - Nicolas Fazio
Software Architect & Blockchain Developer
Mr. Fazio is a software architect and blockchain developer with over 15 years of industry experience. He has worked on a variety of projects ranging from cloud enterprise software to blockchain applications focusing last 3 years exclusively in the Web 3 industry. He is passionate about building decentralized solutions and is currently working on the hexa project.
If you like this project, please consider supporting it by giving a βοΈ on Github and sharing it with your friends!