Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/akhileshthite/dtube
Decentralized video sharing & social media platform on Ethereum blockchain.
https://github.com/akhileshthite/dtube
blockchain dapp ethereum hacktoberfest hactoberfest2022 social-media solidity web3
Last synced: about 2 months ago
JSON representation
Decentralized video sharing & social media platform on Ethereum blockchain.
- Host: GitHub
- URL: https://github.com/akhileshthite/dtube
- Owner: akhileshthite
- License: mit
- Created: 2021-07-29T14:02:19.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-09-15T10:42:49.000Z (over 1 year ago)
- Last Synced: 2024-11-10T01:24:10.034Z (about 2 months ago)
- Topics: blockchain, dapp, ethereum, hacktoberfest, hactoberfest2022, social-media, solidity, web3
- Language: JavaScript
- Homepage: https://dtube-eth.on.fleek.co
- Size: 5.36 MB
- Stars: 80
- Watchers: 3
- Forks: 123
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
DTube
Decentralized video sharing & social media platform on Ethereum blockchain.
Website: https://dtube-eth.on.fleek.co
## Contracts
- https://goerli.etherscan.io/address/0x678af4458950d0aefbc427e663050f50ebdab52a
- https://mumbai.polygonscan.com/address/0xffded6c68ccf4ed30d2b9c85ba21a926cccc8e0e
> ⚠️ Deprecated chains, [learn more](https://blog.ethereum.org/2022/06/21/testnet-deprecation):
- https://rinkeby.etherscan.io/address/0xcda87299367d6b29fef13ca08448bfaaf2e4a175
- https://ropsten.etherscan.io/address/0xc6eb38be0949a63f7c3ac36a053de209970fa19b## About
> ⚠️ Use this DApp for educational purposes only! DTube is not responsible for the harm caused by the content you're uploading.
DTube uploads the video files to [IPFS](https://ipfs.tech/) by using [web3.storage](https://web3.storage/) and stores those IPFS [CID](https://docs.ipfs.tech/concepts/content-addressing/)s to the blockchain network. Read the step-by-step tutorial 📝 "[Build a Social Media dApp & Deploy it on Polygon](https://learn.figment.io/tutorials/build-a-social-media-dapp-and-deploy-it-on-polygon)" to learn how to BUIDL it from scratch. If you have any queries, then please create a [discussion thread](https://github.com/akhileshthite/dtube/discussions).
This DApp is inspired by the [Dapp University](https://www.youtube.com/channel/UCY0xL8V6NzzFcwzHCgB8orQ) YouTube channel.
## Demo
## Development instructions
### Installation & setup
Make sure you have truffle installed on your computer.
```sh
# Install Truffle globally
npm install -g truffle
```- Ensure you create an `.env` file in `root` directory. Then to access the Ethereum network/node, create a project on [infura](https://infura.io/) and copy-paste the `infura project-id url` in `.env` with a variable name `REACT_APP_INFURA_RINKEBY` or `any network you like`.
```sh
REACT_APP_INFURA_RINKEBY=https://rinkeby.infura.io/v3/YOUR_PROJECT_ID
```- Paste the 12 word Secret Recovery Phrase of your (preferably newly generated and testnet-only) MetaMask wallet in `.env` with the variable name `REACT_APP_MNEMONIC`. This will be loaded by truffle at runtime, and the environment variable can then be accessed with `process.env.REACT_APP_MNEMONIC`.
```sh
REACT_APP_MNEMONIC=for example put your twelve word BIP39 secret recovery phrase here
```- For development and testing, you have to create your own web3.storage API token. To do that, `login to` [web3.storage](https://web3.storage/) -> `create a new API token` -> `copy the API token`.
Then create a `.env` file in the root directory.
```bash
REACT_APP_API_TOKEN=PASTE_YOUR_API_TOKEN
```OR
To develop on ganache blockchain, open ganache and import the accounts by adding your ganache private keys in MetaMask.
```sh
$ ganache-cli
```### Deployment
To deploy the smart contracts on blockchain networks, follow the given truffle command below.
```sh
# truffle migrate --network NETWORK_NAME
truffle migrate --network rinkeby# --reset: Run all migrations from the beginning, instead of running from the last completed migration.
```
For more information, read [truffle docs](https://trufflesuite.com/docs/truffle/).
### React client
Start react app.
```sh
npm start
Starting the development server...
```> ⚠️ If dealing with “JavaScript heap out of memory” error after `npm start` then use the following command to solve it: `export NODE_OPTIONS="--max-old-space-size=8192"`
> 📌 Note: I cannot update this repo (main-branch) with react hooks because the initial [educational tutorial](https://learn.figment.io/tutorials/build-a-social-media-dapp-and-deploy-it-on-polygon) was written with react classes. However, if you want to work on this issue, then please `fork` the main branch and push your changes to `react-hooks` branch and send a [pull request](https://github.com/akhileshthite/dtube/pulls) for the same.
## License
DTube is licensed under the [MIT license](https://github.com/AkhileshThite/DTube/blob/main/LICENSE).
Hope you've learned something new. Don't forget to leave a 🌟 and