polblancoo / ReputationSystem

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool


🦑 ink-examples Solución

# Contrato Reputation System

El contrato Reputation System permite administrar un sistema de reputación y votación, donde los participantes pueden votar por otros miembros y ganar premios en función de sus votos y posición en la votación.


# Funcionalidades clave

El contrato Reputation System incluye las siguientes funcionalidades:

  1. Registro de contribuyentes: Los administradores pueden registrar nuevos contribuyentes en el sistema.

  2. Votación: Los miembros pueden votar por otros miembros y ganar reputación
    , se modifico la consigna inicial para que el voto sea positivo y tenga un booster
    determinado en funcion de: % de votos obtenidos / total votos .

  3. Inicio y finalización de rondas de votación: Los administradores pueden iniciar y finalizar rondas de votación
    depositando en el contrato los tres premios a repartir.Lo ideal seria insertar un Timer a futuro.

  4. Premios: Se distribuyen premios monetarios y NFTs a los tres mejores clasificados en cada ronda de votación.

  5. Consulta de reputación: Los miembros pueden consultar su reputación acumulada y su posición en la tabla de clasificación.

  6. Consulta de fondos del premio: Los miembros pueden consultar los fondos acumulados en el premio de la ronda actual

  7. Se agrego en psp34 el ejemplo de como hacer un Upgrade del contrato. Nota: no olvidar cargar la metadata.jason del contrato "nuevo" , en el contrato "viejo"

Funciones claves:

  1. Inicio de una nueva ronda de votación
     let admin = ... // ID del administrador<br>
     let funds1 = ... // Fondos para el primer puesto
     let funds2 = ... // Fondos para el segundo puesto
     let funds3 = ... // Fondos para el tercer puesto
     let duration = ... // Duración de la ronda en segundos
     contract.start_voting_round(funds1, funds2, funds3, duration);

2.Votación por un miembro

   let voter = ... // ID del miembro que vota
   let target = ... // ID del miembro por el que se vota
   contract.vote(target, {value: 1});
  1. Finalización de una ronda de votación
   let admin = ... // ID del administrador
   contract.end_voting_round();

2.1.Consulta de la reputación total de un miembro

   let member = ... // ID del miembro
   let reputation = contract.get_total_reputation_by_account(member);

2.2.Consulta de los fondos del premio en una posición

      let position = ... // Posición en la ronda (1, 2 o 3)
   let prize_funds = contract.get_prize_funds(position);

2.3. Devuelve AccountId de posicion ganadora

      let position = ... // Posición en la ronda (1, 2 o 3)
     let winner_for_position(&self, position: u32)-> Result<AccountId, Error>

2.4. Devuelve AccountId del Contrato

     get_contract_account_id(&self) -> AccountId

Requisitos:

Ink! setup
Cargo-Contract
Descargar substrate-contracts-node-linux.tar.gz
Descargar swanky-node -nodo alternativo

Colocar substrate-contracts-node en una carpeta del PATH del sistema
Nota: Al correr el nodo , setting la variable de entorno CONTRACT_NODE="path/del nodo"

Software utilizado:

Software Versión

rustup 1.26.0 (5af9b9484 2023-04-05)
rustc 1.72.0 (5680fa18f 2023-08-23)
cargo 1.72.0 (103a7ff2e 2023-08-15)
cargo-contract 3.2.0-unknown-x86_64-unknown-linux-gnu
substrate-contracts-node o swanky


Contribución

Si deseas contribuir a este proyecto, ¡no dudes en hacerlo! Puedes enviar problemas (issues) o solicitudes de extracción (pull requests) en el repositorio.

Licencia

Este proyecto está bajo la licencia MIT. ![Licencia MIT]((https://github.com/polblancoo/ReputationSystem/blob/main/MIT.svg)https://github.com/polblancoo/ReputationSystem/blob/main/MIT.svg)

About


Languages

Language:Rust 88.5%Language:Shell 11.5%