Skip to content

Commit

Permalink
logs
Browse files Browse the repository at this point in the history
  • Loading branch information
darcys22 committed Apr 29, 2024
1 parent a0deaf8 commit ecdeba3
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 6 deletions.
18 changes: 18 additions & 0 deletions include/ethyl/logs.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
// logs.hpp
#pragma once

#include <string>
#include <vector>
#include <optional>

struct LogEntry {
std::string address; // Address from which this log originated
std::vector<std::string> topics; // Array of 0-4 32-byte data of indexed log arguments
std::string data; // One or more 32-byte non-indexed arguments of the log
std::optional<uint64_t> blockNumber; // Block number where this log was in (optional)
std::optional<std::string> transactionHash; // Hash of the transaction this log was created from (optional)
std::optional<uint32_t> transactionIndex; // Index of the transaction in the block (optional)
std::optional<std::string> blockHash; // Hash of the block where this log was in (optional)
std::optional<uint32_t> logIndex; // Index of the log in the block (optional)
bool removed; // True if log was removed due to a chain reorganization
};
3 changes: 3 additions & 0 deletions include/ethyl/provider.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,8 @@ class Provider {
std::optional<nlohmann::json> getTransactionReceipt(const std::string& transactionHash);
std::vector<LogEntry> getLogs(uint64_t fromBlock, uint64_t toBlock, const std::string& address);
std::vector<LogEntry> getLogs(uint64_t block, const std::string& address);
std::string getContractStorageRoot(const std::string& address, uint64_t blockNumberInt);
std::string getContractStorageRoot(const std::string& address, const std::string& blockNumber = "latest");

std::string sendTransaction(const Transaction& signedTx);
std::string sendUncheckedTransaction(const Transaction& signedTx);
Expand All @@ -102,6 +104,7 @@ class Provider {
std::string getBalance(const std::string& address);
std::string getContractDeployedInLatestBlock();

uint64_t getLatestHeight();
FeeData getFeeData();

private:
Expand Down
54 changes: 48 additions & 6 deletions src/provider.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,14 +33,15 @@ void Provider::disconnectFromNetwork() {
}

cpr::Response Provider::makeJsonRpcRequest(const std::string& method, const nlohmann::json& params) {
if (url.str() == "")
throw std::runtime_error("No URL provided to provider");
nlohmann::json bodyJson;
bodyJson["jsonrpc"] = "2.0";
bodyJson["method"] = method;
bodyJson["params"] = params;
bodyJson["id"] = 1;

cpr::Body body(bodyJson.dump());

session.SetUrl(url);
session.SetBody(body);
session.SetHeader({{"Content-Type", "application/json"}});
Expand Down Expand Up @@ -251,13 +252,13 @@ std::vector<LogEntry> Provider::getLogs(uint64_t fromBlock, uint64_t toBlock, co
logEntry.topics.push_back(topic.get<std::string>());
}
}

logEntry.data = logJson.contains("data") ? logJson["data"].get<std::string>() : "";
logEntry.blockNumber = logJson.contains("blockNumber") ? std::make_optional(logJson["blockNumber"].get<uint64_t>()) : std::nullopt;
logEntry.blockNumber = logJson.contains("blockNumber") ? std::make_optional(std::stoull(logJson["blockNumber"].get<std::string>(), nullptr, 16)) : std::nullopt;
logEntry.transactionHash = logJson.contains("transactionHash") ? std::make_optional(logJson["transactionHash"].get<std::string>()) : std::nullopt;
logEntry.transactionIndex = logJson.contains("transactionIndex") ? std::make_optional(logJson["transactionIndex"].get<uint32_t>()) : std::nullopt;
logEntry.transactionIndex = logJson.contains("transactionIndex") ? std::make_optional(std::stoull(logJson["transactionIndex"].get<std::string>(), nullptr, 16)) : std::nullopt;
logEntry.blockHash = logJson.contains("blockHash") ? std::make_optional(logJson["blockHash"].get<std::string>()) : std::nullopt;
logEntry.logIndex = logJson.contains("logIndex") ? std::make_optional(logJson["logIndex"].get<uint32_t>()) : std::nullopt;
logEntry.logIndex = logJson.contains("logIndex") ? std::make_optional(std::stoul(logJson["logIndex"].get<std::string>(), nullptr, 16)) : std::nullopt;
logEntry.removed = logJson.contains("removed") ? logJson["removed"].get<bool>() : false;

logEntries.push_back(logEntry);
Expand All @@ -271,6 +272,36 @@ std::vector<LogEntry> Provider::getLogs(uint64_t block, const std::string& addre
return getLogs(block, block, address);
}

std::string Provider::getContractStorageRoot(const std::string& address, uint64_t blockNumberInt) {
std::stringstream stream;
stream << "0x" << std::hex << blockNumberInt; // Convert uint64_t to hex string
std::string blockNumberHex = stream.str();

return getContractStorageRoot(address, blockNumberHex); // Call the original function
}

std::string Provider::getContractStorageRoot(const std::string& address, const std::string& blockNumber) {
nlohmann::json params = nlohmann::json::array();
params.push_back(address);
auto storage_keys = nlohmann::json::array();
params.push_back(storage_keys);
params.push_back(blockNumber);

auto response = makeJsonRpcRequest("eth_getProof", params);
if(response.status_code != 200)
throw std::runtime_error("Failed to call eth_getProof: " + response.text + " params: " + params.dump());

nlohmann::json responseJson = nlohmann::json::parse(response.text);
if (responseJson.find("error") != responseJson.end())
throw std::runtime_error("Error in response of eth_getProof: " + responseJson["error"]["message"].get<std::string>());

if (responseJson.contains("result") && responseJson["result"].contains("storageHash")) {
return responseJson["result"]["storageHash"].get<std::string>();
}

throw std::runtime_error("No storage proof found in response");
}

// Create and send a raw transaction returns the hash but will also check that it got into the mempool
std::string Provider::sendTransaction(const Transaction& signedTx) {
std::string hash = sendUncheckedTransaction(signedTx);
Expand Down Expand Up @@ -436,14 +467,25 @@ std::string Provider::getContractDeployedInLatestBlock() {
}


uint64_t Provider::getLatestHeight() {
nlohmann::json params = nlohmann::json::array();
auto blockResponse = makeJsonRpcRequest("eth_blockNumber", params);
if (blockResponse.status_code != 200) {
throw std::runtime_error("Failed to get the latest height");
}
nlohmann::json blockJson = nlohmann::json::parse(blockResponse.text);
return std::stoull(blockJson["result"].get<std::string>(), nullptr, 16);

}

FeeData Provider::getFeeData() {
// Get latest block
nlohmann::json params = nlohmann::json::array();
params.push_back("latest");
params.push_back(true);
auto blockResponse = makeJsonRpcRequest("eth_getBlockByNumber", params);
if (blockResponse.status_code != 200) {
throw std::runtime_error("Failed to get the latest block");
throw std::runtime_error("Failed to call get block by number for latest block for baseFeePerGas");
}
nlohmann::json blockJson = nlohmann::json::parse(blockResponse.text);
uint64_t baseFeePerGas = std::stoull(blockJson["result"]["baseFeePerGas"].get<std::string>(), nullptr, 16);
Expand Down

0 comments on commit ecdeba3

Please sign in to comment.