# 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:
-
Registro de contribuyentes: Los administradores pueden registrar nuevos contribuyentes en el sistema.
-
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 . -
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. -
Premios: Se distribuyen premios monetarios y NFTs a los tres mejores clasificados en cada ronda de votación.
-
Consulta de reputación: Los miembros pueden consultar su reputación acumulada y su posición en la tabla de clasificación.
-
Consulta de fondos del premio: Los miembros pueden consultar los fondos acumulados en el premio de la ronda actual
-
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"
- 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});
- 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
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"
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
Si deseas contribuir a este proyecto, ¡no dudes en hacerlo! Puedes enviar problemas (issues) o solicitudes de extracción (pull requests) en el repositorio. 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)