Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

concatenate multiple text fields #332

Open
wants to merge 21 commits into
base: fix/refactor-wrapped-callback
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
89ad8ed
concatenate multiple text fields
mdtanrikulu Feb 20, 2024
2880879
update wildcard check without copying name, concatenate text in O(n)
mdtanrikulu Feb 20, 2024
2be5088
sync testing with feature/better-offchain-dns
mdtanrikulu Mar 26, 2024
e9894f6
update testhexutils
mdtanrikulu Mar 27, 2024
092b087
Merge branch 'fix/refactor-wrapped-callback' into experimental-multi-…
mdtanrikulu Jul 23, 2024
0758752
remove DummyDNSResolver2
mdtanrikulu Aug 22, 2024
c3a0836
update extendeddnsresolver deployments file
mdtanrikulu Aug 22, 2024
1445c3f
merge staging into
mdtanrikulu Aug 22, 2024
d7f5ee6
Merge branch 'fix/refactor-wrapped-callback' into experimental-multi-…
mdtanrikulu Aug 22, 2024
67e3145
fix wildcard check by comparing to it's hex representation
mdtanrikulu Aug 27, 2024
4f59136
Merge branch 'staging' into experimental-multi-field
mdtanrikulu Oct 24, 2024
92d01c6
revert wildcard support
mdtanrikulu Oct 24, 2024
c03968b
update deprecated experimental loader, bump hardhat
mdtanrikulu Oct 24, 2024
7ff6a56
update deprecated buffer use
mdtanrikulu Oct 24, 2024
6bc18af
revert redundant name offset
mdtanrikulu Oct 28, 2024
f98f323
update lock file
mdtanrikulu Oct 28, 2024
69476ed
Merge branch 'fix/refactor-wrapped-callback' into experimental-multi-…
mdtanrikulu Oct 28, 2024
db8a085
improve TXT concatenation testing
mdtanrikulu Oct 29, 2024
7654735
Update contracts/dnsregistrar/OffchainDNSResolver.sol
mdtanrikulu Nov 15, 2024
4630340
Update contracts/dnsregistrar/OffchainDNSResolver.sol
mdtanrikulu Nov 15, 2024
24fcb62
update for loops in readTXT method
mdtanrikulu Nov 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 21 additions & 15 deletions contracts/dnsregistrar/OffchainDNSResolver.sol
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,13 @@ contract OffchainDNSResolver is IExtendedResolver, IERC165 {
) {
// Ignore records with wrong name, type, or class
bytes memory rrname = RRUtils.readName(iter.data, iter.offset);
uint256 nameOffset = 0;
if (checkWildcard(name)) {
nameOffset = 2;
}

if (
!rrname.equals(stripWildcard(name)) ||
!name.equals(nameOffset, rrname, 0, name.length - nameOffset) ||
iter.class != CLASS_INET ||
iter.dnstype != TYPE_TXT
) {
Expand Down Expand Up @@ -168,17 +173,10 @@ contract OffchainDNSResolver is IExtendedResolver, IERC165 {
);
}

function stripWildcard(
function checkWildcard(
bytes memory name
) public pure returns (bytes memory) {
if (name.length > 4 && name[0] == "*" && name[1] == ".") {
bytes memory strippedName = new bytes(name.length - 2);
for (uint i = 2; i < name.length; i++) {
strippedName[i - 2] = name[i];
}
return strippedName;
}
return name;
) public pure returns (bool isWildcard) {
return name.length > 4 && uint8(name[0]) == 1 && name[1] == "*";
mdtanrikulu marked this conversation as resolved.
Show resolved Hide resolved
}

function parseRR(
Expand Down Expand Up @@ -212,13 +210,21 @@ contract OffchainDNSResolver is IExtendedResolver, IERC165 {
uint256 startIdx,
uint256 lastIdx
) internal pure returns (bytes memory) {
bytes memory result = new bytes(0);
uint256 totalLength = 0;
uint256 idx = startIdx;
while (idx < lastIdx) {
uint256 fieldLength = data.readUint8(idx);
assert(idx + fieldLength + 1 <= lastIdx);
bytes memory field = data.substring(idx + 1, fieldLength);
result = abi.encodePacked(result, field);
totalLength += fieldLength;
idx += fieldLength + 1;
}

bytes memory result = new bytes(totalLength);
idx = startIdx;
uint256 resultIdx = 0;
while (idx < lastIdx) {
uint256 fieldLength = data.readUint8(idx);
result.strcpy(resultIdx, data, idx + 1, fieldLength);
resultIdx += fieldLength;
idx += fieldLength + 1;
}
return result;
Expand Down
21 changes: 21 additions & 0 deletions contracts/dnssec-oracle/BytesUtils.sol
Original file line number Diff line number Diff line change
Expand Up @@ -291,6 +291,27 @@ library BytesUtils {
}
}

function strcpy(
bytes memory self,
uint256 selfOffset,
bytes memory src,
uint256 srcOffset,
uint256 length
) internal pure {
require(selfOffset + length <= self.length);
require(srcOffset + length <= src.length);

uint256 selfPtr;
uint256 srcPtr;

assembly {
selfPtr := add(add(self, 32), selfOffset)
srcPtr := add(add(src, 32), srcOffset)
}

memcpy(selfPtr, srcPtr, length);
}

/*
* @dev Copies a substring into a new byte string.
* @param self The byte string to copy from.
Expand Down
Loading