Skip to content

Commit

Permalink
refactor(world,world-modules): rename module args to encodedArgs
Browse files Browse the repository at this point in the history
  • Loading branch information
yonadaa committed Jan 26, 2024
1 parent 6ca974b commit 6d77fee
Show file tree
Hide file tree
Showing 11 changed files with 27 additions and 27 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ contract ERC20Module is Module {

address immutable registrationLibrary = address(new ERC20ModuleRegistrationLibrary());

function install(bytes memory args) public {
function install(bytes memory encodedArgs) public {
// Require the module to not be installed with these args yet
requireNotInstalled(__self, args);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ contract ERC721Module is Module {

address immutable registrationLibrary = address(new ERC721ModuleRegistrationLibrary());

function install(bytes memory args) public {
function install(bytes memory encodedArgs) public {
// Require the module to not be installed with these args yet
requireNotInstalled(__self, args);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ contract KeysInTableModule is Module {
// from the source table id (passed as argument to the hook methods)
KeysInTableHook private immutable hook = new KeysInTableHook();

function installRoot(bytes memory args) public override {
function installRoot(bytes memory encodedArgs) public override {
// Naive check to ensure this is only installed once
// TODO: only revert if there's nothing to do
requireNotInstalled(__self, args);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ contract KeysWithValueModule is Module {
// from the source table id (passed as argument to the hook methods)
KeysWithValueHook private immutable hook = new KeysWithValueHook();

function installRoot(bytes memory args) public {
function installRoot(bytes memory encodedArgs) public {
// Naive check to ensure this is only installed once
// TODO: only revert if there's nothing to do
requireNotInstalled(__self, args);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ contract UniqueEntityModule is Module {
// known tables, we can deploy it once and register it in multiple Worlds.
UniqueEntitySystem private immutable uniqueEntitySystem = new UniqueEntitySystem();

function installRoot(bytes memory args) public {
function installRoot(bytes memory encodedArgs) public {
// Naive check to ensure this is only installed once
// TODO: only revert if there's nothing to do
requireNotInstalled(__self, args);
Expand Down Expand Up @@ -51,7 +51,7 @@ contract UniqueEntityModule is Module {
if (!success) revertWithBytes(data);
}

function install(bytes memory args) public {
function install(bytes memory encodedArgs) public {
// Naive check to ensure this is only installed once
// TODO: only revert if there's nothing to do
requireNotInstalled(__self, args);
Expand Down
8 changes: 4 additions & 4 deletions packages/world/src/IModule.sol
Original file line number Diff line number Diff line change
Expand Up @@ -20,16 +20,16 @@ interface IModule is IERC165 {
* @notice Installs the module as a root module.
* @dev This function is invoked by the World contract during `installRootModule` process.
* The module expects to be called via the World contract and thus installs itself on the `msg.sender`.
* @param args Arguments that may be needed during the installation process.
* @param encodedArgs Arguments that may be needed during the installation process.
*/
function installRoot(bytes memory args) external;
function installRoot(bytes memory encodedArgs) external;

/**
* @notice Installs the module.
* @dev This function is invoked by the World contract during `installModule` process.
* The module expects to be called via the World contract and thus installs itself on the `msg.sender`.
* Logic might differ from `installRoot`, for example, this might accept namespace parameters.
* @param args Arguments that may be needed during the installation process.
* @param encodedArgs Arguments that may be needed during the installation process.
*/
function install(bytes memory args) external;
function install(bytes memory encodedArgs) external;
}
4 changes: 2 additions & 2 deletions packages/world/src/IWorldKernel.sol
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,9 @@ interface IWorldModuleInstallation {
* @notice Install the given root module in the World.
* @dev Requires the caller to own the root namespace. The module is delegatecalled and installed in the root namespace.
* @param module The module to be installed.
* @param args The arguments provided for the module installation.
* @param encodedArgs The arguments provided for the module installation.
*/
function installRootModule(IModule module, bytes memory args) external;
function installRootModule(IModule module, bytes memory encodedArgs) external;
}

/**
Expand Down
12 changes: 6 additions & 6 deletions packages/world/src/Module.sol
Original file line number Diff line number Diff line change
Expand Up @@ -32,20 +32,20 @@ abstract contract Module is IModule, WorldContextConsumer {
/**
* @dev Check if a module with the given name and arguments is installed.
* @param moduleAddress The address of the module.
* @param args The arguments for the module installation.
* @param encodedArgs The arguments for the module installation.
* @return true if the module is installed, false otherwise.
*/
function isInstalled(address moduleAddress, bytes memory args) internal view returns (bool) {
return InstalledModules.get(moduleAddress, keccak256(args));
function isInstalled(address moduleAddress, bytes memory encodedArgs) internal view returns (bool) {
return InstalledModules.get(moduleAddress, keccak256(encodedArgs));
}

/**
* @dev Revert if the module with the given name and arguments is already installed.
* @param moduleAddress The address of the module.
* @param args The arguments for the module installation.
* @param encodedArgs The arguments for the module installation.
*/
function requireNotInstalled(address moduleAddress, bytes memory args) internal view {
if (isInstalled(moduleAddress, args)) {
function requireNotInstalled(address moduleAddress, bytes memory encodedArgs) internal view {
if (isInstalled(moduleAddress, encodedArgs)) {
revert Module_AlreadyInstalled();
}
}
Expand Down
14 changes: 7 additions & 7 deletions packages/world/src/World.sol
Original file line number Diff line number Diff line change
Expand Up @@ -84,32 +84,32 @@ contract World is StoreData, IWorldKernel {
/**
* @notice Installs a given root module in the World.
* @param module The module to be installed.
* @param args Arguments for module installation.
* @param encodedArgs Arguments for module installation.
* @dev The caller must own the root namespace.
*/
function installRootModule(IModule module, bytes memory args) public prohibitDirectCallback {
function installRootModule(IModule module, bytes memory encodedArgs) public prohibitDirectCallback {
AccessControl.requireOwner(ROOT_NAMESPACE_ID, msg.sender);
_installRootModule(module, args);
_installRootModule(module, encodedArgs);
}

/**
* @dev Internal function to install a root module.
* @param module The module to be installed.
* @param args Arguments for module installation.
* @param encodedArgs Arguments for module installation.
*/
function _installRootModule(IModule module, bytes memory args) internal {
function _installRootModule(IModule module, bytes memory encodedArgs) internal {
// Require the provided address to implement the IModule interface
requireInterface(address(module), type(IModule).interfaceId);

WorldContextProviderLib.delegatecallWithContextOrRevert({
msgSender: msg.sender,
msgValue: 0,
target: address(module),
callData: abi.encodeCall(IModule.installRoot, (args))
callData: abi.encodeCall(IModule.installRoot, (encodedArgs))
});

// Register the module in the InstalledModules table
InstalledModules._set(address(module), keccak256(args), true);
InstalledModules._set(address(module), keccak256(encodedArgs), true);
}

/************************************************************************
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ contract ModuleInstallationSystem is System, LimitedCallContext {
* @param module The module to be installed.
* @param args Arguments for the module installation.
*/
function installModule(IModule module, bytes memory args) public onlyDelegatecall {
function installModule(IModule module, bytes memory encodedArgs) public onlyDelegatecall {
// Require the provided address to implement the IModule interface
requireInterface(address(module), type(IModule).interfaceId);

Expand Down

0 comments on commit 6d77fee

Please sign in to comment.