setControllerOf
Contract: JBDirectory
Interface: IJBDirectory
- Step by step
- Code
- Errors
- Events
- Bug bounty
Update the controller that manages how terminals interact with the ecosystem.
A controller can be set if:
- the message sender is the project owner or an operator having the correct authorization.
- the message sender is the project's current controller.
- or, an allowedlisted address is setting a controller for a project that doesn't already have a controller.
Definition
function setControllerOf(uint256 _projectId, address _controller)
external
override
requirePermissionAllowingOverride(
projects.ownerOf(_projectId),
_projectId,
JBOperations.SET_CONTROLLER,
(msg.sender == address(controllerOf[_projectId]) ||
(isAllowedToSetFirstController[msg.sender] &&
controllerOf[_projectId] == IJBController(address(0))))
) { ... }
- Arguments:
_projectId
is the ID of the project to set a new controller for._controller
is the new controller to set.
- Through the
requirePermissionAllowingOverride
modifier, the function is only accessible by the project's owner, from an operator that has been given theJBOperations.SET_CONTROLLER
permission by the project owner for the provided_projectId
, from the project's current controller, or from an allow-listed controller if the project doesn't already have a controller set. - The function overrides a function definition from the
IJBDirectory
interface. - The function doesn't return anything
Body
-
Project IDs are assigned incrementally. If the provided project ID is greater than the number of projects, it must not be a valid project ID.
// The project must exist.
if (projects.count() < _projectId) revert INVALID_PROJECT_ID_IN_DIRECTORY();Internal references:
External references:
-
Get a reference to the project's current funding cycle.
// Get a reference to the project's current funding cycle.
JBFundingCycle memory _fundingCycle = fundingCycleStore.currentOf(_projectId);Internal references:
External references:
-
Make sure the project's current funding cycle is set to allow setting its controller, or the request to set the controller is coming from the project's current controller or is setting the first controller.
// Setting controller must be allowed if not called from the current controller or if the project already has a controller.
if (
msg.sender != address(controllerOf[_projectId]) &&
controllerOf[_projectId] != address(0) &&
!uint8(_fundingCycle.metadata >> 8).setControllerAllowed()
) revert SET_CONTROLLER_NOT_ALLOWED();Library references:
JBFundingCycleMetadataResolver
.setControllerAllowed(...)
Internal references:
-
Store the provided controller as the controller of the project.
// Set the new controller.
controllerOf[_projectId] = _controller;Internal references:
-
Emit a
SetController
event with the relevant parameters.emit SetController(_projectId, _controller, msg.sender);
Event references:
/**
@notice
Update the controller that manages how terminals interact with the ecosystem.
@dev
A controller can be set if:
- the message sender is the project owner or an operator having the correct authorization.
- the message sender is the project's current controller.
- or, an allowedlisted address is setting a controller for a project that doesn't already have a controller.
@param _projectId The ID of the project to set a new controller for.
@param _controller The new controller to set.
*/
function setControllerOf(uint256 _projectId, address _controller)
external
override
requirePermissionAllowingOverride(
projects.ownerOf(_projectId),
_projectId,
JBOperations.SET_CONTROLLER,
(msg.sender == address(controllerOf[_projectId]) ||
(isAllowedToSetFirstController[msg.sender] && controllerOf[_projectId] == address(0)))
)
{
// The project must exist.
if (projects.count() < _projectId) revert INVALID_PROJECT_ID_IN_DIRECTORY();
// Get a reference to the project's current funding cycle.
JBFundingCycle memory _fundingCycle = fundingCycleStore.currentOf(_projectId);
// Setting controller must be allowed if not called from the current controller or if the project already has a controller.
if (
msg.sender != address(controllerOf[_projectId]) &&
controllerOf[_projectId] != address(0) &&
!uint8(_fundingCycle.metadata >> 8).setControllerAllowed()
) revert SET_CONTROLLER_NOT_ALLOWED();
// Set the new controller.
controllerOf[_projectId] = _controller;
emit SetController(_projectId, _controller, msg.sender);
}
String | Description |
---|---|
INVALID_PROJECT_ID | Thrown if the provided project doesn't yet exist. |
SET_CONTROLLER_NOT_ALLOWED | Thrown if the provided project isn't currently allowed to set its controller. |
Name | Data |
---|---|
SetController |
|
Category | Description | Reward |
---|---|---|
Optimization | Help make this operation more efficient. | 0.5ETH |
Low severity | Identify a vulnerability in this operation that could lead to an inconvenience for a user of the protocol or for a protocol developer. | 1ETH |
High severity | Identify a vulnerability in this operation that could lead to data corruption or loss of funds. | 5+ETH |