Compare commits
2 Commits
1b3756ed51
...
b54336461b
Author | SHA1 | Date |
---|---|---|
David E. Perez Negron R. | b54336461b | |
David E. Perez Negron R. | 79ea134343 |
|
@ -1,3 +1,6 @@
|
||||||
[submodule "lib/forge-std"]
|
[submodule "lib/forge-std"]
|
||||||
path = lib/forge-std
|
path = lib/forge-std
|
||||||
url = https://github.com/foundry-rs/forge-std
|
url = https://github.com/foundry-rs/forge-std
|
||||||
|
[submodule "lib/openzeppelin-contracts"]
|
||||||
|
path = lib/openzeppelin-contracts
|
||||||
|
url = https://github.com/openzeppelin/openzeppelin-contracts
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
# Foundry default testing private keys
|
||||||
|
PK0="0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80"
|
||||||
|
PK1="0x59c6995e998f97a5a0044966f0945389dc9e86dae88c7a8412f4603b6b78690d"
|
||||||
|
PK2="0x5de4111afa1a4b94908f83103eb1f1706367c2e68ca870fc3fb9a804cdab365a"
|
||||||
|
PK3="0x7c852118294e51e653712a81e05800f419141751be58f605c371e15141b007a6"
|
||||||
|
PK4="0x47e179ec197488593b187f80a00eb0da91f1b9d0b13f8733639f19c30a34926a"
|
||||||
|
PK5="0x8b3a350cf5c34c9194ca85829a2df0ec3153be0318b5e2d3348e872092edffba"
|
||||||
|
PK6="0x92db14e403b83dfe3df233f83dfa3a0d7096f21ca9b0d6d6b8d88b2b4ec1564e"
|
||||||
|
PK7="0x4bbbf85ce3377467afe5d46f804f221813b2bb87f24d81f60f1fcdbf7cbf4356"
|
||||||
|
PK8="0xdbda1821b80551c9d65939329250298aa3472ba22feea921c0cf5d620ea67b97"
|
||||||
|
PK9="0x2a871d0798f97d79848a013d4936a73bf4cc922c825d33c1cf7073dff6d409c6"
|
||||||
|
|
||||||
|
# some IPFS URIs to test
|
||||||
|
dapps="bafkreibc6p3y36yjmeqqnttqfrpb2yttxa6aonoywxwdxl7nqym4jj3jwa
|
||||||
|
bafkreidcf5baqb5wevs6avyd7dtd3j7rzrq65uyqasj4dbkcy6na4ig3ay
|
||||||
|
bafkreibffiehtv4ntajq5vjwpl7q44i6cjbg54lm5hkoa665ue2taspiyu
|
||||||
|
bafkreifqztiwfutjik4wfs3gyfdyrff7cugi4mcctluunrrbp5cgareisq
|
||||||
|
bafybeiepujtyev5ett75mxd5eazjlqor7loibey5exbmoal6teivnrrkwi"
|
||||||
|
|
||||||
|
# https://book.getfoundry.sh/tutorials/solidity-scripting?highlight=Private%20key#environment-configuration
|
||||||
|
# GOERLI_RPC_URL=
|
||||||
|
# PRIVATE_KEY=
|
||||||
|
# ETHERSCAN_API_KEY=
|
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit 01ef448981be9d20ca85f2faf6ebdf591ce409f3
|
|
@ -0,0 +1,71 @@
|
||||||
|
// SPDX-License-Identifier: UNLICENSED
|
||||||
|
pragma solidity ^0.8.23;
|
||||||
|
|
||||||
|
import {Script, console2} from "forge-std/Script.sol";
|
||||||
|
import { DappIndexer} from "src/DappIndexer.sol";
|
||||||
|
|
||||||
|
contract DappIndexerScript is Script {
|
||||||
|
DappIndexer public dappIdxr;
|
||||||
|
string[] public dappsURI;
|
||||||
|
|
||||||
|
function setUp() public {
|
||||||
|
dappIdxr = new DappIndexer(0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266,
|
||||||
|
0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266);
|
||||||
|
console2.log("The Dapps Indexer contract address is: ", address(dappIdxr));
|
||||||
|
dappsURI = vm.envString("dapps", ' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
// run is the entry point
|
||||||
|
function run() public {
|
||||||
|
// startBroadcast and stopBraodcast will let us execute transactions anything between them
|
||||||
|
vm.startBroadcast();
|
||||||
|
// here we just need to deploy a new contractc
|
||||||
|
|
||||||
|
bytes32 CID1;
|
||||||
|
bytes32 CID2;
|
||||||
|
|
||||||
|
(CID1, CID2) = stringToBytes32Pair(dappsURI[0]);
|
||||||
|
|
||||||
|
// Add Dapp
|
||||||
|
console2.log("-----Adding Dapp-----");
|
||||||
|
console2.log("Bytes32 first:");
|
||||||
|
console2.logBytes32(CID1);
|
||||||
|
console2.log("Bytes32 second:");
|
||||||
|
console2.logBytes32(CID2);
|
||||||
|
console2.log(Bytes32PairToString(CID1, CID2));
|
||||||
|
dappIdxr.addDapp(bytes32("Dapp01"), DappIndexer.PackedCID(CID1, CID2));
|
||||||
|
|
||||||
|
// retrive Dapp
|
||||||
|
console2.log("-----retriving Dapp-----");
|
||||||
|
DappIndexer.PackedCID memory dapp1 = dappIdxr.getCID(bytes32("Dapp01"));
|
||||||
|
console2.log("Bytes32 first:");
|
||||||
|
console2.logBytes32(dapp1.CID1);
|
||||||
|
console2.log("Bytes32 second:");
|
||||||
|
console2.logBytes32(dapp1.CID2);
|
||||||
|
console2.log(Bytes32PairToString(dapp1.CID1, dapp1.CID2));
|
||||||
|
|
||||||
|
vm.stopBroadcast();
|
||||||
|
}
|
||||||
|
|
||||||
|
function Bytes32PairToString(bytes32 part1, bytes32 part2) public pure returns (string memory) {
|
||||||
|
// Concatenate the two bytes32 variables
|
||||||
|
bytes memory concatenatedBytes = abi.encodePacked(part1, part2);
|
||||||
|
|
||||||
|
// Convert the concatenated bytes to a string
|
||||||
|
string memory str = string(concatenatedBytes);
|
||||||
|
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
function stringToBytes32Pair(string memory source) public pure returns (bytes32 part1, bytes32 part2) {
|
||||||
|
bytes memory sourceBytes = bytes(source);
|
||||||
|
require(sourceBytes.length <= 64, "String must be less than or equal to 64 bytes");
|
||||||
|
|
||||||
|
assembly {
|
||||||
|
// Load the first 32 bytes of the string data
|
||||||
|
part1 := mload(add(sourceBytes, 32))
|
||||||
|
// Load the second 32 bytes of the string data
|
||||||
|
part2 := mload(add(sourceBytes, 64))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,14 +0,0 @@
|
||||||
// SPDX-License-Identifier: UNLICENSED
|
|
||||||
pragma solidity ^0.8.13;
|
|
||||||
|
|
||||||
contract Counter {
|
|
||||||
uint256 public number;
|
|
||||||
|
|
||||||
function setNumber(uint256 newNumber) public {
|
|
||||||
number = newNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
function increment() public {
|
|
||||||
number++;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -4,10 +4,34 @@ pragma solidity ^0.8.23;
|
||||||
import "@openzeppelin/contracts/access/AccessControl.sol";
|
import "@openzeppelin/contracts/access/AccessControl.sol";
|
||||||
|
|
||||||
contract DappIndexer is AccessControl {
|
contract DappIndexer is AccessControl {
|
||||||
|
// Moderator adds/updates and removes DAPPs
|
||||||
|
bytes32 public constant MODERATOR_ROLE = keccak256("MODERATOR_ROLE");
|
||||||
|
|
||||||
constructor(){
|
struct PackedCID {
|
||||||
_grantRole(DEFAULT_ADMIN_ROLE, defaultAdmin);
|
bytes32 CID1;
|
||||||
|
bytes32 CID2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mapping (bytes32 => PackedCID) private dapps;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
address defaultAdmin,
|
||||||
|
address moderator
|
||||||
|
){
|
||||||
|
_grantRole(DEFAULT_ADMIN_ROLE, defaultAdmin);
|
||||||
|
_grantRole(MODERATOR_ROLE, moderator);
|
||||||
|
}
|
||||||
|
|
||||||
|
function addDapp(bytes32 dapp_name, PackedCID calldata cid)
|
||||||
|
external onlyRole(MODERATOR_ROLE) {
|
||||||
|
dapps[dapp_name] = PackedCID(cid.CID1, cid.CID2);
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeDapp(bytes32 dapp_name) external onlyRole(MODERATOR_ROLE) {
|
||||||
|
delete dapps[dapp_name];
|
||||||
|
}
|
||||||
|
|
||||||
|
function getCID(bytes32 dapp_name) external view returns (PackedCID memory){
|
||||||
|
return dapps[dapp_name];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
// SPDX-License-Identifier: UNLICENSED
|
||||||
|
pragma solidity ^0.8.23;
|
||||||
|
|
||||||
|
import { Test, console2 } from "forge-std/Test.sol";
|
||||||
|
import { DappIndexer } from "src/DappIndexer.sol";
|
||||||
|
|
||||||
|
contract DappIndexerTest is Test {
|
||||||
|
DappIndexer public dappIdxr;
|
||||||
|
string[] public dappsURI;
|
||||||
|
|
||||||
|
function setUp() public {
|
||||||
|
dappIdxr = new DappIndexer(address(this), address(this));
|
||||||
|
dappsURI = vm.envString("dapps", ' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
function testAddDapp() public {
|
||||||
|
bytes32 CID1;
|
||||||
|
bytes32 CID2;
|
||||||
|
|
||||||
|
(CID1, CID2) = stringToBytes32Pair(dappsURI[0]);
|
||||||
|
|
||||||
|
// Add Dapp
|
||||||
|
console2.log("Bytes32 first:");
|
||||||
|
console2.logBytes32(CID1);
|
||||||
|
console2.log("Bytes32 second:");
|
||||||
|
console2.logBytes32(CID2);
|
||||||
|
console2.log(Bytes32PairToString(CID1, CID2));
|
||||||
|
dappIdxr.addDapp(bytes32("Dapp01"), DappIndexer.PackedCID(CID1, CID2));
|
||||||
|
// retrive Dapp
|
||||||
|
DappIndexer.PackedCID memory dapp1 = dappIdxr.getCID(bytes32("Dapp01"));
|
||||||
|
assertEq(CID1, dapp1.CID1);
|
||||||
|
assertEq(CID2, dapp1.CID2);
|
||||||
|
//string memory retrivedDapp = Bytes32PairToString(dapp1.CID1, dapp1.CID2);
|
||||||
|
//assertEq(dappsURI[0], retrivedDapp[0:59]);
|
||||||
|
}
|
||||||
|
|
||||||
|
function Bytes32PairToString(bytes32 part1, bytes32 part2) public pure returns (string memory) {
|
||||||
|
// Concatenate the two bytes32 variables
|
||||||
|
bytes memory concatenatedBytes = abi.encodePacked(part1, part2);
|
||||||
|
|
||||||
|
// Convert the concatenated bytes to a string
|
||||||
|
string memory str = string(concatenatedBytes);
|
||||||
|
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
function stringToBytes32Pair(string memory source) public pure returns (bytes32 part1, bytes32 part2) {
|
||||||
|
bytes memory sourceBytes = bytes(source);
|
||||||
|
require(sourceBytes.length == 59, "URI string must equal to 59 bytes");
|
||||||
|
|
||||||
|
assembly {
|
||||||
|
// Load the first 32 bytes of the string data
|
||||||
|
part1 := mload(add(sourceBytes, 32))
|
||||||
|
// Load the second 32 bytes of the string data
|
||||||
|
part2 := mload(add(sourceBytes, 64))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue