Skip to content

Commit

Permalink
fix: ensure recipients on Sealevel warp transfers are 32 bytes (#4760)
Browse files Browse the repository at this point in the history
### Description

Ran into an issue trying to send from Sealevel -> Cosmos where the
recipient was 20 bytes. This hasn't been an issue so far because:
- no previous Sealevel -> Cosmos transfers have been done in the UI
- Sealevel -> EVM transfers are successful bc `addressToBytes` actually
pads the 20 byte EVM addresses to 32 bytes
- Sealevel -> Sealevel transfers are fine because Sealevel addys are
always 32 bytes

### Drive-by changes

<!--
Are there any minor or drive-by changes also included?
-->

### Related issues

<!--
- Fixes #[issue number here]
-->

### Backward compatibility

<!--
Are these changes backward compatible? Are there any infrastructure
implications, e.g. changes that would prohibit deploying older commits
using this infra tooling?

Yes/No
-->

### Testing

<!--
What kind of testing have these changes undergone?

None/Manual/Unit Tests
-->
  • Loading branch information
tkporter authored Oct 25, 2024
1 parent a36fc5f commit 5fd4267
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 1 deletion.
6 changes: 6 additions & 0 deletions .changeset/olive-maps-applaud.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'@hyperlane-xyz/utils': patch
'@hyperlane-xyz/sdk': patch
---

Supported non-32 byte non-EVM recipients when sending warps from Sealevel
3 changes: 2 additions & 1 deletion typescript/sdk/src/token/adapters/SealevelTokenAdapter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import {
addressToBytes,
eqAddress,
median,
padBytesToLength,
} from '@hyperlane-xyz/utils';

import { BaseSealevelAdapter } from '../../app/MultiProtocolApp.js';
Expand Down Expand Up @@ -295,7 +296,7 @@ export abstract class SealevelHypTokenAdapter
instruction: SealevelHypTokenInstruction.TransferRemote,
data: new SealevelTransferRemoteInstruction({
destination_domain: destination,
recipient: addressToBytes(recipient),
recipient: padBytesToLength(addressToBytes(recipient), 32),
amount_or_id: BigInt(weiAmountOrId),
}),
});
Expand Down
12 changes: 12 additions & 0 deletions typescript/utils/src/addresses.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import {
addressToBytes,
bytesToProtocolAddress,
isZeroishAddress,
padBytesToLength,
} from './addresses.js';
import { ProtocolType } from './types.js';

Expand Down Expand Up @@ -42,6 +43,17 @@ describe('Address utilities', () => {
});
});

describe('padBytesToLength', () => {
it('Pads bytes to a given length', () => {
const bytes = Buffer.from([1, 2, 3]);
expect(padBytesToLength(bytes, 5).equals(Buffer.from([0, 0, 1, 2, 3])));
});
it('Rejects bytes that exceed the target length', () => {
const bytes = Buffer.from([1, 2, 3]);
expect(() => padBytesToLength(bytes, 2)).to.throw(Error);
});
});

describe('bytesToProtocolAddress', () => {
it('Converts bytes to address', () => {
expect(
Expand Down
8 changes: 8 additions & 0 deletions typescript/utils/src/addresses.ts
Original file line number Diff line number Diff line change
Expand Up @@ -316,6 +316,14 @@ export function bytesToBytes32(bytes: Uint8Array): string {
);
}

// Pad bytes to a certain length, padding with 0s at the start
export function padBytesToLength(bytes: Uint8Array, length: number) {
if (bytes.length > length) {
throw new Error(`bytes must be ${length} bytes or less`);
}
return Buffer.concat([Buffer.alloc(length - bytes.length), bytes]);
}

export function bytesToAddressEvm(bytes: Uint8Array): Address {
return bytes32ToAddress(Buffer.from(bytes).toString('hex'));
}
Expand Down
1 change: 1 addition & 0 deletions typescript/utils/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ export {
normalizeAddressCosmos,
normalizeAddressEvm,
normalizeAddressSealevel,
padBytesToLength,
shortenAddress,
strip0x,
} from './addresses.js';
Expand Down

0 comments on commit 5fd4267

Please sign in to comment.