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

Seaport 1.1 #492

Draft
wants to merge 839 commits into
base: seaport-1.0
Choose a base branch
from
Draft

Seaport 1.1 #492

wants to merge 839 commits into from

Conversation

0age
Copy link
Contributor

@0age 0age commented Jun 10, 2022

This PR highlights changes from Seaport 1.0 to Seaport 1.1 and is meant to facilitate review and discussion of those changes.

naps62 and others added 30 commits June 8, 2022 15:47
Revert on dirty bits (unused item parameters)
gas: add unchecked for ConduitController#updateChannel
Added ENS name of JasperAlexander
Assign basicOrderType to a variable rather than loading twice
Gas opt: skip `remaining` calculation when not necessary
if (item.itemType == ConduitItemType.ERC20) {
// Transfer ERC20 token.
// Transfer ERC20 token. Note that item.identifier is ignored and
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a particular reason for this?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Avoiding a redundant check mainly, basically letting channels make the call as to whether they want to do this safety check or not

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Avoiding a redundant check mainly,

Where is this checked before hand? The conduit can be used independently, can't it be?

@@ -198,8 +213,13 @@ contract ConduitController is ConduitControllerInterface {
revert NewPotentialOwnerIsZeroAddress(conduit);
}

// Ensure the new potential owner is not already set.
if (newPotentialOwner == _conduits[conduit].potentialOwner) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This only checks for the same owner being proposed twice, but allows proposing a new one while a proposal is active. Is that the goal?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that’s fine, the current owner is still in control at that stage

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It does feel like a not very useful check though.

if (item.itemType == ConduitItemType.NATIVE) {
revert InvalidItemType();
} else if (item.itemType == ConduitItemType.ERC20) {
_performERC20Transfer(
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This allows item.identifier to be anything.

invalidNativeOfferItemErrorBuffer := shl(
1,
gt(
// Take the remainder of the selector modulo a magic value.
Copy link
Contributor

@axic axic Jun 11, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👀

Which (two) selectors is this comparing? This seems like an extremely fragile piece of code should new external code paths allowed to reach this function.

For the reader: the shr is reading the selector (top 32 bits) and MagicModulus = 69, MagicRemainder = 0x1d.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It seems to be reachable from Consideration.matchOrders, Consideration.matchAdvancedOrders, Consideration.fulfillAvailableOrders, Consideration.fulfillAvailableAdvancedOrders.

That is 4 selectors this code is comparing. Note that not only new external functions are risky here, but also any parameter change to the above would change the selectors.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My recommendation would be to pass down a isMatchOrder flag.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah we’ll definitely replace this pattern with one like you suggest should any aspect of the interface change

assembly {
// Use the second bit of the error buffer to indicate whether the
// current function is not matchAdvancedOrders or matchOrders.
invalidNativeOfferItemErrorBuffer := shl(
Copy link
Contributor

@axic axic Jun 11, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Likely no need for assembly on this and it clearly shows how risky it is to the reader:

unchecked {
  invalidNativeOfferItemErrorBuffer = ((uint32(msg.selector) % NonMatchSelector_MagicModulus) > NonMatchSelector_MagicRemainder) ? 2 : 0;
}

Ok, for this need to have the optimiser support branchless ternary ops.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I do like including this as part of the documentation to demonstrate what’s happening here!

@@ -184,7 +193,7 @@ contract ConsiderationBase is ConsiderationEventsAndErrors {
"bytes32 zoneHash,",
"uint256 salt,",
"bytes32 conduitKey,",
"uint256 nonce",
"uint256 counter",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Documentation still contains old name (nonce instead of coutner)

@github-actions github-actions bot added the Stale label May 9, 2023
@0age 0age added Informational and removed Stale labels May 10, 2023
@ProjectOpenSea ProjectOpenSea deleted a comment from github-actions bot May 23, 2023
@0age 0age changed the title Seaport 1.0 => 1.1 Seaport 1.1 Jul 17, 2023
@ryanio ryanio marked this pull request as draft April 16, 2024 17:59
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.