Skip to content

Commit

Permalink
Merge branch 'dev' into fix(web)/skeletons-styling-dark-and-light-modes
Browse files Browse the repository at this point in the history
  • Loading branch information
kemuru authored Aug 28, 2023
2 parents cbd5b6f + f6c2582 commit 9afac7c
Show file tree
Hide file tree
Showing 6 changed files with 104 additions and 0 deletions.
1 change: 1 addition & 0 deletions contracts/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
"bot:relayer-from-chiado": "NODE_NO_WARNINGS=1 NODE_OPTIONS=--experimental-fetch hardhat run ./scripts/disputeRelayerBotFromChiado.ts",
"bot:relayer-from-goerli": "NODE_NO_WARNINGS=1 NODE_OPTIONS=--experimental-fetch hardhat run ./scripts/disputeRelayerBotFromGoerli.ts",
"bot:relayer-from-hardhat": "NODE_NO_WARNINGS=1 NODE_OPTIONS=--experimental-fetch hardhat run ./scripts/disputeRelayerBotFromHardhat.ts",
"bot:disputor": "NODE_NO_WARNINGS=1 yarn hardhat run ./scripts/disputeCreatorBot.ts",
"etherscan-verify": "hardhat etherscan-verify",
"sourcify": "hardhat sourcify --write-failing-metadata",
"size": "hardhat size-contracts --no-compile",
Expand Down
78 changes: 78 additions & 0 deletions contracts/scripts/disputeCreatorBot.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
import env from "./utils/env";
import loggerFactory from "./utils/logger";
import hre = require("hardhat");
import { KlerosCore, DisputeResolver } from "../typechain-types";
import { BigNumber } from "ethers";
const { ethers } = hre;

const HEARTBEAT_URL = env.optionalNoDefault("HEARTBEAT_URL_DISPUTOR_BOT");
const loggerOptions = env.optionalNoDefault("LOGTAIL_TOKEN_DISPUTOR_BOT")
? {
transportTargetOptions: {
target: "@logtail/pino",
options: { sourceToken: env.require("LOGTAIL_TOKEN_DISPUTOR_BOT") },
level: env.optional("LOG_LEVEL", "info"),
},
level: env.optional("LOG_LEVEL", "info"), // for pino-pretty
}
: {};
const logger = loggerFactory.createLogger(loggerOptions);

export default async function main() {
logger.info("Starting up");

const core = (await ethers.getContract("KlerosCore")) as KlerosCore;
const resolver = (await ethers.getContract("DisputeResolver")) as DisputeResolver;

if (HEARTBEAT_URL) {
logger.debug("Sending heartbeat");
fetch(HEARTBEAT_URL);
} else {
logger.debug("Heartbeat not set up, skipping");
}
const extraData =
"0x" +
"0000000000000000000000000000000000000000000000000000000000000001" + // courtId 1
"000000000000000000000000000000000000000000000000000000000000000B" + // minJurors 11
"0000000000000000000000000000000000000000000000000000000000000002"; // disputeKitId 2
const templates = [
`{"title":"A reality.eth question","description":"A reality.eth question has been raised to arbitration.","question":"**Kleros Moderate:** Did the user, **degenape6** (ID: 1554345080), break the Telegram group, ***[Kleros Trading Group]()*** (ID: -1001151472172), ***[rules](https://ipfs.kleros.io/ipfs/Qme3Qbj9rKUNHUe9vj9rqCLnTVUCWKy2YfveQF8HiuWQSu/Kleros%20Moderate%20Community%20Rules.pdf)*** due to conduct related to the ***[message](https://t.me/c/1151472172/116662)*** (***[backup](https://ipfs.kleros.io/ipfs/QmVbFrZR1bcyQzZjvLyXwL9ekDxrqHERykdreRxXrw4nqg/animations_file_23.mp4)***)?","answers":[{"id":"0x01","title":"Yes","reserved":false},{"id":"0x02","title":"No","reserved":false},{"id":"0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF","title":"Answered Too Soon","reserved":true}],"policyURI":"/ipfs/QmZ5XaV2RVgBADq5qMpbuEwgCuPZdRgCeu8rhGtJWLV6yz","frontendUrl":"https://reality.eth.limo/app/#!/question/0xe78996a233895be74a66f451f1019ca9734205cc-0xe2a3bd38e3ad4e22336ac35b221bbbdd808d716209f84014c7bc3bf62f8e3b39","arbitrableChainID":"100","arbitrableAddress":"0x2e39b8f43d0870ba896f516f78f57cde773cf805","arbitratorChainID":"421613","arbitratorAddress":"0xD08Ab99480d02bf9C092828043f611BcDFEA917b","category":"Oracle","lang":"en_US","specification":"KIP99"}`,
`{"title":"Add an entry to Ledger Contract Domain Name registry v2","description":"Someone requested to add an entry to Ledger Contract Domain Name registry v2","question":"Does the entry comply with the required criteria?","answers":[{"title":"Yes, Add It","description":"Select this if you think the entry complies with the required criteria and should be added."},{"title":"No, Don't Add It","description":"Select this if you think the entry does not comply with the required criteria and should not be added."}],"policyURI":"/ipfs/QmW3nQcMW2adyqe6TujRTYkyq26PiDqcmmTjdgKiz9ynPV","frontendUrl":"https://curate.kleros.io/tcr/100/0x957a53a994860be4750810131d9c876b2f52d6e1/0xc2c1aa705632f53051f22a9f65967c0944370020a7489aba608bd0d755ca1234","arbitratorChainID":"421613","arbitratorAddress":"0x791812B0B9f2ba260B2DA432BB02Ee23BC1bB509","category":"Curation","specification":"KIP0X","lang":"en_US"}`,
`{"title":"Omen Question: News & Politics","description":"This reality dispute has been created by Omen, we advise you to read [the Omen Rules](https://cdn.kleros.link/ipfs/QmU1oZzsduGwtC7vCUQPw1QcBP6BDNDkg4t6zkowPucVcx) and consult the evidence provided in [the Market Comments](https://omen.eth.limo/#/0x95b2271039b020aba31b933039e042b60b063800).","question":"**Assuming that today is December 20th 2020, will Joe Biden win the 2020 United States presidential election?**","answers":[{"title":"Yes"},{"title":"No"}],"policyURI":"/ipfs/QmU1oZzsduGwtC7vCUQPw1QcBP6BDNDkg4t6zkowPucVcx","frontendUrl":"https://omen.eth.limo/#/0x95b2271039b020aba31b933039e042b60b063800","arbitratorChainID":"421613","arbitratorAddress":"0x791812B0B9f2ba260B2DA432BB02Ee23BC1bB509","category":"Oracle","specification":"KIP0X","lang":"en_US"}`,
`{"title":"Proof of Humanity Registration Request","description":"A request to register the specified entry to a list of provable humans.","question":"Should the request to register be accepted?","answers":[{"title":"Yes","description":"Accept the request to register the entry."},{"title":"No","description":"Deny the request."}],"policyURI":"/ipfs/QmYPf2fdSyr9BiSy6pJFUmB1oTUPwg6dhEuFqL1n4ZosgH","frontendUrl":"https://app.proofofhumanity.id/profile/0x00de4b13153673bcae2616b67bf822500d325fc3?network=mainnet","arbitratorChainID":"421613","arbitratorAddress":"0x791812B0B9f2ba260B2DA432BB02Ee23BC1bB509","category":"Curated List","specification":"KIP0X","lang":"en_US"}`,
];
const randomTemplate = templates[Math.floor(Math.random() * templates.length)];
const nbOfChoices = 2;
const cost = (await core.functions["arbitrationCost(bytes)"](extraData)).cost;
const tx = await resolver.createDisputeForTemplate(
extraData,
randomTemplate,
"disputeTemplateMapping: TODO",
nbOfChoices,
{
value: cost,
}
);

logger.info(`Dispute creation tx: ${tx.hash}`);
const blockNumber = await tx.wait().then((receipt) => receipt.blockNumber);
const disputeId = await resolver
.queryFilter(resolver.filters.DisputeRequest(), blockNumber, blockNumber)
.then((events) => BigNumber.from(events[0].args[1]));
logger.info(`Dispute created with disputeId ${disputeId.toString()}`);

logger.info("Shutting down");
await delay(2000); // Some log messages may be lost otherwise
}

const delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));

main()
.then(() => process.exit(0))
.catch((error) => {
console.error(error);
process.exit(1);
})
.finally(() => {
logger.flush();
});
1 change: 1 addition & 0 deletions cspell.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
"datetime",
"devnet",
"Devnet",
"DISPUTOR",
"dockerhost",
"Ethfinex",
"gluegun",
Expand Down
2 changes: 2 additions & 0 deletions services/bots/testnet/bots.env.testnet.example
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,11 @@ SUBGRAPH_URL=https://api.thegraph.com/subgraphs/name/alcercu/kleroscoretest
LOG_LEVEL=debug
LOGTAIL_TOKEN_KEEPER_BOT=<optional token>
LOGTAIL_TOKEN_RELAYER_BOT=<optional token>
LOGTAIL_TOKEN_DISPUTOR_BOT=<optional token>

# Heartbeat
HEARTBEAT_URL_KEEPER_BOT=<optional url>
HEARTBEAT_URL_RELAYER_BOT=<optional url>
HEARTBEAT_URL_DISPUTOR_BOT=<optional url>

DISPUTES_TO_SKIP=
10 changes: 10 additions & 0 deletions services/bots/testnet/compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,16 @@ services:
- type: bind
source: ./pm2.config.keeper-bot.${DEPLOYMENT}.js
target: /usr/src/app/contracts/ecosystem.config.js

disputor-bot:
container_name: disputor-bot-${DEPLOYMENT:?error}
extends:
file: ../base/bot-pm2.yml
service: bot-pm2
volumes:
- type: bind
source: ./pm2.config.disputor-bot.${DEPLOYMENT}.js
target: /usr/src/app/contracts/ecosystem.config.js

relayer-bot-from-chiado:
container_name: relayer-bot-from-chiado-${DEPLOYMENT:?error}
Expand Down
12 changes: 12 additions & 0 deletions services/bots/testnet/pm2.config.disputor-bot.testnet.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
module.exports = {
apps: [
{
name: "disputor-bot-testnet",
interpreter: "sh",
script: "yarn",
args: "bot:disputor --network arbitrumGoerli",
restart_delay: 43200000, // 12 hours
autorestart: true,
},
],
};

0 comments on commit 9afac7c

Please sign in to comment.