An open API service indexing awesome lists of open source software.

https://github.com/keep-starknet-strange/art-peace

Competitive art canvas on Starknet
https://github.com/keep-starknet-strange/art-peace

cairo full-stack onchain-game starknet

Last synced: about 2 months ago
JSON representation

Competitive art canvas on Starknet

Awesome Lists containing this project

README

        


art_canvas

***Collaborative art canvas on Starknet***

[![Check Workflow Status](https://github.com/keep-starknet-strange/art-peace/actions/workflows/check.yml/badge.svg)](https://github.com/keep-starknet-strange/art-peace/actions/workflows/check.yml)
[![Build Workflow Status](https://github.com/keep-starknet-strange/art-peace/actions/workflows/build.yml/badge.svg)](https://github.com/keep-starknet-strange/art-peace/actions/workflows/build.yml)

[![Exploration_Team](https://img.shields.io/badge/Exploration_Team-29296E.svg?&style=for-the-badge&logo=)](https://github.com/keep-starknet-strange)

> Art Peace Round 2 is live!
> Check live stats on this cool [Dune Dashboard](https://dune.com/hessish/artpeace)
> And go place some pixels and draw cool shit you mfer! ==> [art-peace.net](https://www.art-peace.net)

## Overview

`art/peace` is a collaborative art game where users can place pixels on a large shared canvas and receive rewards for collaborating to build art. The game will run over X days, and end with a final snapshot of the board. The goal is to give users the feeling of collectively building on a highly responsive art canvas, which they can explore, interact with, and compete on.

Some of the features include :

- **Placing Pixels** : This will be the main user interaction, where every X minutes a user will be allowed to place a pixel onto the canvas.
- **Quests** : Tasks to get extra pixels to place on-top of the one every X minutes.
- **Voting** : In addition to the base colors, there will be a vote to add new colors to the palette every day.
- **Templates** : Artwork templates used to help communities collaborate on an art piece. Bounties can be added to a template to incentivize creation.
- **NFTs** : Mint NFTs from the canvas.

## Running

### Docker Run ( Recommended )

```bash
docker compose up
```

To stop the run use `Ctrl-C`.

For a complete reset of the state and rebuild of the containers use :

```bash
# WARNING! This will clear the state (volumes) of all the DBs and the Devnet
docker compose down --volumes
docker compose build
```

### Local Run

```bash
# Must install all the dependencies first
# Use npm install inside the `frontend` directory
# Change the user on `configs/database.config.json` for postgres
make integration-test-local
```

To stop the run use `Ctrl-C`.

### Component Run

Each component can also be run individually, check the [Components](#Components) section below for more details.

## Build

### Docker Build ( Recommended )

```bash
docker compose build
```

### Local Build

```bash
make build
```

### Component Build

Use the `make build-X` command for each corresponding component `X`. See the [Components](#Components) section below for more details.

## Components

- **Onchain:** [Starknet contract(s)](./onchain/) for trustless onchain interactions.
- **Backend:** [Monolithic Go backend](./backend/) for managing requests, interactions, and DBs.
- **Frontend:** [Reactjs application](./frontend/) for users to interact with.
- **Indexer:** [Apibara indexer](./indexer/) for monitoring Starknet events and forwarding to the DBs.
- **Postgres:** DB for storing general data used for analytics, frontend, and backend.
- **Redis:** In memory DB used to store the compressed `Canvas` data for fast retrieval
- **tests:** Integration tests for local, docker, ...

![art/peace diagram](./docs/diagrams/art-peace-diagram.png)

## Dependencies

Its recommended to use `docker compose` when building and running, so the only dependencies would be [docker](https://docs.docker.com/desktop/) and [docker compose](https://docs.docker.com/compose/install/linux/)

However, it might be worth running only certain components for development/testing sometimes. Each component has various dependencies, check [dependencies.txt](./dependencies.txt) for more details.

## References

- [Diagrams](./docs/diagrams/)
- [r/place technical document](https://www.redditinc.com/blog/how-we-built-rplace)
- [Telegram](https://t.me/art_peace_starknet)
- [OnlyDust](https://app.onlydust.com/p/artpeace)

## Contributors ✨

Thanks goes to these wonderful people. Follow the [contributors guide](https://github.com/keep-starknet-strange/art-peace/blob/main/CONTRIBUTING.md) if you'd like to take part.



Brandon R
Brandon R

πŸ’»
Adeyemi Gbenga
Adeyemi Gbenga

πŸ’»
Tristan
Tristan

πŸ’»
Abdulhakeem Abdulazeez Ayodeji
Abdulhakeem Abdulazeez Ayodeji

πŸ’»
Trunks @ Carbonable
Trunks @ Carbonable

πŸ’»
ptisserand
ptisserand

πŸ’»
Mubarak Muhammad Aminu
Mubarak Muhammad Aminu

πŸ’»


0xK2
0xK2

πŸ’»
Fishon Amos
Fishon Amos

πŸ’»
Xaxxoo
Xaxxoo

πŸ’»
Mano.dev
Mano.dev

πŸ’»
Abdulsamad sadiq
Abdulsamad sadiq

πŸ’»
Agada Gabriel
Agada Gabriel

πŸ’»
Abdulqahar Usman
Abdulqahar Usman

πŸ’»


Awe Olumide David
Awe Olumide David

πŸ’»
Catherine Jonathan
Catherine Jonathan

πŸ’»
Emmaunuel Ejembi
Emmaunuel Ejembi

πŸ’»
CollinsC1O
CollinsC1O

πŸ’»
Alfred Emmanuel
Alfred Emmanuel

πŸ’»
princeibs
princeibs

πŸ’»
Oshioke Salaki
Oshioke Salaki

πŸ’»


Caleb
Caleb

πŸ’»
Immanuelolivia
Immanuelolivia

πŸ’»
Stephanie Nwankwo
Stephanie Nwankwo

πŸ’»
Joy Adah
Joy Adah

πŸ’»
Na'omi Emmanuel Gift
Na'omi Emmanuel Gift

πŸ’»
Yusuf Habib
Yusuf Habib

πŸ’»
drspacemn
drspacemn

πŸ’»


Emmanuel A Akalo
Emmanuel A Akalo

πŸ’»
Kenee Patel
Kenee Patel

πŸ’»
BillXJ
BillXJ

πŸ’»
Jemiiah
Jemiiah

πŸ’»
Umar I Salihu
Umar I Salihu

πŸ’»
lfg2
lfg2

πŸ’»
Zintarh
Zintarh

πŸ’»


Naomi
Naomi

πŸ’»
Supreme Labs
Supreme Labs

πŸ’»
Aβ‚Ώdel ∞/21M
Aβ‚Ώdel ∞/21M

πŸ’»
jike
jike

πŸ’»
Rumia
Rumia

πŸ’»
Okoli Evans
Okoli Evans

πŸ’»
Iwueseiter
Iwueseiter

πŸ’»


Emmanuel Soetan
Emmanuel Soetan

πŸ’»
Emmanuel AgΓΌero
Emmanuel AgΓΌero

πŸ’»
Babs
Babs

πŸ’»
ADR!AN
ADR!AN

πŸ’»






Add your contributions



This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!