@@@@@@@@@
                                        @@@@@@@@@@@@@@@@@@@@@
                                    @@@@@@@@@@@@@@@@@@@@@@@@@@@@
                                  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
                                @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
              @@@@@@@@@@@       @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@      @@@@@@@@@@@
        @@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
    @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@@@@              @@@@@@@@@@@@@@              @@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@          @@@@@@@   @@@@@@@@@         @@@@@@    @@@@@@@@@@@@@@@@@@@@@@@@@
  @@@@@@@@@@@@@@@@@@@@@@  @@        @@@@@@@@  @@@@@@   @       @@@@@@@@   @@@@@@@@@@@@@@@@@@@@@@
    @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
          @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
            @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@            @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
                @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
                      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
                          @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
                                  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
Lens Protocol
The Lens Protocol is a decentralized, non-custodial social graph. Lens implements unique, on-chain social interaction mechanisms analogous to commonly understood Web2 social media interactions, but significantly expanded with unique functionality that empower communities to form and participants to own their own social graph.
Cloning
You must clone the repo using SSH:
git clone [email protected]:lens-protocol/core-private.git
Setup
- Install Foundry by following the instructions from their repository.
- curl -L https://foundry.paradigm.xyz | bash
- foundryup
- done
 
- Install the dependencies by running : npm i && forge install
You can now build it using:
npm run build
Testing
You can run unit tests using
npm run test
Coverage
You can run coverage using
npm run coverage
You can go to our docs to learn more about Lens Protocol.
Contents
- upgradeability
- ERC2981CollectionRoyalties
- HubRestricted
- LensBaseERC721
- LensGovernable
- LensHubEventHooks
- LensHubStorage
- LensImplGetters
- LensProfiles
Contents
FollowNFTProxy
Inherits: Proxy
State Variables
HUB
address immutable HUB;
Functions
constructor
constructor(bytes memory data);
_implementation
function _implementation() internal view override returns (address);
VersionedInitializable
Author: Lens Protocol, inspired by Aave's implementation, which is in turn inspired by OpenZeppelin's Initializable contract
Helper contract to implement initializer functions. To use it, replace
the constructor with a function that has the initializer modifier.
WARNING: Unlike constructors, initializer functions must be manually
invoked. This applies both to deploying an Initializable contract, as well
as extending an Initializable contract via inheritance.
WARNING: When used with inheritance, manual care must be taken to not invoke
a parent initializer twice, or ensure that all initializers are idempotent,
because this is not dealt with automatically as with constructors.
This is slightly modified from Aave's version.
State Variables
originalImpl
address private immutable originalImpl;
Functions
initializer
Modifier to use in the initializer function of a contract.
modifier initializer();
constructor
constructor();
getRevision
returns the revision number of the contract Needs to be defined in the inherited class as a constant.
function getRevision() internal pure virtual returns (uint256);
ERC2981CollectionRoyalties
Inherits: IERC2981
State Variables
BASIS_POINTS
uint16 internal constant BASIS_POINTS = 10000;
INTERFACE_ID_ERC2981
bytes4 internal constant INTERFACE_ID_ERC2981 = 0x2a55205a;
Functions
supportsInterface
See {IERC165-supportsInterface}.
function supportsInterface(bytes4 interfaceId) public view virtual returns (bool);
setRoyalty
Changes the royalty percentage for secondary sales.
function setRoyalty(uint256 royaltiesInBasisPoints) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| royaltiesInBasisPoints | uint256 | The royalty percentage (measured in basis points). | 
royaltyInfo
Called with the sale price to determine how much royalty is owed and to whom.
function royaltyInfo(uint256 tokenId, uint256 salePrice) external view returns (address, uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The ID of the token queried for royalty information. | 
| salePrice | uint256 | The sale price of the token specified. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | A tuple with the address that should receive the royalties and the royalty payment amount for the given sale price. | 
| <none> | uint256 | 
_setRoyalty
function _setRoyalty(uint256 royaltiesInBasisPoints) internal virtual;
_getRoyaltyAmount
function _getRoyaltyAmount(uint256, uint256 salePrice) internal view virtual returns (uint256);
_storeRoyaltiesInBasisPoints
function _storeRoyaltiesInBasisPoints(uint256 royaltiesInBasisPoints) internal virtual;
_loadRoyaltiesInBasisPoints
function _loadRoyaltiesInBasisPoints() internal view virtual returns (uint256);
_beforeRoyaltiesSet
function _beforeRoyaltiesSet(uint256 royaltiesInBasisPoints) internal view virtual;
_getRoyaltiesInBasisPointsSlot
function _getRoyaltiesInBasisPointsSlot() internal view virtual returns (uint256);
_getReceiver
function _getReceiver(uint256 tokenId) internal view virtual returns (address);
HubRestricted
Author: Lens Protocol
This abstract contract adds a public HUB immutable field, as well as an onlyHub modifier,
to inherit from contracts that have functions restricted to be only called by the Lens hub.
State Variables
HUB
address public immutable HUB;
Functions
onlyHub
modifier onlyHub();
constructor
constructor(address hub);
LensBaseERC721
Inherits: ERC165, ILensERC721
*Implementation of https://eips.ethereum.org/EIPS/eip-721[ERC721] Non-Fungible Token Standard, including the Metadata extension, but not including the Enumerable extension, which is available separately as {ERC721Enumerable}. Modifications:
- Refactored _operatorApprovals setter into an internal function to allow meta-transactions.
- Constructor replaced with an initializer.
- Mint timestamp is now stored in a TokenData struct alongside the owner address.*
State Variables
_name
string private _name;
_symbol
string private _symbol;
_tokenData
mapping(uint256 => Types.TokenData) private _tokenData;
_balances
mapping(address => uint256) private _balances;
_tokenApprovals
mapping(uint256 => address) private _tokenApprovals;
_operatorApprovals
mapping(address => mapping(address => bool)) private _operatorApprovals;
__DEPRECATED__ownedTokens
mapping(address => mapping(uint256 => uint256)) private __DEPRECATED__ownedTokens;
__DEPRECATED__ownedTokensIndex
mapping(uint256 => uint256) private __DEPRECATED__ownedTokensIndex;
_totalSupply
uint256 private _totalSupply;
__DEPRECATED__allTokensIndex
mapping(uint256 => uint256) private __DEPRECATED__allTokensIndex;
_nonces
mapping(address => uint256) private _nonces;
Functions
_initialize
Initializes the ERC721 name and symbol.
function _initialize(string calldata name_, string calldata symbol_) internal;
Parameters
| Name | Type | Description | 
|---|---|---|
| name_ | string | The name to set. | 
| symbol_ | string | The symbol to set. | 
tokenURI
Returns the Uniform Resource Identifier (URI) for tokenId token.
function tokenURI(uint256 tokenId) external view virtual returns (string memory);
supportsInterface
See {IERC165-supportsInterface}.
function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165, IERC165) returns (bool);
nonces
function nonces(address signer) public view override returns (uint256);
getDomainSeparator
Returns the EIP-712 domain separator for this contract.
function getDomainSeparator() external view virtual override returns (bytes32);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | bytes32 The domain separator. | 
balanceOf
See {IERC721-balanceOf}.
function balanceOf(address owner) public view virtual override returns (uint256);
ownerOf
See {IERC721-ownerOf}.
function ownerOf(uint256 tokenId) public view virtual override returns (address);
mintTimestampOf
See {IERC721Timestamped-mintTimestampOf}
function mintTimestampOf(uint256 tokenId) public view virtual override returns (uint256);
tokenDataOf
See {IERC721Timestamped-tokenDataOf}
function tokenDataOf(uint256 tokenId) public view virtual override returns (Types.TokenData memory);
exists
See {IERC721Timestamped-exists}
function exists(uint256 tokenId) public view virtual override returns (bool);
name
See {IERC721Metadata-name}.
function name() public view virtual override returns (string memory);
symbol
See {IERC721Metadata-symbol}.
function symbol() public view virtual override returns (string memory);
totalSupply
function totalSupply() external view virtual override returns (uint256);
approve
See {IERC721-approve}.
function approve(address to, uint256 tokenId) public virtual override;
getApproved
See {IERC721-getApproved}.
function getApproved(uint256 tokenId) public view virtual override returns (address);
setApprovalForAll
See {IERC721-setApprovalForAll}.
function setApprovalForAll(address operator, bool approved) public virtual override;
isApprovedForAll
See {IERC721-isApprovedForAll}.
function isApprovedForAll(address owner, address operator) public view virtual override returns (bool);
transferFrom
See {IERC721-transferFrom}.
function transferFrom(address from, address to, uint256 tokenId) public virtual override;
safeTransferFrom
See {IERC721-safeTransferFrom}.
function safeTransferFrom(address from, address to, uint256 tokenId) public virtual override;
safeTransferFrom
See {IERC721-safeTransferFrom}.
function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory _data) public virtual override;
burn
*Burns tokenId.
Requirements:
- The caller must own tokenIdor be an approved operator.*
function burn(uint256 tokenId) public virtual override;
_unsafeOwnerOf
Returns the owner of the tokenId token.
It is prefixed as unsafe as it does not revert when the token does not exist.
function _unsafeOwnerOf(uint256 tokenId) internal view returns (address);
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The token whose owner is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address owning the given token, zero address if the token does not exist. | 
_safeTransfer
*Safely transfers tokenId token from from to to, checking first that contract recipients
are aware of the ERC721 protocol to prevent tokens from being forever locked.
_data is additional data, it has no specified format and it is sent in call to to.
This internal function is equivalent to {safeTransferFrom}, and can be used to e.g.
implement alternative mechanisms to perform a token transfer, such as signature-based.
Requirements:
- fromcannot be the zero address.
- tocannot be the zero address.
- tokenIdtoken must exist and be owned by- from.
- If torefers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. Emits a {Transfer} event.*
function _safeTransfer(address from, address to, uint256 tokenId, bytes memory _data) internal virtual;
_exists
Returns whether tokenId exists.
Tokens can be managed by their owner or approved accounts via {approve} or {setApprovalForAll}.
Tokens start existing when they are minted (_mint),
and stop existing when they are burned (_burn).
function _exists(uint256 tokenId) internal view virtual returns (bool);
_isApprovedOrOwner
*Returns whether spender is allowed to manage tokenId.
Requirements:
- tokenIdmust exist.*
function _isApprovedOrOwner(address spender, uint256 tokenId) internal view virtual returns (bool);
_mint
*Mints tokenId and transfers it to to.
WARNING: Usage of this method is discouraged, use {_safeMint} whenever possible
Requirements:
- tokenIdmust not exist.
- tocannot be the zero address. Emits a {Transfer} event.*
function _mint(address to, uint256 tokenId) internal virtual;
_burn
*Destroys tokenId.
The approval is cleared when the token is burned.
Requirements:
- tokenIdmust exist. Emits a {Transfer} event.*
function _burn(uint256 tokenId) internal virtual;
_transfer
*Transfers tokenId from from to to.
As opposed to {transferFrom}, this imposes no restrictions on msg.sender.
Requirements:
- tocannot be the zero address.
- tokenIdtoken must be owned by- from. Emits a {Transfer} event.*
function _transfer(address from, address to, uint256 tokenId) internal virtual;
_approve
Approve to to operate on tokenId
Emits a {Approval} event.
function _approve(address to, uint256 tokenId) internal virtual;
_setOperatorApproval
Refactored from the original OZ ERC721 implementation: approve or revoke approval from
operator to operate on all tokens owned by owner.
Emits a {ApprovalForAll} event.
function _setOperatorApproval(address owner, address operator, bool approved) internal virtual;
_checkOnERC721Received
Private function to invoke {IERC721Receiver-onERC721Received} on a target address. The call is not executed if the target address is not a contract.
function _checkOnERC721Received(address from, address to, uint256 tokenId, bytes memory _data) private returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| from | address | address representing the previous owner of the given token ID | 
| to | address | target address that will receive the tokens | 
| tokenId | uint256 | uint256 ID of the token to be transferred | 
| _data | bytes | bytes optional data to send along with the call | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool whether the call correctly returned the expected magic value | 
_beforeTokenTransfer
*Hook that is called before any token transfer. This includes minting and burning. Calling conditions:
- When fromandtoare both non-zero,from'stokenIdwill be transferred toto.
- When fromis zero,tokenIdwill be minted forto.
- When tois zero,from'stokenIdwill be burned.
- fromand- toare never both zero. To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].*
function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal virtual;
LensGovernable
Inherits: ILensGovernable
Functions
onlyGov
This modifier reverts if the caller is not the configured governance address.
modifier onlyGov();
setGovernance
GOV FUNCTIONS ///
function setGovernance(address newGovernance) external override onlyGov;
Parameters
| Name | Type | Description | 
|---|---|---|
| newGovernance | address | The new governance address to set. | 
setEmergencyAdmin
Sets the emergency admin, which is a permissioned role able to set the protocol state.
function setEmergencyAdmin(address newEmergencyAdmin) external override onlyGov;
Parameters
| Name | Type | Description | 
|---|---|---|
| newEmergencyAdmin | address | The new emergency admin address to set. | 
setState
Sets the protocol state to either a global pause, a publishing pause or an unpaused state.
function setState(Types.ProtocolState newState) external override;
Parameters
| Name | Type | Description | 
|---|---|---|
| newState | Types.ProtocolState | The state to set. It can be one of the following: - Unpaused: The protocol is fully operational. - PublishingPaused: The protocol is paused for publishing, but it is still operational for others operations. - Paused: The protocol is paused for all operations. | 
setTreasury
Sets the treasury address.
function setTreasury(address newTreasury) external override onlyGov;
Parameters
| Name | Type | Description | 
|---|---|---|
| newTreasury | address | The new treasury address to set. | 
setTreasuryFee
Sets the treasury fee.
function setTreasuryFee(uint16 newTreasuryFee) external override onlyGov;
Parameters
| Name | Type | Description | 
|---|---|---|
| newTreasuryFee | uint16 | The new treasury fee to set. | 
whitelistProfileCreator
Adds or removes a profile creator from the whitelist.
function whitelistProfileCreator(address profileCreator, bool whitelist) external override onlyGov;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileCreator | address | The profile creator address to add or remove from the whitelist. | 
| whitelist | bool | Whether or not the profile creator should be whitelisted. | 
getGovernance
EXTERNAL VIEW FUNCTIONS ///
function getGovernance() external view override returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address of the currently configured governance. | 
getState
Returns the current protocol state.
function getState() external view override returns (Types.ProtocolState);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.ProtocolState | ProtocolState The Protocol state, an enum, where: 0: Unpaused 1: PublishingPaused 2: Paused | 
isProfileCreatorWhitelisted
Returns whether or not a profile creator is whitelisted.
function isProfileCreatorWhitelisted(address profileCreator) external view override returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileCreator | address | The address of the profile creator to check. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the profile creator is whitelisted, false otherwise. | 
getTreasury
Returns the treasury address.
function getTreasury() external view override returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The treasury address. | 
getTreasuryFee
Returns the treasury fee.
function getTreasuryFee() external view override returns (uint16);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint16 | uint16 The treasury fee. | 
getTreasuryData
Returns the treasury address and treasury fee in a single call.
function getTreasuryData() external view override returns (address, uint16);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | tuple First, the treasury address, second, the treasury fee. | 
| <none> | uint16 | 
LensHubEventHooks
Inherits: ILensHubEventHooks
Functions
emitUnfollowedEvent
Helper function to emit an Unfollowed event from the hub, to be consumed by indexers to track unfollows.
function emitUnfollowedEvent(uint256 unfollowerProfileId, uint256 idOfProfileUnfollowed, address transactionExecutor)
    external
    override;
Parameters
| Name | Type | Description | 
|---|---|---|
| unfollowerProfileId | uint256 | The ID of the profile that executed the unfollow. | 
| idOfProfileUnfollowed | uint256 | The ID of the profile that was unfollowed. | 
| transactionExecutor | address | The address of the account executing the unfollow operation. | 
emitCollectNFTTransferEvent
DEPRECATED FUNCTIONS ///
function emitCollectNFTTransferEvent(uint256 profileId, uint256 pubId, uint256 collectNFTId, address from, address to)
    external;
LensHubStorage
Author: Lens Protocol
This is an abstract contract that ONLY contains storage for the LensHub contract. This MUST be inherited last to preserve the LensHub storage layout. Adding storage variables should be done ONLY at the bottom of this contract.
State Variables
_lastInitializedRevision
uint256 private _lastInitializedRevision;
_state
Types.ProtocolState internal _state;
_profileCreatorWhitelisted
mapping(address profileCreator => bool isWhitelisted) internal _profileCreatorWhitelisted;
__DEPRECATED__followModuleWhitelisted
mapping(address => bool isWhitelisted) internal __DEPRECATED__followModuleWhitelisted;
__DEPRECATED__collectModuleWhitelisted
mapping(address collectModule => bool isWhitelisted) internal __DEPRECATED__collectModuleWhitelisted;
__DEPRECATED__referenceModuleWhitelisted
mapping(address referenceModule => bool isWhitelisted) internal __DEPRECATED__referenceModuleWhitelisted;
__DEPRECATED__dispatcherByProfile
mapping(uint256 profileId => address dispatcher) internal __DEPRECATED__dispatcherByProfile;
__DEPRECATED__profileIdByHandleHash
mapping(bytes32 handleHash => uint256 profileId) internal __DEPRECATED__profileIdByHandleHash;
_profiles
mapping(uint256 profileId => Types.Profile profile) internal _profiles;
_publications
mapping(uint256 profileId => mapping(uint256 pubId => Types.Publication publication)) internal _publications;
__DEPRECATED__defaultProfiles
mapping(address userAddress => uint256 profileId) internal __DEPRECATED__defaultProfiles;
_profileCounter
uint256 internal _profileCounter;
_governance
address internal _governance;
_emergencyAdmin
address internal _emergencyAdmin;
_tokenGuardianDisablingTimestamp
mapping(address => uint256) internal _tokenGuardianDisablingTimestamp;
_delegatedExecutorsConfigs
mapping(uint256 profileId => Types.DelegatedExecutorsConfig config) internal _delegatedExecutorsConfigs;
_blockedStatus
mapping(uint256 blockerProfileId => mapping(uint256 blockedProfileId => bool isBlocked)) internal _blockedStatus;
_profileRoyaltiesBps
uint256 internal _profileRoyaltiesBps;
_migrationAdminWhitelisted
mapping(address migrationAdmin => bool allowed) internal _migrationAdminWhitelisted;
_treasuryData
Types.TreasuryData internal _treasuryData;
LensImplGetters
Inherits: ILensImplGetters
State Variables
FOLLOW_NFT_IMPL
address internal immutable FOLLOW_NFT_IMPL;
__LEGACY__COLLECT_NFT_IMPL
address internal immutable __LEGACY__COLLECT_NFT_IMPL;
MODULE_REGISTRY
address internal immutable MODULE_REGISTRY;
Functions
constructor
constructor(address followNFTImpl, address collectNFTImpl, address moduleRegistry);
getFollowNFTImpl
Returns the Follow NFT implementation address that is used for all deployed Follow NFTs.
function getFollowNFTImpl() external view override returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The Follow NFT implementation address. | 
getLegacyCollectNFTImpl
Returns the Collect NFT implementation address that is used for each new deployed Collect NFT.
function getLegacyCollectNFTImpl() external view override returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The Collect NFT implementation address. | 
getModuleRegistry
Returns the address of the registry that stores all modules that are used by the Lens Protocol.
function getModuleRegistry() external view override returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address of the Module Registry contract. | 
LensProfiles
Inherits: LensBaseERC721, ERC2981CollectionRoyalties, ILensProfiles
State Variables
TOKEN_GUARDIAN_COOLDOWN
uint256 internal immutable TOKEN_GUARDIAN_COOLDOWN;
Functions
constructor
constructor(uint256 tokenGuardianCooldown);
whenNotPaused
modifier whenNotPaused();
onlyProfileOwner
modifier onlyProfileOwner(address expectedOwner, uint256 profileId);
onlyEOA
modifier onlyEOA();
getTokenGuardianDisablingTimestamp
Returns the timestamp at which the Token Guardian will become effectively disabled.
function getTokenGuardianDisablingTimestamp(address wallet) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| wallet | address | The address to check the timestamp for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The timestamp at which the Token Guardian will become effectively disabled. Zero if enabled. | 
DANGER__disableTokenGuardian
DANGER: Triggers disabling the profile protection mechanism for the msg.sender, which will allow transfers or approvals over profiles held by it. Disabling the mechanism will have a 7-day timelock before it becomes effective, allowing the owner to re-enable the protection back in case of being under attack. The protection layer only applies to EOA wallets.
function DANGER__disableTokenGuardian() external onlyEOA;
enableTokenGuardian
Enables back the profile protection mechanism for the msg.sender, preventing profile transfers or approvals (except when revoking them). The protection layer only applies to EOA wallets.
function enableTokenGuardian() external onlyEOA;
burn
Burns a profile, this maintains the profile data struct.
function burn(uint256 tokenId)
    public
    override(LensBaseERC721, IERC721Burnable)
    whenNotPaused
    onlyProfileOwner(msg.sender, tokenId);
tokenURI
Overrides the ERC721 tokenURI function to return the associated URI with a given profile.
function tokenURI(uint256 tokenId) public view override(LensBaseERC721, IERC721Metadata) returns (string memory);
approve
function approve(address to, uint256 tokenId) public override(LensBaseERC721, IERC721);
setApprovalForAll
function setApprovalForAll(address operator, bool approved) public override(LensBaseERC721, IERC721);
supportsInterface
See {IERC165-supportsInterface}.
function supportsInterface(bytes4 interfaceId)
    public
    view
    virtual
    override(LensBaseERC721, ERC2981CollectionRoyalties, IERC165)
    returns (bool);
_hasTokenGuardianEnabled
function _hasTokenGuardianEnabled(address wallet) internal view returns (bool);
_getRoyaltiesInBasisPointsSlot
function _getRoyaltiesInBasisPointsSlot() internal pure override returns (uint256);
_getReceiver
function _getReceiver(uint256) internal view override returns (address);
_beforeRoyaltiesSet
function _beforeRoyaltiesSet(uint256) internal view override;
_beforeTokenTransfer
function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal override whenNotPaused;
Contents
- ICollectModule
- ICollectNFT
- IERC721Burnable
- IERC721MetaTx
- IERC721Timestamped
- IFollowModule
- IFollowNFT
- ILegacyCollectModule
- ILegacyCollectNFT
- ILegacyFollowModule
- ILegacyReferenceModule
- ILensERC721
- ILensGovernable
- ILensHandles
- ILensHub
- ILensHubEventHooks
- ILensHubInitializable
- ILensImplGetters
- ILensProfiles
- ILensProtocol
- IModuleRegistry
- IPublicationActionModule
- IReferenceModule
- ITokenHandleRegistry
ICollectModule
Author: Lens Protocol
This is the standard interface for all Lens-compatible CollectModules. Collect modules allow users to execute custom logic upon a collect action over a publication, like:
- Only allow the collect if the collector is following the publication author.
- Only allow the collect if the collector has made a payment to
- Allow any collect but only during the first 24 hours.
- Etc.
Functions
initializePublicationCollectModule
Initializes data for a given publication being published.
function initializePublicationCollectModule(
    uint256 profileId,
    uint256 pubId,
    address transactionExecutor,
    bytes calldata data
) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| transactionExecutor | address | The owner or an approved delegated executor. | 
| data | bytes | Arbitrary data passed from the user! to be decoded. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processCollect
Processes a collect action for a given publication.
function processCollect(Types.ProcessCollectParams calldata processCollectParams) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | The parameters for the collect action. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
ICollectNFT
Author: Lens Protocol
This is the interface for the CollectNFT contract. Which is cloned upon the first collect for any given publication.
Functions
initialize
Initializes the collect NFT, setting the feed as the privileged minter, storing the collected publication pointer and initializing the name and symbol in the LensNFTBase contract.
function initialize(uint256 profileId, uint256 pubId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile in the hub that this Collect NFT points to. | 
| pubId | uint256 | The profile publication ID in the hub that this Collect NFT points to. | 
mint
Mints a collect NFT to the specified address. This can only be called by the hub and is called upon collection.
function mint(address to) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| to | address | The address to mint the NFT to. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the minted token ID. | 
getSourcePublicationPointer
Returns the source publication of this collect NFT.
function getSourcePublicationPointer() external view returns (uint256, uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | tuple First is the profile ID, and second is the publication ID. | 
| <none> | uint256 | 
IERC721Burnable
Author: Lens Protocol
Extension of ERC-721 including a function that allows the token to be burned.
Functions
burn
Burns an NFT, removing it from circulation and essentially destroying it.
function burn(uint256 tokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The token ID of the token to burn. | 
IERC721MetaTx
Author: Lens Protocol
Extension of ERC-721 including meta-tx signatures related functions.
Functions
nonces
Returns the current signature nonce of the given signer.
function nonces(address signer) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| signer | address | The address for which to query the nonce. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The current nonce of the given signer. | 
getDomainSeparator
Returns the EIP-712 domain separator for this contract.
function getDomainSeparator() external view returns (bytes32);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | bytes32 The domain separator. | 
IERC721Timestamped
Author: Lens Protocol
Extension of ERC-721 including a struct for token data, which contains the owner and the mint timestamp, as well as their associated getters.
Functions
mintTimestampOf
Returns the mint timestamp associated with a given NFT.
function mintTimestampOf(uint256 tokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The token ID of the NFT to query the mint timestamp for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 Mint timestamp, this is stored as a uint96 but returned as a uint256 to reduce unnecessary padding. | 
tokenDataOf
Returns the token data associated with a given NFT. This allows fetching the token owner and mint timestamp in a single call.
function tokenDataOf(uint256 tokenId) external view returns (Types.TokenData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The token ID of the NFT to query the token data for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.TokenData | TokenData A struct containing both the owner address and the mint timestamp. | 
exists
Returns whether a token with the given token ID exists.
function exists(uint256 tokenId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The token ID of the NFT to check existence for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the token exists. | 
totalSupply
Returns the amount of tokens in circulation.
function totalSupply() external view returns (uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The current total supply of tokens. | 
IFollowModule
Author: Lens Protocol
This is the standard interface for all Lens-compatible Follow Modules. These are responsible for processing the follow actions and can be used to implement any kind of follow logic. For example:
- Token-gated follows (e.g. a user must hold a certain amount of a token to follow a profile).
- Paid follows (e.g. a user must pay a certain amount of a token to follow a profile).
- Rewarding users for following a profile.
- Etc.
Functions
initializeFollowModule
Initializes a follow module for a given Lens profile.
function initializeFollowModule(uint256 profileId, address transactionExecutor, bytes calldata data)
    external
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The Profile ID to initialize this follow module for. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| data | bytes | Arbitrary data passed from the user to be decoded by the Follow Module during initialization. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes The encoded data to be emitted from the hub. | 
processFollow
Processes a given follow.
function processFollow(
    uint256 followerProfileId,
    uint256 followTokenId,
    address transactionExecutor,
    uint256 targetProfileId,
    bytes calldata data
) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The Profile ID of the follower's profile. | 
| followTokenId | uint256 | The Follow Token ID that is being used to follow. Zero if we are processing a new fresh follow, in this case, the follow ID assigned can be queried from the Follow NFT collection if needed. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| targetProfileId | uint256 | The token ID of the profile being followed. | 
| data | bytes | Arbitrary data passed by the follower. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
IFollowNFT
Author: Lens Protocol
This is the interface for the FollowNFT contract, which is cloned upon the first follow for any profile. By default the Follow tokens are tied to the follower profile, which means that they will be automatically transferred with it. This is achieved by them not being ERC-721 initially. However, the Follow NFT collections support converting them to ERC-721 tokens (i.e. wrapping) natively, enabling composability with existing ERC-721-based protocols.
Functions
initialize
Initializes the follow NFT.
Sets the targeted profile, and the token royalties.
function initialize(uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The ID of the profile targeted by the follow tokens minted by this collection. | 
follow
Makes the passed profile follow the profile targeted in this contract.
function follow(uint256 followerProfileId, address transactionExecutor, uint256 followTokenId)
    external
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile acting as the follower. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| followTokenId | uint256 | The ID of the follow token to be used for this follow operation. Zero if a new follow token should be minted. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the token used to follow. | 
unfollow
Makes the passed profile unfollow the profile targeted in this contract.
function unfollow(uint256 unfollowerProfileId, address transactionExecutor) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| unfollowerProfileId | uint256 | The ID of the profile that is performing the unfollow operation. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
removeFollower
Removes the follower from the given follow NFT.
Only on wrapped token.
function removeFollower(uint256 followTokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to remove the follower from. | 
approveFollow
Approves the given profile to follow with the given wrapped token.
Only on wrapped tokens. It approves setting a follower on the given wrapped follow token, which lets the follow token owner to allow a profile to follow with his token without losing its ownership. This approval is cleared on transfers, as well as when unwrapping.
function approveFollow(uint256 approvedProfileId, uint256 followTokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| approvedProfileId | uint256 | The ID of the profile approved to follow with the given token. | 
| followTokenId | uint256 | The ID of the follow token to be approved for the given profile. | 
wrap
Unties the follow token from the follower's profile one, and wraps it into the ERC-721 untied follow tokens collection. Untied follow tokens will NOT be automatically transferred with their follower profile.
Only on unwrapped follow tokens.
function wrap(uint256 followTokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to untie and wrap. | 
wrap
Unties the follow token from the follower's profile one, and wraps it into the ERC-721 untied follow tokens collection. Untied follow tokens will NOT be automatically transferred with their follower profile.
Only on unwrapped follow tokens.
function wrap(uint256 followTokenId, address wrappedTokenReceiver) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to untie and wrap. | 
| wrappedTokenReceiver | address | The address where the follow token is minted to when being wrapped as ERC-721. | 
unwrap
Unwraps the follow token from the ERC-721 untied follow tokens collection, and ties it to the follower's profile token. Tokens that are tied to the follower profile will be automatically transferred with it.
function unwrap(uint256 followTokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to unwrap and tie to its follower. | 
processBlock
Processes logic when the given profile is being blocked. If it was following the targeted profile, this will make it unfollow.
function processBlock(uint256 followerProfileId) external returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the follow token to unwrap and tie. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the given profile was following and now has unfollowed, false otherwise. | 
getFollowerProfileId
GETTERS ///
Gets the ID of the profile following with the given follow token.
function getFollowerProfileId(uint256 followTokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose follower should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the profile following with the given token, zero if it is not being used to follow. | 
getOriginalFollowTimestamp
Gets the original follow timestamp of the given follow token.
function getOriginalFollowTimestamp(uint256 followTokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose original follow timestamp should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The timestamp of the first follow performed with the token, zero if was not used to follow yet. | 
getFollowTimestamp
Gets the current follow timestamp of the given follow token.
function getFollowTimestamp(uint256 followTokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose follow timestamp should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The timestamp of the current follow of the token, zero if it is not being used to follow. | 
getProfileIdAllowedToRecover
Gets the ID of the profile allowed to recover the given follow token.
function getProfileIdAllowedToRecover(uint256 followTokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose allowed profile to recover should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the profile allowed to recover the given follow token, zero if none of them is allowed. | 
getFollowData
Gets the follow data of the given follow token.
function getFollowData(uint256 followTokenId) external view returns (Types.FollowData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose follow data should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.FollowData | FollowData The token data associated with the given follow token. | 
isFollowing
Tells if the given profile is following the profile targeted in this contract.
function isFollowing(uint256 followerProfileId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile whose following state should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | uint256 The ID of the profile set as a follower in the given token, zero if it is not being used to follow. | 
getFollowTokenId
Gets the ID of the token being used to follow by the given follower.
function getFollowTokenId(uint256 followerProfileId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile whose follow ID should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the token being used to follow by the given follower, zero if he is not following. | 
getFollowApproved
Gets the ID of the profile approved to follow with the given token.
function getFollowApproved(uint256 followTokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the token whose approved to follow should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the profile approved to follow with the given token, zero if none of them is approved. | 
getFollowerCount
Gets the count of the followers of the profile targeted in this contract.
This number might be out of sync if one of the followers burns their profile.
function getFollowerCount() external view returns (uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The count of the followers of the profile targeted in this contract. | 
Errors
AlreadyFollowing
error AlreadyFollowing();
NotFollowing
error NotFollowing();
FollowTokenDoesNotExist
error FollowTokenDoesNotExist();
AlreadyWrapped
error AlreadyWrapped();
OnlyWrappedFollowTokens
error OnlyWrappedFollowTokens();
DoesNotHavePermissions
error DoesNotHavePermissions();
ILegacyCollectModule
Author: Lens Protocol
This is the deprecated interface for previously Lens-compatible CollectModules.
Functions
initializePublicationCollectModule
Initializes data for a given publication being published. This can only be called by the hub.
function initializePublicationCollectModule(uint256 profileId, uint256 pubId, bytes calldata data)
    external
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| data | bytes | Arbitrary data passed from the user! to be decoded. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes An ABI-encoded encapsulating the execution's state changes. This will be emitted by the hub alongside the collect module's address and should be consumed by front ends. | 
processCollect
Processes a collect action for a given publication, this can only be called by the hub.
function processCollect(
    uint256 referrerProfileId,
    address collector,
    uint256 profileId,
    uint256 pubId,
    bytes calldata data
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| referrerProfileId | uint256 | The LensHub profile token ID of the referrer's profile (only different in case of mirrors). | 
| collector | address | The collector address. | 
| profileId | uint256 | The token ID of the profile associated with the publication being collected. | 
| pubId | uint256 | The LensHub publication ID associated with the publication being collected. | 
| data | bytes | Arbitrary data passed from the collector! to be decoded. | 
ILegacyCollectNFT
Author: Lens Protocol
This is the interface for the Lens V1 CollectNFT contract. Which is cloned upon the first collect for any given publication.
Functions
initialize
Initializes the collect NFT, setting the feed as the privileged minter, storing the collected publication pointer and initializing the name and symbol in the LensNFTBase contract.
function initialize(uint256 profileId, uint256 pubId, string calldata name, string calldata symbol) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile in the hub that this Collect NFT points to. | 
| pubId | uint256 | The profile publication ID in the hub that this Collect NFT points to. | 
| name | string | The name to set for this NFT. | 
| symbol | string | The symbol to set for this NFT. | 
mint
Mints a collect NFT to the specified address.
function mint(address to) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| to | address | The address to mint the NFT to. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the minted token ID. | 
getSourcePublicationPointer
Returns the source publication of this collect NFT.
function getSourcePublicationPointer() external view returns (uint256, uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | tuple First is the profile ID, and second is the publication ID. | 
| <none> | uint256 | 
ILegacyFollowModule
Author: Lens Protocol
This is the deprecated interface for previously Lens-compatible FollowModules.
Functions
initializeFollowModule
Initializes a follow module for a given Lens profile. This can only be called by the hub contract.
function initializeFollowModule(uint256 profileId, bytes calldata data) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to initialize this follow module for. | 
| data | bytes | Arbitrary data passed by the profile creator. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes The encoded data to emit in the hub. | 
processFollow
Processes a given follow, this can only be called from the LensHub contract.
function processFollow(address follower, uint256 profileId, bytes calldata data) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| follower | address | The follower address. | 
| profileId | uint256 | The token ID of the profile being followed. | 
| data | bytes | Arbitrary data passed by the follower. | 
followModuleTransferHook
This is a transfer hook that is called upon follow NFT transfer in `beforeTokenTransfer. This can only be called from the LensHub contract. NOTE: Special care needs to be taken here: It is possible that follow NFTs were issued before this module was initialized if the profile's follow module was previously different. This transfer hook should take this into consideration, especially when the module holds a state associated with individual follow NFTs.
function followModuleTransferHook(uint256 profileId, address from, address to, uint256 followNFTTokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile associated with the follow NFT being transferred. | 
| from | address | The address sending the follow NFT. | 
| to | address | The address receiving the follow NFT. | 
| followNFTTokenId | uint256 | The token ID of the follow NFT being transferred. | 
isFollowing
This is a helper function that could be used in conjunction with specific collect modules.
NOTE: This function IS meant to replace a check on follower NFT ownership.
NOTE: It is assumed that not all collect modules are aware of the token ID to pass. In these cases,
this should receive a followNFTTokenId of 0, which is impossible regardless.
One example of a use case for this would be a subscription-based following system:
- The collect module:
- Decodes a follower NFT token ID from user-passed data.
- Fetches the follow module from the hub.
- Calls isFollowingpassing the profile ID, follower & follower token ID and checks it returned true.
- The follow module:
- Validates the subscription status for that given NFT, reverting on an invalid subscription.
function isFollowing(uint256 profileId, address follower, uint256 followNFTTokenId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to validate the follow for. | 
| follower | address | The follower address to validate the follow for. | 
| followNFTTokenId | uint256 | The followNFT token ID to validate the follow for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | true if the given address is following the given profile ID, false otherwise. | 
ILegacyReferenceModule
Author: Lens Protocol
This is the deprecated interface for previously Lens-compatible ReferenceModules.
Functions
initializeReferenceModule
Initializes data for a given publication being published. This can only be called by the hub.
function initializeReferenceModule(uint256 profileId, uint256 pubId, bytes calldata data)
    external
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| data | bytes | Arbitrary data passed from the user to be decoded. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes An ABI-encoded data encapsulating the execution's state changes. This will be emitted by the hub alongside the collect module's address and should be consumed by front ends. | 
processComment
Processes a comment action referencing a given publication. This can only be called by the hub.
function processComment(uint256 profileId, uint256 pointedProfileId, uint256 pointedPubId, bytes calldata data)
    external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile associated with the publication being published. | 
| pointedProfileId | uint256 | The profile ID of the profile associated with the publication being referenced. | 
| pointedPubId | uint256 | The publication ID of the publication being referenced. | 
| data | bytes | Arbitrary data passed from the commenter! to be decoded. | 
processMirror
Processes a mirror action referencing a given publication. This can only be called by the hub.
function processMirror(uint256 profileId, uint256 pointedProfileId, uint256 pointedPubId, bytes calldata data)
    external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile associated with the publication being published. | 
| pointedProfileId | uint256 | The profile ID of the profile associated with the publication being referenced. | 
| pointedPubId | uint256 | The publication ID of the publication being referenced. | 
| data | bytes | Arbitrary data passed from the mirrorer! to be decoded. | 
ILensERC721
Inherits: IERC721, IERC721Timestamped, IERC721Burnable, IERC721MetaTx, IERC721Metadata
ILensGovernable
Author: Lens Protocol
This is the interface for the Lens Protocol main governance functions.
Functions
setGovernance
Sets the privileged governance role.
function setGovernance(address newGovernance) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newGovernance | address | The new governance address to set. | 
setEmergencyAdmin
Sets the emergency admin, which is a permissioned role able to set the protocol state.
function setEmergencyAdmin(address newEmergencyAdmin) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newEmergencyAdmin | address | The new emergency admin address to set. | 
setState
Sets the protocol state to either a global pause, a publishing pause or an unpaused state.
function setState(Types.ProtocolState newState) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newState | Types.ProtocolState | The state to set. It can be one of the following: - Unpaused: The protocol is fully operational. - PublishingPaused: The protocol is paused for publishing, but it is still operational for others operations. - Paused: The protocol is paused for all operations. | 
whitelistProfileCreator
Adds or removes a profile creator from the whitelist.
function whitelistProfileCreator(address profileCreator, bool whitelist) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileCreator | address | The profile creator address to add or remove from the whitelist. | 
| whitelist | bool | Whether or not the profile creator should be whitelisted. | 
setTreasury
Sets the treasury address.
function setTreasury(address newTreasury) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newTreasury | address | The new treasury address to set. | 
setTreasuryFee
Sets the treasury fee.
function setTreasuryFee(uint16 newTreasuryFee) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newTreasuryFee | uint16 | The new treasury fee to set. | 
getGovernance
Returns the currently configured governance address.
function getGovernance() external view returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address of the currently configured governance. | 
getState
Gets the state currently set in the protocol. It could be a global pause, a publishing pause or an unpaused state.
function getState() external view returns (Types.ProtocolState);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.ProtocolState | Types.ProtocolState The state currently set in the protocol. | 
isProfileCreatorWhitelisted
Returns whether or not a profile creator is whitelisted.
function isProfileCreatorWhitelisted(address profileCreator) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileCreator | address | The address of the profile creator to check. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the profile creator is whitelisted, false otherwise. | 
getTreasury
Returns the treasury address.
function getTreasury() external view returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The treasury address. | 
getTreasuryFee
Returns the treasury fee.
function getTreasuryFee() external view returns (uint16);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint16 | uint16 The treasury fee. | 
getTreasuryData
Returns the treasury address and treasury fee in a single call.
function getTreasuryData() external view returns (address, uint16);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | tuple First, the treasury address, second, the treasury fee. | 
| <none> | uint16 | 
ILensHandles
Inherits: IERC721
Author: Lens Protocol
This is the interface for the LensHandles contract that is responsible for minting and burning handle NFTs.
A handle is composed of a local name and a namespace, separated by a dot.
Example: satoshi.lens is a handle composed of the local name satoshi and the namespace lens.
Functions
mintHandle
Mints a handle NFT in the given namespace.
function mintHandle(address to, string calldata localName) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| to | address | The address to mint the handle to. | 
| localName | string | The local name of the handle (the part before ".lens"). | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the handle NFT minted. | 
burn
Burns a handle NFT.
function burn(uint256 tokenId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | The ID of the handle NFT to burn. | 
getNamespace
Gets the namespace of the contract. It's 'lens' for the LensHandles contract.
function getNamespace() external pure returns (string memory);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | string | string The namespace of the contract. | 
getNamespaceHash
Gets the hash of the namespace of the contract. It's keccak256('lens') for the LensHandles contract.
function getNamespaceHash() external pure returns (bytes32);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | bytes32 The hash of the namespace of the contract. | 
exists
Returns whether tokenId exists.
Tokens start existing when they are minted (_mint),
and stop existing when they are burned (_burn).
function exists(uint256 tokenId) external view returns (bool);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool Whether the token exists. | 
ILensHub
Inherits: ILensProfiles, ILensProtocol, ILensGovernable, ILensHubEventHooks, ILensImplGetters
ILensHubEventHooks
Author: Lens Protocol
This is the interface for the LensHub contract's event hooks. As we want most of the core events to be emitted by the LensHub contract, event hooks are needed for core events generated by pheripheral contracts.
Functions
emitUnfollowedEvent
Helper function to emit an Unfollowed event from the hub, to be consumed by indexers to track unfollows.
function emitUnfollowedEvent(uint256 unfollowerProfileId, uint256 idOfProfileUnfollowed, address transactionExecutor)
    external;
Parameters
| Name | Type | Description | 
|---|---|---|
| unfollowerProfileId | uint256 | The ID of the profile that executed the unfollow. | 
| idOfProfileUnfollowed | uint256 | The ID of the profile that was unfollowed. | 
| transactionExecutor | address | The address of the account executing the unfollow operation. | 
ILensHubInitializable
Author: Lens Protocol
This is the interface for the LensHub contract, the main entry point for the Lens Protocol. You'll find all the events and external functions, as well as the reasoning behind them here.
Functions
initialize
Initializes the LensHub, setting the initial governance address, the name and symbol of the profiles in the LensNFTBase contract, and Protocol State (Paused).
This is assuming a proxy pattern is implemented.
function initialize(string calldata name, string calldata symbol, address newGovernance) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| name | string | The name of the Profile NFT. | 
| symbol | string | The symbol of the Profile NFT. | 
| newGovernance | address | The governance address to set. | 
ILensImplGetters
Author: Lens Protocol
This is the interface for the LensHub contract's implementation getters. These implementations will be used for deploying each respective contract for each profile.
Functions
getFollowNFTImpl
Returns the Follow NFT implementation address that is used for all deployed Follow NFTs.
function getFollowNFTImpl() external view returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The Follow NFT implementation address. | 
getLegacyCollectNFTImpl
Returns the Collect NFT implementation address that is used for each new deployed Collect NFT.
function getLegacyCollectNFTImpl() external view returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The Collect NFT implementation address. | 
getModuleRegistry
Returns the address of the registry that stores all modules that are used by the Lens Protocol.
function getModuleRegistry() external view returns (address);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address of the Module Registry contract. | 
ILensProfiles
Inherits: ILensERC721
Functions
DANGER__disableTokenGuardian
DANGER: Triggers disabling the profile protection mechanism for the msg.sender, which will allow transfers or approvals over profiles held by it. Disabling the mechanism will have a 7-day timelock before it becomes effective, allowing the owner to re-enable the protection back in case of being under attack. The protection layer only applies to EOA wallets.
function DANGER__disableTokenGuardian() external;
enableTokenGuardian
Enables back the profile protection mechanism for the msg.sender, preventing profile transfers or approvals (except when revoking them). The protection layer only applies to EOA wallets.
function enableTokenGuardian() external;
getTokenGuardianDisablingTimestamp
Returns the timestamp at which the Token Guardian will become effectively disabled.
function getTokenGuardianDisablingTimestamp(address wallet) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| wallet | address | The address to check the timestamp for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The timestamp at which the Token Guardian will become effectively disabled. Zero if enabled. | 
ILensProtocol
Author: Lens Protocol
This is the interface for Lens Protocol's core functions. It contains all the entry points for performing social operations.
Functions
createProfile
Creates a profile with the specified parameters, minting a Profile NFT to the given recipient.
function createProfile(Types.CreateProfileParams calldata createProfileParams) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| createProfileParams | Types.CreateProfileParams | A CreateProfileParams struct containing the needed params. | 
setProfileMetadataURI
Sets the metadata URI for the given profile.
function setProfileMetadataURI(uint256 profileId, string calldata metadataURI) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to set the metadata URI for. | 
| metadataURI | string | The metadata URI to set for the given profile. | 
setProfileMetadataURIWithSig
function setProfileMetadataURIWithSig(
    uint256 profileId,
    string calldata metadataURI,
    Types.EIP712Signature calldata signature
) external;
setFollowModule
Sets the follow module for the given profile.
function setFollowModule(uint256 profileId, address followModule, bytes calldata followModuleInitData) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to set the follow module for. | 
| followModule | address | The follow module to set for the given profile, must be whitelisted. | 
| followModuleInitData | bytes | The data to be passed to the follow module for initialization. | 
setFollowModuleWithSig
function setFollowModuleWithSig(
    uint256 profileId,
    address followModule,
    bytes calldata followModuleInitData,
    Types.EIP712Signature calldata signature
) external;
changeDelegatedExecutorsConfig
Changes the delegated executors configuration for the given profile. It allows setting the approvals for delegated executors in the specified configuration, as well as switching to it.
function changeDelegatedExecutorsConfig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals,
    uint64 configNumber,
    bool switchToGivenConfig
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to which the delegated executor is being changed for. | 
| delegatedExecutors | address[] | The array of delegated executors to set the approval for. | 
| approvals | bool[] | The array of booleans indicating the corresponding executor's new approval status. | 
| configNumber | uint64 | The number of the configuration where the executor approval state is being set. | 
| switchToGivenConfig | bool | A boolean indicating if the configuration must be switched to the one with the given number. | 
changeDelegatedExecutorsConfig
Changes the delegated executors configuration for the given profile under the current configuration.
function changeDelegatedExecutorsConfig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to which the delegated executor is being changed for. | 
| delegatedExecutors | address[] | The array of delegated executors to set the approval for. | 
| approvals | bool[] | The array of booleans indicating the corresponding executor's new approval status. | 
changeDelegatedExecutorsConfigWithSig
function changeDelegatedExecutorsConfigWithSig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals,
    uint64 configNumber,
    bool switchToGivenConfig,
    Types.EIP712Signature calldata signature
) external;
post
Publishes a post. Post is the most basic publication type, and can be used to publish any kind of content. Posts can have these types of modules initialized:
- Action modules: any number of publication actions (e.g. collect, tip, etc.)
- Reference module: a module handling the rules when referencing this post (e.g. token-gated comments)
function post(Types.PostParams calldata postParams) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| postParams | Types.PostParams | A PostParams struct containing the needed parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the post's publication ID. | 
postWithSig
function postWithSig(Types.PostParams calldata postParams, Types.EIP712Signature calldata signature)
    external
    returns (uint256);
comment
Publishes a comment on the given publication. Comment is a type of reference publication that points to another publication. Comments can have these types of modules initialized:
- Action modules: any number of publication actions (e.g. collect, tip, etc.)
- Reference module: a module handling the rules when referencing this comment (e.g. token-gated mirrors) Comments can have referrers (e.g. publications or profiles that allowed to discover the pointed publication).
function comment(Types.CommentParams calldata commentParams) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| commentParams | Types.CommentParams | A CommentParams struct containing the needed parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the comment's publication ID. | 
commentWithSig
function commentWithSig(Types.CommentParams calldata commentParams, Types.EIP712Signature calldata signature)
    external
    returns (uint256);
mirror
Publishes a mirror of the given publication. Mirror is a type of reference publication that points to another publication but doesn't have content. Mirrors don't have any modules initialized. Mirrors can have referrers (e.g. publications or profiles that allowed to discover the pointed publication). You cannot mirror a mirror, comment on a mirror, or quote a mirror.
function mirror(Types.MirrorParams calldata mirrorParams) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| mirrorParams | Types.MirrorParams | A MirrorParams struct containing the necessary parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the mirror's publication ID. | 
mirrorWithSig
function mirrorWithSig(Types.MirrorParams calldata mirrorParams, Types.EIP712Signature calldata signature)
    external
    returns (uint256);
quote
Publishes a quote of the given publication. Quote is a type of reference publication similar to mirror, but it has content and modules. Quotes can have these types of modules initialized:
- Action modules: any number of publication actions (e.g. collect, tip, etc.)
- Reference module: a module handling the rules when referencing this quote (e.g. token-gated comments on quote) Quotes can have referrers (e.g. publications or profiles that allowed to discover the pointed publication). Unlike mirrors, you can mirror a quote, comment on a quote, or quote a quote.
function quote(Types.QuoteParams calldata quoteParams) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| quoteParams | Types.QuoteParams | A QuoteParams struct containing the needed parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the quote's publication ID. | 
quoteWithSig
function quoteWithSig(Types.QuoteParams calldata quoteParams, Types.EIP712Signature calldata signature)
    external
    returns (uint256);
follow
Follows given profiles, executing each profile's follow module logic (if any).
Both the idsOfProfilesToFollow, followTokenIds, and datas arrays must be of the same length,
regardless if the profiles do not have a follow module set.
function follow(
    uint256 followerProfileId,
    uint256[] calldata idsOfProfilesToFollow,
    uint256[] calldata followTokenIds,
    bytes[] calldata datas
) external returns (uint256[] memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile the follows are being executed for. | 
| idsOfProfilesToFollow | uint256[] | The array of IDs of profiles to follow. | 
| followTokenIds | uint256[] | The array of follow token IDs to use for each follow (0 if you don't own a follow token). | 
| datas | bytes[] | The arbitrary data array to pass to the follow module for each profile if needed. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256[] | uint256[] An array of follow token IDs representing the follow tokens created for each follow. | 
followWithSig
function followWithSig(
    uint256 followerProfileId,
    uint256[] calldata idsOfProfilesToFollow,
    uint256[] calldata followTokenIds,
    bytes[] calldata datas,
    Types.EIP712Signature calldata signature
) external returns (uint256[] memory);
unfollow
Unfollows given profiles.
function unfollow(uint256 unfollowerProfileId, uint256[] calldata idsOfProfilesToUnfollow) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| unfollowerProfileId | uint256 | The ID of the profile the unfollows are being executed for. | 
| idsOfProfilesToUnfollow | uint256[] | The array of IDs of profiles to unfollow. | 
unfollowWithSig
function unfollowWithSig(
    uint256 unfollowerProfileId,
    uint256[] calldata idsOfProfilesToUnfollow,
    Types.EIP712Signature calldata signature
) external;
setBlockStatus
Sets the block status for the given profiles. Changing a profile's block status to true (i.e. blocked),
when will also force them to unfollow.
Blocked profiles cannot perform any actions with the profile that blocked them: they cannot comment or mirror
their publications, they cannot follow them, they cannot collect, tip them, etc.
Both the idsOfProfilesToSetBlockStatus and blockStatus arrays must be of the same length.
function setBlockStatus(
    uint256 byProfileId,
    uint256[] calldata idsOfProfilesToSetBlockStatus,
    bool[] calldata blockStatus
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| byProfileId | uint256 | The ID of the profile that is blocking/unblocking somebody. | 
| idsOfProfilesToSetBlockStatus | uint256[] | The array of IDs of profiles to set block status. | 
| blockStatus | bool[] | The array of block statuses to use for each (true is blocked). | 
setBlockStatusWithSig
function setBlockStatusWithSig(
    uint256 byProfileId,
    uint256[] calldata idsOfProfilesToSetBlockStatus,
    bool[] calldata blockStatus,
    Types.EIP712Signature calldata signature
) external;
collectLegacy
Collects a given publication via signature with the specified parameters. Collect can have referrers (e.g. publications or profiles that allowed to discover the pointed publication).
function collectLegacy(Types.LegacyCollectParams calldata collectParams) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| collectParams | Types.LegacyCollectParams | A CollectParams struct containing the parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the minted token ID. | 
collectLegacyWithSig
function collectLegacyWithSig(
    Types.LegacyCollectParams calldata collectParams,
    Types.EIP712Signature calldata signature
) external returns (uint256);
act
Acts on a given publication with the specified parameters. You can act on a publication except a mirror (if it has at least one action module initialized). Actions can have referrers (e.g. publications or profiles that allowed to discover the pointed publication).
function act(Types.PublicationActionParams calldata publicationActionParams) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| publicationActionParams | Types.PublicationActionParams | A PublicationActionParams struct containing the parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Arbitrary data the action module returns. | 
actWithSig
function actWithSig(
    Types.PublicationActionParams calldata publicationActionParams,
    Types.EIP712Signature calldata signature
) external returns (bytes memory);
isFollowing
VIEW FUNCTIONS ///
Returns whether or not followerProfileId is following followedProfileId.
function isFollowing(uint256 followerProfileId, uint256 followedProfileId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile whose following state should be queried. | 
| followedProfileId | uint256 | The ID of the profile whose followed state should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if followerProfileIdis followingfollowedProfileId, false otherwise. | 
isDelegatedExecutorApproved
Returns whether the given address is approved as delegated executor, in the configuration with the given number, to act on behalf of the given profile.
function isDelegatedExecutorApproved(uint256 delegatorProfileId, address delegatedExecutor, uint64 configNumber)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to check the delegated executor approval for. | 
| delegatedExecutor | address | The address to query the delegated executor approval for. | 
| configNumber | uint64 | The number of the configuration where the executor approval state is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the address is approved as a delegated executor to act on behalf of the profile in the given configuration, false otherwise. | 
isDelegatedExecutorApproved
Returns whether the given address is approved as delegated executor, in the current configuration, to act on behalf of the given profile.
function isDelegatedExecutorApproved(uint256 delegatorProfileId, address delegatedExecutor)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to check the delegated executor approval for. | 
| delegatedExecutor | address | The address to query the delegated executor approval for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the address is approved as a delegated executor to act on behalf of the profile in the current configuration, false otherwise. | 
getDelegatedExecutorsConfigNumber
Returns the current delegated executor config number for the given profile.
function getDelegatedExecutorsConfigNumber(uint256 delegatorProfileId) external view returns (uint64);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile from which the delegated executors config number is being queried | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint64 | uint256 The current delegated executor configuration number. | 
getDelegatedExecutorsPrevConfigNumber
Returns the previous used delegated executor config number for the given profile.
function getDelegatedExecutorsPrevConfigNumber(uint256 delegatorProfileId) external view returns (uint64);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile from which the delegated executors' previous configuration number set is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint64 | uint256 The delegated executor configuration number previously set. It will coincide with the current configuration set if it was never switched from the default one. | 
getDelegatedExecutorsMaxConfigNumberSet
Returns the maximum delegated executor config number for the given profile. This is the maximum config number that was ever used by this profile. When creating a new clean configuration, you can only use a number that is maxConfigNumber + 1.
function getDelegatedExecutorsMaxConfigNumberSet(uint256 delegatorProfileId) external view returns (uint64);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile from which the delegated executors' maximum configuration number set is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint64 | uint256 The delegated executor maximum configuration number set. | 
isBlocked
Returns whether profileId is blocked by byProfileId.
See setBlockStatus() for more information on how blocking works on the platform.
function isBlocked(uint256 profileId, uint256 byProfileId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The ID of the profile whose blocked status should be queried. | 
| byProfileId | uint256 | The ID of the profile whose blocker status should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if profileIdis blocked bybyProfileId, false otherwise. | 
getContentURI
Returns the URI associated with a given publication. This is used to store the publication's metadata, e.g.: content, images, etc.
function getContentURI(uint256 profileId, uint256 pubId) external view returns (string memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | string | string The URI associated with a given publication. | 
getProfile
Returns the full profile struct associated with a given profile token ID.
function getProfile(uint256 profileId) external view returns (Types.Profile memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.Profile | Profile The profile struct of the given profile. | 
getPublication
Returns the full publication struct for a given publication.
function getPublication(uint256 profileId, uint256 pubId) external view returns (Types.PublicationMemory memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.PublicationMemory | Publication The publication struct associated with the queried publication. | 
getPublicationType
Returns the type of a given publication. The type can be one of the following (see PublicationType enum):
- Nonexistent
- Post
- Comment
- Mirror
- Quote
function getPublicationType(uint256 profileId, uint256 pubId) external view returns (Types.PublicationType);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.PublicationType | PublicationType The publication type of the queried publication. | 
isActionModuleEnabledInPublication
Returns wether a given Action Module is enabled for a given publication.
function isActionModuleEnabledInPublication(uint256 profileId, uint256 pubId, address module)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
| module | address | The address of the Action Module to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the Action Module is enabled for the queried publication, false if not. | 
IModuleRegistry
Functions
registerModule
function registerModule(address moduleAddress, uint256 moduleType) external returns (bool);
getModuleTypes
function getModuleTypes(address moduleAddress) external view returns (uint256);
isModuleRegistered
function isModuleRegistered(address moduleAddress) external view returns (bool);
isModuleRegisteredAs
function isModuleRegisteredAs(address moduleAddress, uint256 moduleType) external view returns (bool);
registerErc20Currency
function registerErc20Currency(address currencyAddress) external returns (bool);
isErc20CurrencyRegistered
function isErc20CurrencyRegistered(address currencyAddress) external view returns (bool);
Enums
ModuleType
enum ModuleType {
    __,
    PUBLICATION_ACTION_MODULE,
    REFERENCE_MODULE,
    FOLLOW_MODULE
}
IPublicationActionModule
Author: Lens Protocol
This is the standard interface for all Lens-compatible Publication Actions. Publication action modules allow users to execute actions directly from a publication, like:
- Minting NFTs.
- Collecting a publication.
- Sending funds to the publication author (e.g. tipping).
- Etc. Referrers are supported, so any publication or profile that references the publication can receive a share from the publication's action if the action module supports it.
Functions
initializePublicationAction
Initializes the action module for the given publication being published with this Action module.
function initializePublicationAction(uint256 profileId, uint256 pubId, address transactionExecutor, bytes calldata data)
    external
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The profile ID of the author publishing the content with this Publication Action. | 
| pubId | uint256 | The publication ID being published. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| data | bytes | Arbitrary data passed from the user to be decoded by the Action Module during initialization. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processPublicationAction
Processes the action for a given publication. This includes the action's logic and any monetary/token operations.
function processPublicationAction(Types.ProcessActionParams calldata processActionParams)
    external
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processActionParams | Types.ProcessActionParams | The parameters needed to execute the publication action. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
IReferenceModule
Author: Lens Protocol
This is the standard interface for all Lens-compatible ReferenceModules. Reference modules allow executing some action when a publication is referenced, like:
- Rewards for mirroring/commenting/quoting a publication.
- Token-gated comments/mirrors/quotes of a publication.
- Etc.
Functions
initializeReferenceModule
Initializes data for the given publication being published with this Reference module.
function initializeReferenceModule(uint256 profileId, uint256 pubId, address transactionExecutor, bytes calldata data)
    external
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| data | bytes | Arbitrary data passed from the user to be decoded by the Reference Module during initialization. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processComment
Processes a comment being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
function processComment(Types.ProcessCommentParams calldata processCommentParams) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCommentParams | Types.ProcessCommentParams | The parameters for processing a comment. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processQuote
Processes a quote being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
function processQuote(Types.ProcessQuoteParams calldata processQuoteParams) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processQuoteParams | Types.ProcessQuoteParams | The parameters for processing a quote. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processMirror
Processes a mirror being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
function processMirror(Types.ProcessMirrorParams calldata processMirrorParams) external returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processMirrorParams | Types.ProcessMirrorParams | The parameters for processing a mirror. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
ITokenHandleRegistry
Author: Lens Protocol
The interface for TokenHandleRegistry contract that is responsible for linking a handle NFT to a token NFT. Linking means a connection between the two NFTs is created, and the handle NFT can be used to resolve the token NFT or vice versa. The registry is responsible for keeping track of the links between the NFTs, and for resolving them. The first version of the registry is hard-coded to support only the .lens namespace and the Lens Protocol Profiles.
Functions
migrationLink
Lens V1 -> V2 migration function. Links a handle NFT to a profile NFT without additional checks to save gas. Will be called by the migration function (in MigrationLib) in LensHub, only for new handles being migrated.
function migrationLink(uint256 handleId, uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
| profileId | uint256 | ID of the Lens Protocol Profile NFT | 
link
Links a handle NFT with a profile NFT. Linking means a connection between the two NFTs is created, and the handle NFT can be used to resolve the profile NFT or vice versa.
*In the first version of the registry, the NFT contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one accepting addresses of the handle and token contracts.*
function link(uint256 handleId, uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
| profileId | uint256 | ID of the Lens Protocol Profile NFT | 
unlink
Unlinks a handle NFT from a profile NFT.
*In the first version of the registry, the contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one accepting addresses of the handle and token contracts.*
function unlink(uint256 handleId, uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
| profileId | uint256 | ID of the Lens Protocol Profile NFT | 
resolve
Resolves a handle NFT to a profile NFT.
*In the first version of the registry, the contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one.*
function resolve(uint256 handleId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | tokenId ID of the Lens Protocol Profile NFT | 
getDefaultHandle
Gets a default handle for a profile NFT (aka reverse resolution).
*In the first version of the registry, the contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one.*
function getDefaultHandle(uint256 tokenId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| tokenId | uint256 | ID of the Lens Protocol Profile NFT | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | handleId ID of the .lens namespace handle NFT | 
Contents
- constants
- token-uris
- ActionLib
- FollowLib
- GovernanceLib
- LegacyCollectLib
- MetaTxLib
- ILegacyFeeFollowModule
- MigrationLib
- ProfileLib
- PublicationLib
- StorageLib
- ValidationLib
Contents
Errors
Errors
CannotInitImplementation
error CannotInitImplementation();
Initialized
error Initialized();
SignatureExpired
error SignatureExpired();
SignatureInvalid
error SignatureInvalid();
InvalidOwner
error InvalidOwner();
NotOwnerOrApproved
error NotOwnerOrApproved();
NotHub
error NotHub();
TokenDoesNotExist
error TokenDoesNotExist();
NotGovernance
error NotGovernance();
NotGovernanceOrEmergencyAdmin
error NotGovernanceOrEmergencyAdmin();
EmergencyAdminCanOnlyPauseFurther
error EmergencyAdminCanOnlyPauseFurther();
NotProfileOwner
error NotProfileOwner();
PublicationDoesNotExist
error PublicationDoesNotExist();
CallerNotFollowNFT
error CallerNotFollowNFT();
CallerNotCollectNFT
error CallerNotCollectNFT();
ArrayMismatch
error ArrayMismatch();
NotWhitelisted
error NotWhitelisted();
NotRegistered
error NotRegistered();
InvalidParameter
error InvalidParameter();
ExecutorInvalid
error ExecutorInvalid();
Blocked
error Blocked();
SelfBlock
error SelfBlock();
NotFollowing
error NotFollowing();
SelfFollow
error SelfFollow();
InvalidReferrer
error InvalidReferrer();
InvalidPointedPub
error InvalidPointedPub();
NonERC721ReceiverImplementer
error NonERC721ReceiverImplementer();
AlreadyEnabled
error AlreadyEnabled();
InitParamsInvalid
error InitParamsInvalid();
ActionNotAllowed
error ActionNotAllowed();
CollectNotAllowed
error CollectNotAllowed();
Paused
error Paused();
PublishingPaused
error PublishingPaused();
GuardianEnabled
error GuardianEnabled();
NotEOA
error NotEOA();
DisablingAlreadyTriggered
error DisablingAlreadyTriggered();
NotMigrationAdmin
error NotMigrationAdmin();
Events
Events
BaseInitialized
Emitted when the NFT contract's name and symbol are set at initialization.
event BaseInitialized(string name, string symbol, uint256 timestamp);
StateSet
Emitted when the hub state is set.
event StateSet(
    address indexed caller,
    Types.ProtocolState indexed prevState,
    Types.ProtocolState indexed newState,
    uint256 timestamp
);
GovernanceSet
Emitted when the governance address is changed. We emit the caller even though it should be the previous governance address, as we cannot guarantee this will always be the case due to upgradeability.
event GovernanceSet(
    address indexed caller, address indexed prevGovernance, address indexed newGovernance, uint256 timestamp
);
EmergencyAdminSet
Emitted when the emergency admin is changed. We emit the caller even though it should be the previous governance address, as we cannot guarantee this will always be the case due to upgradeability.
event EmergencyAdminSet(
    address indexed caller, address indexed oldEmergencyAdmin, address indexed newEmergencyAdmin, uint256 timestamp
);
ProfileCreatorWhitelisted
Emitted when a profile creator is added to or removed from the whitelist.
event ProfileCreatorWhitelisted(address indexed profileCreator, bool indexed whitelisted, uint256 timestamp);
ProfileCreated
Emitted when a profile is created.
event ProfileCreated(uint256 indexed profileId, address indexed creator, address indexed to, uint256 timestamp);
DelegatedExecutorsConfigChanged
Emitted when a delegated executors configuration is changed.
event DelegatedExecutorsConfigChanged(
    uint256 indexed delegatorProfileId,
    uint256 indexed configNumber,
    address[] delegatedExecutors,
    bool[] approvals,
    uint256 timestamp
);
DelegatedExecutorsConfigApplied
Emitted when a delegated executors configuration is applied.
event DelegatedExecutorsConfigApplied(
    uint256 indexed delegatorProfileId, uint256 indexed configNumber, uint256 timestamp
);
FollowModuleSet
Emitted when a profile's follow module is set.
event FollowModuleSet(
    uint256 indexed profileId,
    address followModule,
    bytes followModuleReturnData,
    address transactionExecutor,
    uint256 timestamp
);
PostCreated
Emitted when a post is successfully published.
event PostCreated(
    Types.PostParams postParams,
    uint256 indexed pubId,
    bytes[] actionModulesInitReturnDatas,
    bytes referenceModuleInitReturnData,
    address transactionExecutor,
    uint256 timestamp
);
CommentCreated
Emitted when a comment is successfully published.
event CommentCreated(
    Types.CommentParams commentParams,
    uint256 indexed pubId,
    bytes referenceModuleReturnData,
    bytes[] actionModulesInitReturnDatas,
    bytes referenceModuleInitReturnData,
    address transactionExecutor,
    uint256 timestamp
);
MirrorCreated
Emitted when a mirror is successfully published.
event MirrorCreated(
    Types.MirrorParams mirrorParams,
    uint256 indexed pubId,
    bytes referenceModuleReturnData,
    address transactionExecutor,
    uint256 timestamp
);
QuoteCreated
Emitted when a quote is successfully published.
event QuoteCreated(
    Types.QuoteParams quoteParams,
    uint256 indexed pubId,
    bytes referenceModuleReturnData,
    bytes[] actionModulesInitReturnDatas,
    bytes referenceModuleInitReturnData,
    address transactionExecutor,
    uint256 timestamp
);
FollowNFTDeployed
Emitted when a followNFT clone is deployed using a lazy deployment pattern.
event FollowNFTDeployed(uint256 indexed profileId, address indexed followNFT, uint256 timestamp);
LegacyCollectNFTDeployed
Emitted when a collectNFT clone is deployed using a lazy deployment pattern.
event LegacyCollectNFTDeployed(
    uint256 indexed profileId, uint256 indexed pubId, address indexed collectNFT, uint256 timestamp
);
Acted
Emitted upon a successful action.
event Acted(
    Types.PublicationActionParams publicationActionParams,
    bytes actionModuleReturnData,
    address transactionExecutor,
    uint256 timestamp
);
Followed
Emitted upon a successful follow operation.
event Followed(
    uint256 indexed followerProfileId,
    uint256 idOfProfileFollowed,
    uint256 followTokenIdAssigned,
    bytes followModuleData,
    bytes processFollowModuleReturnData,
    address transactionExecutor,
    uint256 timestamp
);
Unfollowed
Emitted upon a successful unfollow operation.
event Unfollowed(
    uint256 indexed unfollowerProfileId, uint256 idOfProfileUnfollowed, address transactionExecutor, uint256 timestamp
);
Blocked
Emitted upon a successful block, through a block status setting operation.
event Blocked(uint256 indexed byProfileId, uint256 idOfProfileBlocked, address transactionExecutor, uint256 timestamp);
Unblocked
Emitted upon a successful unblock, through a block status setting operation.
event Unblocked(
    uint256 indexed byProfileId, uint256 idOfProfileUnblocked, address transactionExecutor, uint256 timestamp
);
CollectNFTTransferred
Emitted via callback when a collectNFT is transferred.
event CollectNFTTransferred(
    uint256 indexed profileId,
    uint256 indexed pubId,
    uint256 indexed collectNFTId,
    address from,
    address to,
    uint256 timestamp
);
TreasurySet
Emitted when the treasury address is set.
event TreasurySet(address indexed prevTreasury, address indexed newTreasury, uint256 timestamp);
TreasuryFeeSet
Emitted when the treasury fee is set.
event TreasuryFeeSet(uint16 indexed prevTreasuryFee, uint16 indexed newTreasuryFee, uint256 timestamp);
ProfileMetadataSet
Emitted when the metadata associated with a profile is set in the LensPeriphery.
event ProfileMetadataSet(uint256 indexed profileId, string metadata, address transactionExecutor, uint256 timestamp);
TokenGuardianStateChanged
Emitted when an address' Profile Guardian state change is triggered.
event TokenGuardianStateChanged(
    address indexed wallet, bool indexed enabled, uint256 tokenGuardianDisablingTimestamp, uint256 timestamp
);
NonceUpdated
Emitted when a signer's nonce is used and, as a consequence, the next available nonce is updated.
event NonceUpdated(address indexed signer, uint256 nonce, uint256 timestamp);
Typehash
State Variables
ACT
bytes32 constant ACT = keccak256(
    "Act(uint256 publicationActedProfileId,uint256 publicationActedId,uint256 actorProfileId,uint256[] referrerProfileIds,uint256[] referrerPubIds,address actionModuleAddress,bytes actionModuleData,uint256 nonce,uint256 deadline)"
);
CHANGE_DELEGATED_EXECUTORS_CONFIG
bytes32 constant CHANGE_DELEGATED_EXECUTORS_CONFIG = keccak256(
    "ChangeDelegatedExecutorsConfig(uint256 delegatorProfileId,address[] delegatedExecutors,bool[] approvals,uint64 configNumber,bool switchToGivenConfig,uint256 nonce,uint256 deadline)"
);
COLLECT_LEGACY
bytes32 constant COLLECT_LEGACY = keccak256(
    "CollectLegacy(uint256 publicationCollectedProfileId,uint256 publicationCollectedId,uint256 collectorProfileId,uint256 referrerProfileId,uint256 referrerPubId,bytes collectModuleData,uint256 nonce,uint256 deadline)"
);
COMMENT
bytes32 constant COMMENT = keccak256(
    "Comment(uint256 profileId,string contentURI,uint256 pointedProfileId,uint256 pointedPubId,uint256[] referrerProfileIds,uint256[] referrerPubIds,bytes referenceModuleData,address[] actionModules,bytes[] actionModulesInitDatas,address referenceModule,bytes referenceModuleInitData,uint256 nonce,uint256 deadline)"
);
EIP712_DOMAIN
bytes32 constant EIP712_DOMAIN =
    keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)");
FOLLOW
bytes32 constant FOLLOW = keccak256(
    "Follow(uint256 followerProfileId,uint256[] idsOfProfilesToFollow,uint256[] followTokenIds,bytes[] datas,uint256 nonce,uint256 deadline)"
);
MIRROR
bytes32 constant MIRROR = keccak256(
    "Mirror(uint256 profileId,string metadataURI,uint256 pointedProfileId,uint256 pointedPubId,uint256[] referrerProfileIds,uint256[] referrerPubIds,bytes referenceModuleData,uint256 nonce,uint256 deadline)"
);
POST
bytes32 constant POST = keccak256(
    "Post(uint256 profileId,string contentURI,address[] actionModules,bytes[] actionModulesInitDatas,address referenceModule,bytes referenceModuleInitData,uint256 nonce,uint256 deadline)"
);
QUOTE
bytes32 constant QUOTE = keccak256(
    "Quote(uint256 profileId,string contentURI,uint256 pointedProfileId,uint256 pointedPubId,uint256[] referrerProfileIds,uint256[] referrerPubIds,bytes referenceModuleData,address[] actionModules,bytes[] actionModulesInitDatas,address referenceModule,bytes referenceModuleInitData,uint256 nonce,uint256 deadline)"
);
SET_BLOCK_STATUS
bytes32 constant SET_BLOCK_STATUS = keccak256(
    "SetBlockStatus(uint256 byProfileId,uint256[] idsOfProfilesToSetBlockStatus,bool[] blockStatus,uint256 nonce,uint256 deadline)"
);
SET_FOLLOW_MODULE
bytes32 constant SET_FOLLOW_MODULE = keccak256(
    "SetFollowModule(uint256 profileId,address followModule,bytes followModuleInitData,uint256 nonce,uint256 deadline)"
);
SET_PROFILE_METADATA_URI
bytes32 constant SET_PROFILE_METADATA_URI =
    keccak256("SetProfileMetadataURI(uint256 profileId,string metadataURI,uint256 nonce,uint256 deadline)");
UNFOLLOW
bytes32 constant UNFOLLOW =
    keccak256("Unfollow(uint256 unfollowerProfileId,uint256[] idsOfProfilesToUnfollow,uint256 nonce,uint256 deadline)");
Types
Author: Lens Protocol
A standard library of data types used throughout the Lens Protocol.
Structs
TokenData
ERC721Timestamped storage. Contains the owner address and the mint timestamp for every NFT. Note: Instead of the owner address in the _tokenOwners private mapping, we now store it in the _tokenData mapping, alongside the mint timestamp.
struct TokenData {
    address owner;
    uint96 mintTimestamp;
}
FollowData
A struct containing token follow-related data.
struct FollowData {
    uint160 followerProfileId;
    uint48 originalFollowTimestamp;
    uint48 followTimestamp;
    uint256 profileIdAllowedToRecover;
}
EIP712Signature
A struct containing the necessary information to reconstruct an EIP-712 typed data signature.
struct EIP712Signature {
    address signer;
    uint8 v;
    bytes32 r;
    bytes32 s;
    uint256 deadline;
}
Profile
A struct containing profile data.
struct Profile {
    uint256 pubCount;
    address followModule;
    address followNFT;
    string __DEPRECATED__handle;
    string __DEPRECATED__imageURI;
    string __DEPRECATED__followNFTURI;
    string metadataURI;
}
Publication
A struct containing publication data.
struct Publication {
    uint256 pointedProfileId;
    uint256 pointedPubId;
    string contentURI;
    address referenceModule;
    address __DEPRECATED__collectModule;
    address __DEPRECATED__collectNFT;
    PublicationType pubType;
    uint256 rootProfileId;
    uint256 rootPubId;
    mapping(address => bool) actionModuleEnabled;
}
PublicationMemory
struct PublicationMemory {
    uint256 pointedProfileId;
    uint256 pointedPubId;
    string contentURI;
    address referenceModule;
    address __DEPRECATED__collectModule;
    address __DEPRECATED__collectNFT;
    PublicationType pubType;
    uint256 rootProfileId;
    uint256 rootPubId;
}
CreateProfileParams
A struct containing the parameters required for the createProfile() function.
struct CreateProfileParams {
    address to;
    address followModule;
    bytes followModuleInitData;
}
PostParams
A struct containing the parameters required for the post() function.
struct PostParams {
    uint256 profileId;
    string contentURI;
    address[] actionModules;
    bytes[] actionModulesInitDatas;
    address referenceModule;
    bytes referenceModuleInitData;
}
CommentParams
A struct containing the parameters required for the comment() function.
struct CommentParams {
    uint256 profileId;
    string contentURI;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    bytes referenceModuleData;
    address[] actionModules;
    bytes[] actionModulesInitDatas;
    address referenceModule;
    bytes referenceModuleInitData;
}
QuoteParams
A struct containing the parameters required for the quote() function.
struct QuoteParams {
    uint256 profileId;
    string contentURI;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    bytes referenceModuleData;
    address[] actionModules;
    bytes[] actionModulesInitDatas;
    address referenceModule;
    bytes referenceModuleInitData;
}
ReferencePubParams
A struct containing the parameters required for the comment() or quote() internal functions.
struct ReferencePubParams {
    uint256 profileId;
    string contentURI;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    bytes referenceModuleData;
    address[] actionModules;
    bytes[] actionModulesInitDatas;
    address referenceModule;
    bytes referenceModuleInitData;
}
MirrorParams
A struct containing the parameters required for the mirror() function.
struct MirrorParams {
    uint256 profileId;
    string metadataURI;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    bytes referenceModuleData;
}
LegacyCollectParams
Deprecated in V2: Will be removed after some time after upgrading to V2.
A struct containing the parameters required for the legacy collect() function.
The referrer can only be a mirror of the publication being collected.
struct LegacyCollectParams {
    uint256 publicationCollectedProfileId;
    uint256 publicationCollectedId;
    uint256 collectorProfileId;
    uint256 referrerProfileId;
    uint256 referrerPubId;
    bytes collectModuleData;
}
PublicationActionParams
A struct containing the parameters required for the action() function.
struct PublicationActionParams {
    uint256 publicationActedProfileId;
    uint256 publicationActedId;
    uint256 actorProfileId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    address actionModuleAddress;
    bytes actionModuleData;
}
ProcessActionParams
struct ProcessActionParams {
    uint256 publicationActedProfileId;
    uint256 publicationActedId;
    uint256 actorProfileId;
    address actorProfileOwner;
    address transactionExecutor;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    Types.PublicationType[] referrerPubTypes;
    bytes actionModuleData;
}
ProcessCollectParams
struct ProcessCollectParams {
    uint256 publicationCollectedProfileId;
    uint256 publicationCollectedId;
    uint256 collectorProfileId;
    address collectorProfileOwner;
    address transactionExecutor;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    Types.PublicationType[] referrerPubTypes;
    bytes data;
}
ProcessCommentParams
struct ProcessCommentParams {
    uint256 profileId;
    address transactionExecutor;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    Types.PublicationType[] referrerPubTypes;
    bytes data;
}
ProcessQuoteParams
struct ProcessQuoteParams {
    uint256 profileId;
    address transactionExecutor;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    Types.PublicationType[] referrerPubTypes;
    bytes data;
}
ProcessMirrorParams
struct ProcessMirrorParams {
    uint256 profileId;
    address transactionExecutor;
    uint256 pointedProfileId;
    uint256 pointedPubId;
    uint256[] referrerProfileIds;
    uint256[] referrerPubIds;
    Types.PublicationType[] referrerPubTypes;
    bytes data;
}
DelegatedExecutorsConfig
A struct containing a profile's delegated executors configuration.
struct DelegatedExecutorsConfig {
    mapping(uint256 => mapping(address => bool)) isApproved;
    uint64 configNumber;
    uint64 prevConfigNumber;
    uint64 maxConfigNumberSet;
}
TreasuryData
struct TreasuryData {
    address treasury;
    uint16 treasuryFeeBPS;
}
MigrationParams
struct MigrationParams {
    address lensHandlesAddress;
    address tokenHandleRegistryAddress;
    address legacyFeeFollowModule;
    address legacyProfileFollowModule;
    address newFeeFollowModule;
    address migrationAdmin;
}
Enums
ProtocolState
An enum containing the different states the protocol can be in, limiting certain actions.
enum ProtocolState {
    Unpaused,
    PublishingPaused,
    Paused
}
PublicationType
An enum specifically used in a helper function to easily retrieve the publication type for integrations.
enum PublicationType {
    Nonexistent,
    Post,
    Comment,
    Mirror,
    Quote
}
Contents
FollowTokenURILib
Functions
getTokenURI
function getTokenURI(uint256 followTokenId, uint256 followedProfileId, uint256 originalFollowTimestamp)
    external
    pure
    returns (string memory);
_getSVGImageBase64Encoded
function _getSVGImageBase64Encoded(string memory followTokenIdAsString, string memory followedProfileIdAsString)
    private
    pure
    returns (string memory);
HandleTokenURILib
Functions
getTokenURI
function getTokenURI(uint256 tokenId, string memory localName) external pure returns (string memory);
_getSVGImageBase64Encoded
function _getSVGImageBase64Encoded(string memory localName) private pure returns (string memory);
_localNameLengthToFontSize
Maps the local name length to a font size.
Gives the font size as a function of the local name length. This dynamic font size mapping ensures all handle token URIs will look nice when rendered as image.
function _localNameLengthToFontSize(uint256 localNameLength) internal pure returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| localNameLength | uint256 | The handle's local name length. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The font size. | 
ProfileTokenURILib
Functions
getTokenURI
function getTokenURI(uint256 profileId) external view returns (string memory);
_getSVGImageBase64Encoded
function _getSVGImageBase64Encoded(string memory profileIdAsString) private pure returns (string memory);
TokenURIMainFontLib
Functions
getFontName
function getFontName() internal pure returns (string memory);
getFontBase64Encoded
function getFontBase64Encoded() external pure returns (string memory);
TokenURISecondaryFontLib
Functions
getFontName
function getFontName() internal pure returns (string memory);
getFontBase64Encoded
function getFontBase64Encoded() external pure returns (string memory);
ActionLib
Functions
act
function act(
    Types.PublicationActionParams calldata publicationActionParams,
    address transactionExecutor,
    address actorProfileOwner
) external returns (bytes memory);
_isActionEnabled
function _isActionEnabled(Types.Publication storage _publication, address actionModuleAddress)
    private
    view
    returns (bool);
FollowLib
Functions
follow
function follow(
    uint256 followerProfileId,
    address transactionExecutor,
    uint256[] calldata idsOfProfilesToFollow,
    uint256[] calldata followTokenIds,
    bytes[] calldata followModuleDatas
) external returns (uint256[] memory);
unfollow
function unfollow(uint256 unfollowerProfileId, address transactionExecutor, uint256[] calldata idsOfProfilesToUnfollow)
    external;
_deployFollowNFT
Deploys the given profile's Follow NFT contract.
function _deployFollowNFT(uint256 profileId) private returns (address);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile which Follow NFT should be deployed. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address of the deployed Follow NFT contract. | 
_follow
function _follow(
    uint256 followerProfileId,
    address transactionExecutor,
    uint256 idOfProfileToFollow,
    uint256 followTokenId,
    bytes calldata followModuleData
) private returns (uint256);
_processFollow
function _processFollow(ProcessFollowParams memory processFollowParams) private returns (uint256);
Structs
ProcessFollowParams
struct ProcessFollowParams {
    address followNFT;
    uint256 followerProfileId;
    address transactionExecutor;
    uint256 idOfProfileToFollow;
    uint256 followTokenId;
    address followModule;
    bytes followModuleData;
}
GovernanceLib
State Variables
BPS_MAX
uint16 internal constant BPS_MAX = 10000;
Functions
setGovernance
Sets the governance address.
function setGovernance(address newGovernance) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newGovernance | address | The new governance address to set. | 
setEmergencyAdmin
Sets the emergency admin address.
function setEmergencyAdmin(address newEmergencyAdmin) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newEmergencyAdmin | address | The new governance address to set. | 
initState
Sets the protocol state, only meant to be called at initialization since this does not validate the caller.
function initState(Types.ProtocolState newState) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newState | Types.ProtocolState | The new protocol state to set. | 
setState
Sets the protocol state and validates the caller. The emergency admin can only pause further (Unpaused => PublishingPaused => Paused). Whereas governance can set any state.
function setState(Types.ProtocolState newState) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newState | Types.ProtocolState | The new protocol state to set. | 
_setState
function _setState(Types.ProtocolState newState) private returns (Types.ProtocolState);
whitelistProfileCreator
function whitelistProfileCreator(address profileCreator, bool whitelist) external;
setTreasury
function setTreasury(address newTreasury) internal;
setTreasuryFee
function setTreasuryFee(uint16 newTreasuryFee) internal;
LegacyCollectLib
Author: Lens Protocol
Library containing the logic for legacy collect operation.
Functions
collect
function collect(
    Types.LegacyCollectParams calldata collectParams,
    address transactionExecutor,
    address collectorProfileOwner,
    address collectNFTImpl
) external returns (uint256);
_getOrDeployCollectNFT
function _getOrDeployCollectNFT(
    Types.Publication storage _collectedPublication,
    uint256 publicationCollectedProfileId,
    uint256 publicationCollectedId,
    address collectNFTImpl
) private returns (address);
_deployCollectNFT
Deploys the given profile's Collect NFT contract.
function _deployCollectNFT(uint256 profileId, uint256 pubId, address collectNFTImpl) private returns (address);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile which Collect NFT should be deployed. | 
| pubId | uint256 | The publication ID of the publication being collected, which Collect NFT should be deployed. | 
| collectNFTImpl | address | The address of the Collect NFT implementation that should be used for the deployment. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | address | address The address of the deployed Collect NFT contract. | 
Events
CollectedLegacy
Emitted upon a successful legacy collect action.
event CollectedLegacy(
    uint256 indexed publicationCollectedProfileId,
    uint256 indexed publicationCollectedId,
    address transactionExecutor,
    uint256 referrerProfileId,
    uint256 referrerPubId,
    bytes collectModuleData,
    uint256 timestamp
);
MetaTxLib
Author: Lens Protocol NOTE: the functions in this contract operate under the assumption that the passed signer is already validated to either be the originator or one of their delegated executors.
User nonces are incremented from this library as well.
State Variables
EIP712_DOMAIN_VERSION
string constant EIP712_DOMAIN_VERSION = "2";
EIP712_DOMAIN_VERSION_HASH
bytes32 constant EIP712_DOMAIN_VERSION_HASH = keccak256(bytes(EIP712_DOMAIN_VERSION));
EIP1271_MAGIC_VALUE
bytes4 constant EIP1271_MAGIC_VALUE = 0x1626ba7e;
LENS_HUB_CACHED_POLYGON_DOMAIN_SEPARATOR
We store the domain separator and LensHub Proxy address as constants to save gas. keccak256( abi.encode( keccak256('EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)'), keccak256('Lens Protocol Profiles'), // Contract Name keccak256('2'), // Version Hash 137, // Polygon Chain ID address(0xDb46d1Dc155634FbC732f92E853b10B288AD5a1d) // Verifying Contract Address - LensHub Address ) );
bytes32 constant LENS_HUB_CACHED_POLYGON_DOMAIN_SEPARATOR =
    0xbf9544cf7d7a0338fc4f071be35409a61e51e9caef559305410ad74e16a05f2d;
LENS_HUB_ADDRESS
address constant LENS_HUB_ADDRESS = 0xDb46d1Dc155634FbC732f92E853b10B288AD5a1d;
POLYGON_CHAIN_ID
uint256 constant POLYGON_CHAIN_ID = 137;
Functions
validateSetProfileMetadataURISignature
function validateSetProfileMetadataURISignature(
    Types.EIP712Signature calldata signature,
    uint256 profileId,
    string calldata metadataURI
) external;
validateSetFollowModuleSignature
function validateSetFollowModuleSignature(
    Types.EIP712Signature calldata signature,
    uint256 profileId,
    address followModule,
    bytes calldata followModuleInitData
) external;
validateChangeDelegatedExecutorsConfigSignature
function validateChangeDelegatedExecutorsConfigSignature(
    Types.EIP712Signature calldata signature,
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals,
    uint64 configNumber,
    bool switchToGivenConfig
) external;
validatePostSignature
function validatePostSignature(Types.EIP712Signature calldata signature, Types.PostParams calldata postParams)
    external;
validateCommentSignature
function validateCommentSignature(Types.EIP712Signature calldata signature, Types.CommentParams calldata commentParams)
    external;
validateQuoteSignature
function validateQuoteSignature(Types.EIP712Signature calldata signature, Types.QuoteParams calldata quoteParams)
    external;
validateMirrorSignature
function validateMirrorSignature(Types.EIP712Signature calldata signature, Types.MirrorParams calldata mirrorParams)
    external;
validateFollowSignature
function validateFollowSignature(
    Types.EIP712Signature calldata signature,
    uint256 followerProfileId,
    uint256[] calldata idsOfProfilesToFollow,
    uint256[] calldata followTokenIds,
    bytes[] calldata datas
) external;
validateUnfollowSignature
function validateUnfollowSignature(
    Types.EIP712Signature calldata signature,
    uint256 unfollowerProfileId,
    uint256[] calldata idsOfProfilesToUnfollow
) external;
validateSetBlockStatusSignature
function validateSetBlockStatusSignature(
    Types.EIP712Signature calldata signature,
    uint256 byProfileId,
    uint256[] calldata idsOfProfilesToSetBlockStatus,
    bool[] calldata blockStatus
) external;
validateLegacyCollectSignature
function validateLegacyCollectSignature(
    Types.EIP712Signature calldata signature,
    Types.LegacyCollectParams calldata collectParams
) external;
validateActSignature
function validateActSignature(
    Types.EIP712Signature calldata signature,
    Types.PublicationActionParams calldata publicationActionParams
) external;
calculateDomainSeparator
function calculateDomainSeparator() internal view returns (bytes32);
_validateRecoveredAddress
Wrapper for ecrecover to reduce code size, used in meta-tx specific functions.
function _validateRecoveredAddress(bytes32 digest, Types.EIP712Signature calldata signature) private view;
_calculateDigest
Calculates EIP712 digest based on the current DOMAIN_SEPARATOR.
function _calculateDigest(bytes32 hashedMessage) private view returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| hashedMessage | bytes32 | The message hash from which the digest should be calculated. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | bytes32 A 32-byte output representing the EIP712 digest. | 
_getNonceIncrementAndEmitEvent
This fetches a signer's current nonce and increments it so it's ready for the next meta-tx. Also emits
the NonceUpdated event.
function _getNonceIncrementAndEmitEvent(address signer) private returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| signer | address | The address to get and increment the nonce for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The current nonce for the given signer prior to being incremented. | 
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(bytes[] memory bytesArray) private pure returns (bytes32);
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(bool[] memory boolArray) private pure returns (bytes32);
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(address[] memory addressArray) private pure returns (bytes32);
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(uint256[] memory uint256Array) private pure returns (bytes32);
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(bytes32[] memory bytes32Array) private pure returns (bytes32);
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(string memory stringValue) private pure returns (bytes32);
_encodeUsingEip712Rules
function _encodeUsingEip712Rules(bytes memory bytesValue) private pure returns (bytes32);
ILegacyFeeFollowModule
Functions
getProfileData
function getProfileData(uint256 profileId) external view returns (ProfileData memory);
Structs
ProfileData
struct ProfileData {
    address currency;
    uint256 amount;
    address recipient;
}
MigrationLib
State Variables
LENS_PROTOCOL_PROFILE_ID
uint256 internal constant LENS_PROTOCOL_PROFILE_ID = 1;
DOT_LENS_SUFFIX_LENGTH
uint256 internal constant DOT_LENS_SUFFIX_LENGTH = 5;
Functions
batchMigrateProfiles
Migrates an array of profiles from V1 to V2. This function can be callable by anyone. We would still perform the migration in batches by ourselves, but good to allow users to migrate on their own if they want to.
function batchMigrateProfiles(
    uint256[] calldata profileIds,
    LensHandles lensHandles,
    TokenHandleRegistry tokenHandleRegistry
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileIds | uint256[] | The array of profile IDs to migrate. | 
| lensHandles | LensHandles | |
| tokenHandleRegistry | TokenHandleRegistry | 
_migrateProfile
Migrates a profile from V1 to V2.
We do not revert in any case, as we want to allow the migration to continue even if one profile fails (and it usually fails if already migrated or profileNFT moved).
Estimated gas cost of one profile migration is around 178k gas.
function _migrateProfile(uint256 profileId, LensHandles lensHandles, TokenHandleRegistry tokenHandleRegistry) private;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The profile ID to migrate. | 
| lensHandles | LensHandles | |
| tokenHandleRegistry | TokenHandleRegistry | 
batchMigrateFollows
function batchMigrateFollows(
    uint256 followerProfileIds,
    uint256[] calldata idsOfProfileFollowed,
    uint256[] calldata followTokenIds
) external;
batchMigrateFollowers
function batchMigrateFollowers(
    uint256[] calldata followerProfileIds,
    uint256 idOfProfileFollowed,
    uint256[] calldata followTokenIds
) external;
_migrateFollow
function _migrateFollow(
    address followNFT,
    uint256 followerProfileId,
    uint256 idOfProfileFollowed,
    uint256 followTokenId
) private;
batchMigrateFollowModules
function batchMigrateFollowModules(
    uint256[] calldata profileIds,
    address legacyFeeFollowModule,
    address legacyProfileFollowModule,
    address newFeeFollowModule
) external;
Events
ProfileMigrated
event ProfileMigrated(uint256 profileId, address profileDestination, string handle, uint256 handleId);
ProfileLib
Functions
MODULE_REGISTRY
function MODULE_REGISTRY() internal view returns (IModuleRegistry);
ownerOf
function ownerOf(uint256 profileId) internal view returns (address);
exists
function exists(uint256 profileId) internal view returns (bool);
createProfile
Creates a profile with the given parameters to the given address. Minting happens in the hub.
function createProfile(Types.CreateProfileParams calldata createProfileParams, uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| createProfileParams | Types.CreateProfileParams | The CreateProfileParams struct containing the following parameters: to: The address receiving the profile. followModule: The follow module to use, can be the zero address. followModuleInitData: The follow module initialization data, if any | 
| profileId | uint256 | The profile ID to associate with this profile NFT (token ID). | 
setFollowModule
Sets the follow module for a given profile.
function setFollowModule(
    uint256 profileId,
    address followModule,
    bytes calldata followModuleInitData,
    address transactionExecutor
) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The profile ID to set the follow module for. | 
| followModule | address | The follow module to set for the given profile, if any. | 
| followModuleInitData | bytes | The data to pass to the follow module for profile initialization. | 
| transactionExecutor | address | 
setProfileMetadataURI
function setProfileMetadataURI(uint256 profileId, string calldata metadataURI, address transactionExecutor) external;
_initFollowModule
function _initFollowModule(
    uint256 profileId,
    address transactionExecutor,
    address followModule,
    bytes memory followModuleInitData
) private returns (bytes memory);
setBlockStatus
function setBlockStatus(
    uint256 byProfileId,
    uint256[] calldata idsOfProfilesToSetBlockStatus,
    bool[] calldata blockStatus,
    address transactionExecutor
) external;
switchToNewFreshDelegatedExecutorsConfig
function switchToNewFreshDelegatedExecutorsConfig(uint256 profileId) external;
changeDelegatedExecutorsConfig
function changeDelegatedExecutorsConfig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals
) external;
changeGivenDelegatedExecutorsConfig
function changeGivenDelegatedExecutorsConfig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals,
    uint64 configNumber,
    bool switchToGivenConfig
) external;
isExecutorApproved
function isExecutorApproved(uint256 delegatorProfileId, address delegatedExecutor) external view returns (bool);
_changeDelegatedExecutorsConfig
function _changeDelegatedExecutorsConfig(
    Types.DelegatedExecutorsConfig storage _delegatedExecutorsConfig,
    uint256 delegatorProfileId,
    address[] memory delegatedExecutors,
    bool[] memory approvals,
    uint64 configNumber,
    bool switchToGivenConfig
) private;
_prepareStorageToApplyChangesUnderGivenConfig
function _prepareStorageToApplyChangesUnderGivenConfig(
    Types.DelegatedExecutorsConfig storage _delegatedExecutorsConfig,
    uint64 configNumber,
    bool switchToGivenConfig
) private returns (bool);
_setFollowModule
function _setFollowModule(
    uint256 profileId,
    address followModule,
    bytes calldata followModuleInitData,
    address transactionExecutor
) private;
PublicationLib
Functions
MODULE_REGISTRY
function MODULE_REGISTRY() internal view returns (IModuleRegistry);
post
Publishes a post to a given profile.
function post(Types.PostParams calldata postParams, address transactionExecutor) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| postParams | Types.PostParams | The PostParams struct. | 
| transactionExecutor | address | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The created publication's pubId. | 
comment
Publishes a comment to a given profile via signature.
function comment(Types.CommentParams calldata commentParams, address transactionExecutor) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| commentParams | Types.CommentParams | the CommentParams struct. | 
| transactionExecutor | address | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The created publication's pubId. | 
mirror
Publishes a mirror to a given profile.
function mirror(Types.MirrorParams calldata mirrorParams, address transactionExecutor) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| mirrorParams | Types.MirrorParams | the MirrorParams struct. | 
| transactionExecutor | address | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The created publication's pubId. | 
quote
Publishes a quote publication to a given profile via signature.
function quote(Types.QuoteParams calldata quoteParams, address transactionExecutor) external returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| quoteParams | Types.QuoteParams | the QuoteParams struct. | 
| transactionExecutor | address | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The created publication's pubId. | 
getPublicationType
function getPublicationType(uint256 profileId, uint256 pubId) internal view returns (Types.PublicationType);
getContentURI
function getContentURI(uint256 profileId, uint256 pubId) external view returns (string memory);
_asReferencePubParams
function _asReferencePubParams(Types.QuoteParams calldata quoteParams)
    private
    pure
    returns (Types.ReferencePubParams calldata referencePubParams);
_asReferencePubParams
function _asReferencePubParams(Types.CommentParams calldata commentParams)
    private
    pure
    returns (Types.ReferencePubParams calldata referencePubParams);
_createReferencePublication
function _createReferencePublication(
    Types.ReferencePubParams calldata referencePubParams,
    address transactionExecutor,
    Types.PublicationType referencePubType
) private returns (uint256, bytes[] memory, bytes memory, Types.PublicationType[] memory);
_fillReferencePublicationStorage
function _fillReferencePublicationStorage(
    Types.ReferencePubParams calldata referencePubParams,
    Types.PublicationType referencePubType
) private returns (uint256, uint256);
_fillRootOfPublicationInStorage
function _fillRootOfPublicationInStorage(
    Types.Publication storage _publication,
    uint256 pointedProfileId,
    uint256 pointedPubId
) internal returns (uint256);
_processCommentIfNeeded
function _processCommentIfNeeded(
    Types.CommentParams calldata commentParams,
    address transactionExecutor,
    Types.PublicationType[] memory referrerPubTypes
) private returns (bytes memory);
_processQuoteIfNeeded
Equivalent to reverting with the returned error selector if the length is not zero.
function _processQuoteIfNeeded(
    Types.QuoteParams calldata quoteParams,
    address transactionExecutor,
    Types.PublicationType[] memory referrerPubTypes
) private returns (bytes memory);
_processMirrorIfNeeded
Equivalent to reverting with the returned error selector if the length is not zero.
function _processMirrorIfNeeded(
    Types.MirrorParams calldata mirrorParams,
    address transactionExecutor,
    Types.PublicationType[] memory referrerPubTypes
) private returns (bytes memory);
_initPubActionModules
function _initPubActionModules(InitActionModuleParams memory params) private returns (bytes[] memory);
_initPubReferenceModule
function _initPubReferenceModule(InitReferenceModuleParams memory params) private returns (bytes memory);
Structs
InitActionModuleParams
Equivalent to reverting with the returned error selector if the length is not zero.
struct InitActionModuleParams {
    uint256 profileId;
    address transactionExecutor;
    uint256 pubId;
    address[] actionModules;
    bytes[] actionModulesInitDatas;
}
InitReferenceModuleParams
struct InitReferenceModuleParams {
    uint256 profileId;
    address transactionExecutor;
    uint256 pubId;
    address referenceModule;
    bytes referenceModuleInitData;
}
StorageLib
State Variables
TOKEN_DATA_MAPPING_SLOT
uint256 constant TOKEN_DATA_MAPPING_SLOT = 2;
SIG_NONCES_MAPPING_SLOT
uint256 constant SIG_NONCES_MAPPING_SLOT = 10;
LAST_INITIALIZED_REVISION_SLOT
uint256 constant LAST_INITIALIZED_REVISION_SLOT = 11;
PROTOCOL_STATE_SLOT
uint256 constant PROTOCOL_STATE_SLOT = 12;
PROFILE_CREATOR_WHITELIST_MAPPING_SLOT
uint256 constant PROFILE_CREATOR_WHITELIST_MAPPING_SLOT = 13;
PROFILE_ID_BY_HANDLE_HASH_MAPPING_SLOT
uint256 constant PROFILE_ID_BY_HANDLE_HASH_MAPPING_SLOT = 18;
PROFILES_MAPPING_SLOT
uint256 constant PROFILES_MAPPING_SLOT = 19;
PUBLICATIONS_MAPPING_SLOT
uint256 constant PUBLICATIONS_MAPPING_SLOT = 20;
PROFILE_COUNTER_SLOT
uint256 constant PROFILE_COUNTER_SLOT = 22;
GOVERNANCE_SLOT
uint256 constant GOVERNANCE_SLOT = 23;
EMERGENCY_ADMIN_SLOT
uint256 constant EMERGENCY_ADMIN_SLOT = 24;
TOKEN_GUARDIAN_DISABLING_TIMESTAMP_MAPPING_SLOT
Introduced in Lens V1.3: ///
uint256 constant TOKEN_GUARDIAN_DISABLING_TIMESTAMP_MAPPING_SLOT = 25;
DELEGATED_EXECUTOR_CONFIG_MAPPING_SLOT
Introduced in Lens V2: ///
uint256 constant DELEGATED_EXECUTOR_CONFIG_MAPPING_SLOT = 26;
BLOCKED_STATUS_MAPPING_SLOT
uint256 constant BLOCKED_STATUS_MAPPING_SLOT = 27;
PROFILE_ROYALTIES_BPS_SLOT
uint256 constant PROFILE_ROYALTIES_BPS_SLOT = 28;
MIGRATION_ADMINS_WHITELISTED_MAPPING_SLOT
uint256 constant MIGRATION_ADMINS_WHITELISTED_MAPPING_SLOT = 29;
TREASURY_DATA_SLOT
uint256 constant TREASURY_DATA_SLOT = 30;
Functions
getPublication
function getPublication(uint256 profileId, uint256 pubId)
    internal
    pure
    returns (Types.Publication storage _publication);
getPublicationMemory
function getPublicationMemory(uint256 profileId, uint256 pubId)
    internal
    pure
    returns (Types.PublicationMemory memory);
getProfile
function getProfile(uint256 profileId) internal pure returns (Types.Profile storage _profiles);
getDelegatedExecutorsConfig
function getDelegatedExecutorsConfig(uint256 delegatorProfileId)
    internal
    pure
    returns (Types.DelegatedExecutorsConfig storage _delegatedExecutorsConfig);
tokenGuardianDisablingTimestamp
function tokenGuardianDisablingTimestamp()
    internal
    pure
    returns (mapping(address => uint256) storage _tokenGuardianDisablingTimestamp);
getTokenData
function getTokenData(uint256 tokenId) internal pure returns (Types.TokenData storage _tokenData);
blockedStatus
function blockedStatus(uint256 blockerProfileId)
    internal
    pure
    returns (mapping(uint256 => bool) storage _blockedStatus);
nonces
function nonces() internal pure returns (mapping(address => uint256) storage _nonces);
profileIdByHandleHash
function profileIdByHandleHash() internal pure returns (mapping(bytes32 => uint256) storage _profileIdByHandleHash);
profileCreatorWhitelisted
function profileCreatorWhitelisted()
    internal
    pure
    returns (mapping(address => bool) storage _profileCreatorWhitelisted);
migrationAdminWhitelisted
function migrationAdminWhitelisted()
    internal
    pure
    returns (mapping(address => bool) storage _migrationAdminWhitelisted);
getGovernance
function getGovernance() internal view returns (address _governance);
setGovernance
function setGovernance(address newGovernance) internal;
getEmergencyAdmin
function getEmergencyAdmin() internal view returns (address _emergencyAdmin);
setEmergencyAdmin
function setEmergencyAdmin(address newEmergencyAdmin) internal;
getState
function getState() internal view returns (Types.ProtocolState _state);
setState
function setState(Types.ProtocolState newState) internal;
getLastInitializedRevision
function getLastInitializedRevision() internal view returns (uint256 _lastInitializedRevision);
setLastInitializedRevision
function setLastInitializedRevision(uint256 newLastInitializedRevision) internal;
getTreasuryData
function getTreasuryData() internal pure returns (Types.TreasuryData storage _treasuryData);
ValidationLib
Author: Lens Protocol
Functions
validatePointedPub
function validatePointedPub(uint256 profileId, uint256 pubId) internal view;
validateAddressIsProfileOwner
function validateAddressIsProfileOwner(address expectedProfileOwner, uint256 profileId) internal view;
validateAddressIsProfileOwnerOrDelegatedExecutor
function validateAddressIsProfileOwnerOrDelegatedExecutor(address expectedOwnerOrDelegatedExecutor, uint256 profileId)
    internal
    view;
validateAddressIsDelegatedExecutor
function validateAddressIsDelegatedExecutor(address expectedDelegatedExecutor, uint256 delegatorProfileId)
    internal
    view;
validateProfileCreatorWhitelisted
function validateProfileCreatorWhitelisted(address profileCreator) internal view;
validateNotBlocked
function validateNotBlocked(uint256 profile, uint256 byProfile) internal view;
validateNotBlocked
function validateNotBlocked(uint256 profile, uint256 byProfile, bool unidirectionalCheck) internal view;
validateProfileExists
function validateProfileExists(uint256 profileId) internal view;
validateCallerIsGovernance
function validateCallerIsGovernance() internal view;
validateReferrersAndGetReferrersPubTypes
function validateReferrersAndGetReferrersPubTypes(
    uint256[] memory referrerProfileIds,
    uint256[] memory referrerPubIds,
    uint256 targetedProfileId,
    uint256 targetedPubId
) internal view returns (Types.PublicationType[] memory);
validateLegacyCollectReferrer
function validateLegacyCollectReferrer(
    uint256 referrerProfileId,
    uint256 referrerPubId,
    uint256 publicationCollectedProfileId,
    uint256 publicationCollectedId
) external view;
_validateReferrerAndGetReferrerPubType
function _validateReferrerAndGetReferrerPubType(
    uint256 referrerProfileId,
    uint256 referrerPubId,
    uint256 targetedProfileId,
    uint256 targetedPubId
) private view returns (Types.PublicationType);
_validateReferrerAsPost
function _validateReferrerAsPost(
    uint256 referrerProfileId,
    uint256 referrerPubId,
    uint256 targetedProfileId,
    uint256 targetedPubId
) private view;
_validateReferrerAsMirrorOrCommentOrQuote
Validates that the referrer publication and the interacted publication are linked.
function _validateReferrerAsMirrorOrCommentOrQuote(
    uint256 referrerProfileId,
    uint256 referrerPubId,
    uint256 targetedProfileId,
    uint256 targetedPubId
) private view;
Parameters
| Name | Type | Description | 
|---|---|---|
| referrerProfileId | uint256 | The profile id of the referrer. | 
| referrerPubId | uint256 | The publication id of the referrer. | 
| targetedProfileId | uint256 | The ID of the profile who authored the publication being acted or referenced. | 
| targetedPubId | uint256 | The pub ID being acted or referenced. | 
Contents
- access
- ImmutableOwnable
- LegacyCollectNFT
- LensHubInitializable
- LensV2Migration
- LensV2UpgradeContract
- ModuleRegistry
- ProfileCreationProxy
Contents
ControllableByContract
Inherits: Ownable
State Variables
controllerContract
address public controllerContract;
Functions
onlyOwnerOrControllerContract
modifier onlyOwnerOrControllerContract();
constructor
constructor(address owner) Ownable;
clearControllerContract
function clearControllerContract() external onlyOwnerOrControllerContract;
setControllerContract
function setControllerContract(address newControllerContract) external onlyOwner;
Events
ControllerContractUpdated
event ControllerContractUpdated(address previousControllerContract, address newControllerContract);
Errors
Unauthorized
error Unauthorized();
Governance
Inherits: ControllableByContract
State Variables
LENS_HUB
ILensHub public immutable LENS_HUB;
Functions
constructor
constructor(address lensHubAddress_, address governanceOwner_) ControllableByContract(governanceOwner_);
lensHub_setGovernance
ONLY GOVERNANCE OWNER ///
function lensHub_setGovernance(address newGovernance) external onlyOwner;
lensHub_setEmergencyAdmin
function lensHub_setEmergencyAdmin(address newEmergencyAdmin) external onlyOwner;
lensHub_whitelistProfileCreator
ONLY GOVERNANCE OWNER OR CONTROLLER CONTRACT ///
function lensHub_whitelistProfileCreator(address profileCreator, bool whitelist)
    external
    onlyOwnerOrControllerContract;
executeAsGovernance
function executeAsGovernance(address target, bytes calldata data)
    external
    payable
    onlyOwnerOrControllerContract
    returns (bytes memory);
LitAccessControl
Author: Lens Protocol
This contract enables additional access control for encrypted publications on Lens by reporting whether an address owns or has control over a given profile.
State Variables
LENS_HUB
address internal immutable LENS_HUB;
COLLECT_PUB_ACTION
address internal immutable COLLECT_PUB_ACTION;
Functions
constructor
constructor(address lensHub, address collectPubAction);
hasAccess
Function used to check whether an address is the Owner or Delegated Executor of a profile.
function hasAccess(address requestorAddress, uint256 profileId, bytes memory) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| requestorAddress | address | The address to check ownership over a profile. | 
| profileId | uint256 | The ID of the profile being checked for ownership. param data Optional data parameter, which may be used in future upgrades. | 
| <none> | bytes | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | Boolean indicating whether address owns the profile or not. | 
isFollowing
Function used to check whether followerProfileId is following profileId and requestor is Owner/Delegated Executor of followerProfileId.
function isFollowing(address requestorAddress, uint256 profileId, uint256 followerProfileId, bytes memory)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| requestorAddress | address | The address to check ownership over a profile. | 
| profileId | uint256 | The ID of the profile being followed. | 
| followerProfileId | uint256 | The ID of the following profile. param data Optional data parameter, which may be used in future upgrades. | 
| <none> | bytes | 
hasCollected
Function used to check whether an address owns or has collected the publication.
function hasCollected(
    address requestorAddress,
    uint256 publisherId,
    uint256 pubId,
    uint256 collectorProfileId,
    bytes memory
) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| requestorAddress | address | The address to check if it owns the collect NFT of the publication. | 
| publisherId | uint256 | ID of the profile who is the publisher of the publication. | 
| pubId | uint256 | ID of the publication. | 
| collectorProfileId | uint256 | ID of the collector profile (optional, will check if the profile owner owns the NFT) param data Optional data parameter, which may be used in future upgrades. | 
| <none> | bytes | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | Boolean indicating whether address owns the collect NFT of the publication or not. | 
_isOwnerOrDelegatedExecutor
Internal function used to check whether an address is the Owner or DelegatedExecutor of a profile.
function _isOwnerOrDelegatedExecutor(address requestorAddress, uint256 profileId) internal view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| requestorAddress | address | The address to check ownership over a profile. | 
| profileId | uint256 | The ID of the profile being checked for ownership. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | Boolean indicating whether address owns the profile or is DelegatedExecutor of it. | 
ProxyAdmin
Inherits: ControllableByContract
State Variables
LENS_HUB_PROXY
TransparentUpgradeableProxy public immutable LENS_HUB_PROXY;
previousImplementation
address public previousImplementation;
Functions
constructor
constructor(address lensHubAddress_, address previousImplementation_, address proxyAdminOwner_)
    ControllableByContract(proxyAdminOwner_);
currentImplementation
function currentImplementation() external returns (address);
rollbackLastUpgrade
ONLY PROXY ADMIN OWNER ///
function rollbackLastUpgrade() external onlyOwner;
proxy_changeAdmin
function proxy_changeAdmin(address newAdmin) external onlyOwner;
proxy_upgrade
ONLY PROXY ADMIN OWNER OR CONTROLLER CONTRACT ///
function proxy_upgrade(address newImplementation) external onlyOwnerOrControllerContract;
proxy_upgradeAndCall
function proxy_upgradeAndCall(address newImplementation, bytes calldata data) external onlyOwnerOrControllerContract;
ImmutableOwnable
State Variables
OWNER
address public immutable OWNER;
LENS_HUB
address public immutable LENS_HUB;
Functions
onlyOwner
modifier onlyOwner();
onlyOwnerOrHub
modifier onlyOwnerOrHub();
constructor
constructor(address owner, address lensHub);
Errors
OnlyOwner
error OnlyOwner();
OnlyOwnerOrHub
error OnlyOwnerOrHub();
LegacyCollectNFT
Inherits: LensBaseERC721, ERC2981CollectionRoyalties, ICollectNFT
Author: Lens Protocol
This is the NFT contract that is minted upon collecting a given publication. It is cloned upon the first collect for a given publication, and the token URI points to the original publication's contentURI.
This is the Legacy CollectNFT that is used for Legacy Lens V1 publications. The new CollectNFT was introduced in Lens V2 with the only difference that it is restricted by the Action Module instead of the LensHub.
State Variables
HUB
address public immutable HUB;
_profileId
uint256 internal _profileId;
_pubId
uint256 internal _pubId;
_tokenIdCounter
uint256 internal _tokenIdCounter;
_initialized
bool private _initialized;
_royaltiesInBasisPoints
uint256 internal _royaltiesInBasisPoints;
Functions
constructor
constructor(address hub);
initialize
Initializes the collect NFT, setting the feed as the privileged minter, storing the collected publication pointer and initializing the name and symbol in the LensNFTBase contract.
function initialize(uint256 profileId, uint256 pubId) external override;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile in the hub that this Collect NFT points to. | 
| pubId | uint256 | The profile publication ID in the hub that this Collect NFT points to. | 
mint
Mints a collect NFT to the specified address. This can only be called by the hub and is called upon collection.
function mint(address to) external override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| to | address | The address to mint the NFT to. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the minted token ID. | 
getSourcePublicationPointer
Returns the source publication of this collect NFT.
function getSourcePublicationPointer() external view override returns (uint256, uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | tuple First is the profile ID, and second is the publication ID. | 
| <none> | uint256 | 
tokenURI
function tokenURI(uint256 tokenId) public view override returns (string memory);
name
See {IERC721Metadata-name}.
function name() public view override returns (string memory);
symbol
See {IERC721Metadata-symbol}.
function symbol() public pure override returns (string memory);
supportsInterface
See {IERC165-supportsInterface}.
function supportsInterface(bytes4 interfaceId)
    public
    view
    virtual
    override(ERC2981CollectionRoyalties, LensBaseERC721)
    returns (bool);
_getReceiver
function _getReceiver(uint256) internal view override returns (address);
_beforeRoyaltiesSet
function _beforeRoyaltiesSet(uint256) internal view override;
_getRoyaltiesInBasisPointsSlot
function _getRoyaltiesInBasisPointsSlot() internal pure override returns (uint256);
LensHubInitializable
Inherits: LensHub, VersionedInitializable, ILensHubInitializable
Author: Lens Protocol
Extension of LensHub contract that includes initialization for fresh deployments.
State Variables
REVISION
uint256 internal constant REVISION = 1;
Functions
constructor
constructor(
    address followNFTImpl,
    address collectNFTImpl,
    address moduleRegistry,
    uint256 tokenGuardianCooldown,
    Types.MigrationParams memory migrationParams
) LensHub(followNFTImpl, collectNFTImpl, moduleRegistry, tokenGuardianCooldown, migrationParams);
initialize
Initializes the LensHub, setting the initial governance address, the name and symbol of the profiles in the LensNFTBase contract, and Protocol State (Paused).
This is assuming a proxy pattern is implemented.
function initialize(string calldata name, string calldata symbol, address newGovernance)
    external
    override
    initializer;
Parameters
| Name | Type | Description | 
|---|---|---|
| name | string | The name of the Profile NFT. | 
| symbol | string | The symbol of the Profile NFT. | 
| newGovernance | address | The governance address to set. | 
getRevision
function getRevision() internal pure virtual override returns (uint256);
LensV2Migration
State Variables
FEE_FOLLOW_MODULE
address internal immutable FEE_FOLLOW_MODULE;
PROFILE_FOLLOW_MODULE
address internal immutable PROFILE_FOLLOW_MODULE;
NEW_FEE_FOLLOW_MODULE
address internal immutable NEW_FEE_FOLLOW_MODULE;
lensHandles
LensHandles internal immutable lensHandles;
tokenHandleRegistry
TokenHandleRegistry internal immutable tokenHandleRegistry;
Functions
constructor
constructor(Types.MigrationParams memory migrationParams);
batchMigrateProfiles
function batchMigrateProfiles(uint256[] calldata profileIds) external;
batchMigrateFollows
function batchMigrateFollows(
    uint256 followerProfileId,
    uint256[] calldata idsOfProfileFollowed,
    uint256[] calldata followTokenIds
) external;
batchMigrateFollowers
function batchMigrateFollowers(
    uint256[] calldata followerProfileIds,
    uint256 idOfProfileFollowed,
    uint256[] calldata followTokenIds
) external;
batchMigrateFollowModules
function batchMigrateFollowModules(uint256[] calldata profileIds) external;
getProfileIdByHandleHash
function getProfileIdByHandleHash(bytes32 handleHash) external view returns (uint256);
setMigrationAdmins
function setMigrationAdmins(address[] memory migrationAdmins, bool whitelisted) external;
LensV2UpgradeContract
Inherits: ImmutableOwnable
State Variables
PROXY_ADMIN
ProxyAdmin public immutable PROXY_ADMIN;
GOVERNANCE
Governance public immutable GOVERNANCE;
newImplementation
address public immutable newImplementation;
Functions
constructor
constructor(
    address proxyAdminAddress,
    address governanceAddress,
    address owner,
    address lensHub,
    address newImplementationAddress
) ImmutableOwnable(owner, lensHub);
executeLensV2Upgrade
function executeLensV2Upgrade() external onlyOwner;
_upgrade
function _upgrade() internal;
ModuleRegistry
Inherits: IModuleRegistry
State Variables
registeredModules
mapping(address moduleAddress => uint256 moduleTypesBitmap) internal registeredModules;
registeredErc20Currencies
mapping(address erc20CurrencyAddress => bool) internal registeredErc20Currencies;
Functions
registerModule
function registerModule(address moduleAddress, uint256 moduleType) public returns (bool registrationWasPerformed);
getModuleTypes
function getModuleTypes(address moduleAddress) public view returns (uint256);
isModuleRegistered
function isModuleRegistered(address moduleAddress) external view returns (bool);
isModuleRegisteredAs
function isModuleRegisteredAs(address moduleAddress, uint256 moduleType) public view returns (bool);
registerErc20Currency
function registerErc20Currency(address currencyAddress) public returns (bool registrationWasPerformed);
isErc20CurrencyRegistered
function isErc20CurrencyRegistered(address currencyAddress) external view returns (bool);
Events
ModuleRegistered
event ModuleRegistered(address indexed moduleAddress, uint256 indexed moduleType, uint256 timestamp);
erc20CurrencyRegistered
event erc20CurrencyRegistered(
    address indexed erc20CurrencyAddress, string name, string symbol, uint8 decimals, uint256 timestamp
);
ProfileCreationProxy
Inherits: ImmutableOwnable
Author: Lens Protocol
This is an ownable proxy contract that enforces ".lens" handle suffixes at profile creation. Only the owner can create profiles.
State Variables
LENS_HANDLES
ILensHandles immutable LENS_HANDLES;
TOKEN_HANDLE_REGISTRY
ITokenHandleRegistry immutable TOKEN_HANDLE_REGISTRY;
Functions
constructor
constructor(address owner, address hub, address lensHandles, address tokenHandleRegistry)
    ImmutableOwnable(owner, hub);
proxyCreateProfile
function proxyCreateProfile(Types.CreateProfileParams calldata createProfileParams)
    external
    onlyOwner
    returns (uint256);
proxyCreateProfileWithHandle
function proxyCreateProfileWithHandle(Types.CreateProfileParams memory createProfileParams, string calldata handle)
    external
    onlyOwner
    returns (uint256, uint256);
proxyCreateHandle
function proxyCreateHandle(address to, string calldata handle) external onlyOwner returns (uint256);
Errors
ProfileAlreadyExists
error ProfileAlreadyExists();
Contents
Contents
Contents
- base
- CollectNFT
- CollectPublicationAction
- RecipientData
- MultirecipientFeeCollectModuleInitData
- MultirecipientFeeCollectProfilePublicationData
- TooManyRecipients
- InvalidRecipientSplits
- RecipientSplitCannotBeZero
- MultirecipientFeeCollectModule
- SimpleFeeCollectModule
Contents
BaseFeeCollectModule
Inherits: FeeModuleBase, ActionRestricted, IBaseFeeCollectModule
Author: Lens Protocol
This is base Lens CollectModule implementation, allowing customization of time to collect, number of collects and Followers-only restriction. Charges a fee for collect and distributing it among Receiver/Referrals/Treasury.
Here we use "Base" terminology to anything that represents this base functionality (base structs, base functions, base storage). Other collect modules can be built on top of the "Base" by inheriting from this contract and overriding functions. This contract is marked "abstract" as it requires you to implement initializePublicationCollectModule and getPublicationData functions when you inherit from it. See SimpleFeeCollectModule as an example implementation.
State Variables
HUB
address immutable HUB;
_dataByPublicationByProfile
mapping(uint256 => mapping(uint256 => BaseProfilePublicationData)) internal _dataByPublicationByProfile;
Functions
constructor
constructor(address hub, address actionModule) ActionRestricted(actionModule) FeeModuleBase(hub);
processCollect
Processes a collect by:
- Validating that collect action meets all needed criteria
- Processing the collect action either with or without referral
function processCollect(Types.ProcessCollectParams calldata processCollectParams)
    external
    virtual
    onlyActionModule
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | Collect action parameters (see Types.ProcessCollectParams struct) | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
getBasePublicationData
Returns the Base publication data for a given publication, or an empty struct if that publication was not initialized with this module.
function getBasePublicationData(uint256 profileId, uint256 pubId)
    public
    view
    virtual
    returns (BaseProfilePublicationData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile mapped to the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | BaseProfilePublicationData | The BaseProfilePublicationData struct mapped to that publication. | 
calculateFee
Calculates and returns the collect fee of a publication.
Override this function to use a different formula for the fee.
function calculateFee(Types.ProcessCollectParams calldata processCollectParams) public view virtual returns (uint160);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint160 | The collect fee of the specified publication. | 
_validateBaseInitData
*Validates the Base parameters like:
- Is the currency whitelisted
- Is the referralFee in valid range
- Is the end of collects timestamp in valid range This should be called during initializePublicationCollectModule()*
function _validateBaseInitData(BaseFeeCollectModuleInitData memory baseInitData) internal virtual;
Parameters
| Name | Type | Description | 
|---|---|---|
| baseInitData | BaseFeeCollectModuleInitData | Module initialization data (see BaseFeeCollectModuleInitData struct) | 
_storeBasePublicationCollectParameters
Stores the initial module parameters This should be called during initializePublicationCollectModule()
function _storeBasePublicationCollectParameters(
    uint256 profileId,
    uint256 pubId,
    BaseFeeCollectModuleInitData memory baseInitData
) internal virtual;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The publication ID. | 
| baseInitData | BaseFeeCollectModuleInitData | Module initialization data (see BaseFeeCollectModuleInitData struct) | 
_validateAndStoreCollect
*Validates the collect action by checking that:
- the collector is a follower (if enabled)
- the number of collects after the action doesn't surpass the collect limit (if enabled)
- the current block timestamp doesn't surpass the end timestamp (if enabled) This should be called during processCollect()*
function _validateAndStoreCollect(Types.ProcessCollectParams calldata processCollectParams) internal virtual;
_processCollect
*Internal processing of a collect:
- Calculation of fees
- Validation that fees are what collector expected
- Transfer of fees to recipient(-s) and treasury*
function _processCollect(Types.ProcessCollectParams calldata processCollectParams) internal virtual;
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | Parameters of the collect | 
_processCollectWithReferral
*Internal processing of a collect with a referrals (if any). Same as _processCollect, but also includes transfer to referrals (if any):
- Calculation of fees
- Validation that fees are what collector expected
- Transfer of fees to treasury, referrals (if any) and recipients*
function _processCollectWithReferral(Types.ProcessCollectParams calldata processCollectParams) internal virtual;
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | Parameters of the collect | 
_transferToRecipients
Tranfers the fee to recipient(-s) Override this to add additional functionality (e.g. multiple recipients)
function _transferToRecipients(
    Types.ProcessCollectParams calldata processCollectParams,
    address currency,
    uint256 amount
) internal virtual;
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | Parameters of the collect | 
| currency | address | Currency of the transaction | 
| amount | uint256 | Amount to transfer to recipient(-s) | 
_transferToReferrals
Tranfers the part of fee to referral(-s) Override this to add additional functionality (e.g. different amounts to different referrals, etc)
function _transferToReferrals(
    Types.ProcessCollectParams calldata processCollectParams,
    address currency,
    uint256 amount
) internal virtual returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | Parameters of the collect | 
| currency | address | Currency of the transaction | 
| amount | uint256 | Amount of the fee after subtracting the Treasury part. | 
CollectNFT
Inherits: LensBaseERC721, ERC2981CollectionRoyalties, ActionRestricted, ICollectNFT
Author: Lens Protocol
This is the NFT contract that is minted upon collecting a given publication. It is cloned upon the first collect for a given publication, and the token URI points to the original publication's contentURI.
This is the CollectNFT for Lens V2, it differs from LegacyCollectNFT that it's restricted to be called by an action module instead of LensHub.
State Variables
HUB
address public immutable HUB;
_profileId
uint256 internal _profileId;
_pubId
uint256 internal _pubId;
_tokenIdCounter
uint256 internal _tokenIdCounter;
_initialized
bool private _initialized;
_royaltiesInBasisPoints
uint256 internal _royaltiesInBasisPoints;
Functions
constructor
constructor(address hub, address actionModule) ActionRestricted(actionModule);
initialize
Initializes the collect NFT, setting the feed as the privileged minter, storing the collected publication pointer and initializing the name and symbol in the LensNFTBase contract.
function initialize(uint256 profileId, uint256 pubId) external override;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile in the hub that this Collect NFT points to. | 
| pubId | uint256 | The profile publication ID in the hub that this Collect NFT points to. | 
mint
Mints a collect NFT to the specified address. This can only be called by the hub and is called upon collection.
function mint(address to) external override onlyActionModule returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| to | address | The address to mint the NFT to. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the minted token ID. | 
getSourcePublicationPointer
Returns the source publication of this collect NFT.
function getSourcePublicationPointer() external view override returns (uint256, uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | tuple First is the profile ID, and second is the publication ID. | 
| <none> | uint256 | 
tokenURI
function tokenURI(uint256 tokenId) public view override returns (string memory);
name
See {IERC721Metadata-name}.
function name() public view override returns (string memory);
symbol
See {IERC721Metadata-symbol}.
function symbol() public pure override returns (string memory);
supportsInterface
See {IERC165-supportsInterface}.
function supportsInterface(bytes4 interfaceId)
    public
    view
    virtual
    override(ERC2981CollectionRoyalties, LensBaseERC721)
    returns (bool);
_getReceiver
function _getReceiver(uint256) internal view override returns (address);
_beforeRoyaltiesSet
function _beforeRoyaltiesSet(uint256) internal view override;
_getRoyaltiesInBasisPointsSlot
function _getRoyaltiesInBasisPointsSlot() internal pure override returns (uint256);
CollectPublicationAction
Inherits: HubRestricted, IPublicationActionModule
State Variables
COLLECT_NFT_IMPL
address public immutable COLLECT_NFT_IMPL;
_collectModuleRegistered
mapping(address collectModule => bool isWhitelisted) internal _collectModuleRegistered;
_collectDataByPub
mapping(uint256 profileId => mapping(uint256 pubId => CollectData collectData)) internal _collectDataByPub;
Functions
constructor
constructor(address hub, address collectNFTImpl) HubRestricted(hub);
registerCollectModule
function registerCollectModule(address collectModule) public returns (bool);
initializePublicationAction
function initializePublicationAction(uint256 profileId, uint256 pubId, address transactionExecutor, bytes calldata data)
    external
    override
    onlyHub
    returns (bytes memory);
processPublicationAction
function processPublicationAction(Types.ProcessActionParams calldata processActionParams)
    external
    override
    onlyHub
    returns (bytes memory);
_emitCollectedEvent
function _emitCollectedEvent(
    Types.ProcessActionParams calldata processActionParams,
    address collectNftRecipient,
    bytes memory collectData,
    bytes memory collectActionResult,
    address collectNFT,
    uint256 tokenId
) private;
getCollectData
function getCollectData(uint256 profileId, uint256 pubId) external view returns (CollectData memory);
_getOrDeployCollectNFT
function _getOrDeployCollectNFT(
    uint256 publicationCollectedProfileId,
    uint256 publicationCollectedId,
    address collectNFTImpl
) private returns (address);
_processCollect
function _processCollect(
    address collectModule,
    bytes memory collectData,
    Types.ProcessActionParams calldata processActionParams
) private returns (bytes memory);
_deployCollectNFT
function _deployCollectNFT(uint256 profileId, uint256 pubId, address collectNFTImpl) private returns (address);
isCollectModuleRegistered
function isCollectModuleRegistered(address collectModule) external view returns (bool);
Events
CollectModuleRegistered
event CollectModuleRegistered(address collectModule, uint256 timestamp);
CollectNFTDeployed
Emitted when a collectNFT clone is deployed using a lazy deployment pattern.
event CollectNFTDeployed(
    uint256 indexed profileId, uint256 indexed pubId, address indexed collectNFT, uint256 timestamp
);
Collected
Emitted upon a successful collect action.
event Collected(
    uint256 indexed collectedProfileId,
    uint256 indexed collectedPubId,
    uint256 indexed collectorProfileId,
    address nftRecipient,
    bytes collectActionData,
    bytes collectActionResult,
    address collectNFT,
    uint256 tokenId,
    address transactionExecutor,
    uint256 timestamp
);
Structs
CollectData
struct CollectData {
    address collectModule;
    address collectNFT;
}
RecipientData
struct RecipientData {
    address recipient;
    uint16 split;
}
MultirecipientFeeCollectModuleInitData
A struct containing the necessary data to initialize MultirecipientFeeCollectModule.
struct MultirecipientFeeCollectModuleInitData {
    uint160 amount;
    uint96 collectLimit;
    address currency;
    uint16 referralFee;
    bool followerOnly;
    uint72 endTimestamp;
    RecipientData[] recipients;
}
MultirecipientFeeCollectProfilePublicationData
A struct containing the necessary data to execute collect actions on a publication.
struct MultirecipientFeeCollectProfilePublicationData {
    uint160 amount;
    uint96 collectLimit;
    address currency;
    uint96 currentCollects;
    uint16 referralFee;
    bool followerOnly;
    uint72 endTimestamp;
    RecipientData[] recipients;
}
TooManyRecipients
error TooManyRecipients();
InvalidRecipientSplits
error InvalidRecipientSplits();
RecipientSplitCannotBeZero
error RecipientSplitCannotBeZero();
MultirecipientFeeCollectModule
Inherits: BaseFeeCollectModule
Author: Lens Protocol
This is a simple Lens CollectModule implementation, allowing customization of time to collect, number of collects, splitting collect fee across multiple recipients, and whether only followers can collect. It is charging a fee for collect and distributing it among (one or up to five) Receivers, Referral, Treasury.
State Variables
_recipientsByPublicationByProfile
mapping(uint256 => mapping(uint256 => RecipientData[])) internal _recipientsByPublicationByProfile;
Functions
constructor
constructor(address hub, address actionModule) BaseFeeCollectModule(hub, actionModule);
initializePublicationCollectModule
Initializes data for a given publication being published.
function initializePublicationCollectModule(uint256 profileId, uint256 pubId, address, bytes calldata data)
    external
    override
    onlyActionModule
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| <none> | address | |
| data | bytes | Arbitrary data passed from the user! to be decoded. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
_validateAndStoreRecipients
Validates the recipients array and stores them to (a separate from Base) storage.
function _validateAndStoreRecipients(RecipientData[] memory recipients, uint256 profileId, uint256 pubId) internal;
Parameters
| Name | Type | Description | 
|---|---|---|
| recipients | RecipientData[] | An array of recipients | 
| profileId | uint256 | The profile ID who is publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
_transferToRecipients
Transfers the fee to multiple recipients.
function _transferToRecipients(
    Types.ProcessCollectParams calldata processCollectParams,
    address currency,
    uint256 amount
) internal override;
Parameters
| Name | Type | Description | 
|---|---|---|
| processCollectParams | Types.ProcessCollectParams | Parameters of the collect | 
| currency | address | Currency of the transaction | 
| amount | uint256 | Amount to transfer to recipient(-s) | 
getPublicationData
Returns the publication data for a given publication, or an empty struct if that publication was not initialized with this module.
function getPublicationData(uint256 profileId, uint256 pubId)
    external
    view
    returns (MultirecipientFeeCollectProfilePublicationData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile mapped to the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | MultirecipientFeeCollectProfilePublicationData | The BaseProfilePublicationData struct mapped to that publication. | 
SimpleFeeCollectModule
Inherits: BaseFeeCollectModule
Author: Lens Protocol
This is a simple Lens CollectModule implementation, allowing customization of time to collect, number of collects and whether only followers can collect. You can build your own collect modules by inheriting from BaseFeeCollectModule and adding your functionality along with getPublicationData function.
Functions
constructor
constructor(address hub, address actionModule) BaseFeeCollectModule(hub, actionModule);
initializePublicationCollectModule
This collect module levies a fee on collects and supports referrals. Thus, we need to decode data.
function initializePublicationCollectModule(uint256 profileId, uint256 pubId, address, bytes calldata data)
    external
    override
    onlyActionModule
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| <none> | address | |
| data | bytes | The arbitrary data parameter, decoded into BaseFeeCollectModuleInitData struct: amount: The collecting cost associated with this publication. 0 for free collect. collectLimit: The maximum number of collects for this publication. 0 for no limit. currency: The currency associated with this publication. referralFee: The referral fee associated with this publication. followerOnly: True if only followers of publisher may collect the post. endTimestamp: The end timestamp after which collecting is impossible. 0 for no expiry. recipient: Recipient of collect fees. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | An abi encoded bytes parameter, which is the same as the passed data parameter. | 
getPublicationData
Returns the publication data for a given publication, or an empty struct if that publication was not initialized with this module.
function getPublicationData(uint256 profileId, uint256 pubId)
    external
    view
    virtual
    returns (BaseProfilePublicationData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile mapped to the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | BaseProfilePublicationData | The BaseProfilePublicationData struct mapped to that publication. | 
Contents
LensSeaDropCollection
Inherits: ERC721SeaDropCloneable
State Variables
ROYALTIES_BPS
uint16 private constant ROYALTIES_BPS = 1_000;
HUB
address immutable HUB;
SEADROP_ACTION_MODULE
address immutable SEADROP_ACTION_MODULE;
DEFAULT_SEADROP
address immutable DEFAULT_SEADROP;
Functions
onlySeaDropActionModule
modifier onlySeaDropActionModule();
constructor
constructor(address lensHub, address seaDropActionModule, address defaultSeaDrop);
initialize
function initialize(
    address owner,
    string calldata name,
    string calldata symbol,
    address[] calldata allowedSeaDrops,
    MultiConfigureStruct calldata config
) external onlySeaDropActionModule;
_validateInitializationData
function _validateInitializationData(address[] calldata allowedSeaDrops, MultiConfigureStruct calldata config)
    internal
    view;
updateAllowedSeaDrop
Update the allowed SeaDrop contracts. Only the owner or administrator can use this function.
function updateAllowedSeaDrop(address[] calldata allowedSeaDrop) external virtual override onlyOwner;
Parameters
| Name | Type | Description | 
|---|---|---|
| allowedSeaDrop | address[] | The allowed SeaDrop addresses. | 
updatePublicDrop
Update the public drop data for this NFT contract on SeaDrop. Only the owner can use this function.
function updatePublicDrop(address seaDropImpl, PublicDrop calldata publicDrop) external virtual override;
Parameters
| Name | Type | Description | 
|---|---|---|
| seaDropImpl | address | The allowed SeaDrop contract. | 
| publicDrop | PublicDrop | The public drop data. | 
updateAllowedFeeRecipient
Update the allowed fee recipient for this NFT contract on SeaDrop. Only the owner can set the allowed fee recipient.
function updateAllowedFeeRecipient(address seaDropImpl, address feeRecipient, bool allowed) external virtual override;
Parameters
| Name | Type | Description | 
|---|---|---|
| seaDropImpl | address | The allowed SeaDrop contract. | 
| feeRecipient | address | The new fee recipient. | 
| allowed | bool | If the fee recipient is allowed. | 
updatePayer
Update the allowed payers for this NFT contract on SeaDrop. Only the owner can use this function.
function updatePayer(address seaDropImpl, address payer, bool allowed) external virtual override;
Parameters
| Name | Type | Description | 
|---|---|---|
| seaDropImpl | address | The allowed SeaDrop contract. | 
| payer | address | The payer to update. | 
| allowed | bool | Whether the payer is allowed. | 
Errors
OnlySeaDropActionModule
error OnlySeaDropActionModule();
FeesDoNotCoverLensTreasury
error FeesDoNotCoverLensTreasury();
InvalidParams
error InvalidParams();
SeaDropMintPublicationAction
Inherits: HubRestricted, IPublicationActionModule
State Variables
MAX_BPS
uint256 constant MAX_BPS = 10_000;
SEADROP
ISeaDrop public immutable SEADROP;
WMATIC
IWMATIC public immutable WMATIC;
MODULE_REGISTRY
IModuleRegistry public immutable MODULE_REGISTRY;
_collectionDataByPub
mapping(uint256 profileId => mapping(uint256 pubId => CollectionData collectionData)) internal _collectionDataByPub;
lensSeaDropCollectionImpl
address public lensSeaDropCollectionImpl;
Functions
constructor
constructor(address hub, address moduleRegistry, address seaDrop, address wmatic) HubRestricted(hub);
deploySeaDropCollection
function deploySeaDropCollection(
    address owner,
    string memory name,
    string memory symbol,
    ERC721SeaDropStructsErrorsAndEvents.MultiConfigureStruct calldata config
) external returns (address);
setLensSeaDropCollectionImpl
function setLensSeaDropCollectionImpl(address newLensSeaDropCollectionImpl) external;
initializePublicationAction
function initializePublicationAction(uint256 profileId, uint256 pubId, address, bytes calldata data)
    external
    override
    onlyHub
    returns (bytes memory);
receive
receive() external payable;
withdrawToTreasury
function withdrawToTreasury(address currency) external;
processPublicationAction
function processPublicationAction(Types.ProcessActionParams calldata processActionParams)
    external
    override
    onlyHub
    returns (bytes memory);
rescaleFees
function rescaleFees(uint256 profileId, uint256 pubId) public;
_rescaleFees
function _rescaleFees(uint256 profileId, uint256 pubId, uint16 lensTreasuryFeeBps, PublicDrop memory publicDrop)
    internal;
_distributeFees
function _distributeFees(
    uint256 feesToDistribute,
    uint256 mintPaymentAmount,
    address lensTreasuryAddress,
    CollectionData memory collectionData,
    Types.ProcessActionParams calldata processActionParams
) internal;
_validateFees
function _validateFees(PublicDrop memory publicDrop, uint16 lensTreasuryFeeBps, uint16 referrersFeeBps) internal pure;
_validateFeesAndRescaleThemIfNecessary
function _validateFeesAndRescaleThemIfNecessary(
    uint256 profileId,
    uint256 pubId,
    PublicDrop memory publicDrop,
    uint16 lensTreasuryFeeBps,
    uint16 referrersFeeBps
) internal;
Events
SeaDropPublicationFeesRescaled
event SeaDropPublicationFeesRescaled(uint256 profileId, uint256 pubId, uint16 referrersFeeBps);
LensSeaDropCollectionDeployed
event LensSeaDropCollectionDeployed(
    address collectionAddress,
    address owner,
    string name,
    string symbol,
    ERC721SeaDropStructsErrorsAndEvents.MultiConfigureStruct config
);
Errors
WrongMintPaymentAmount
error WrongMintPaymentAmount();
SeaDropFeesNotReceived
error SeaDropFeesNotReceived();
ActionModuleNotAllowedAsPayer
error ActionModuleNotAllowedAsPayer();
ActionModuleNotAllowedAsFeeRecipient
error ActionModuleNotAllowedAsFeeRecipient();
MintPriceExceedsExpectedOne
error MintPriceExceedsExpectedOne();
NotEnoughFeesSet
error NotEnoughFeesSet();
Unauthorized
error Unauthorized();
Structs
CollectionData
struct CollectionData {
    address nftCollectionAddress;
    uint16 referrersFeeBps;
}
Contents
Errors
Errors
FollowInvalid
error FollowInvalid();
ModuleDataMismatch
error ModuleDataMismatch();
NotHub
error NotHub();
InitParamsInvalid
error InitParamsInvalid();
InvalidParams
error InvalidParams();
MintLimitExceeded
error MintLimitExceeded();
CollectExpired
error CollectExpired();
NotActionModule
error NotActionModule();
CollectNotAllowed
error CollectNotAllowed();
AlreadyInitialized
error AlreadyInitialized();
Contents
FeeConfig
A struct containing the necessary data to execute follow actions on a given profile.
struct FeeConfig {
    address currency;
    uint256 amount;
    address recipient;
}
FeeFollowModule
Inherits: FeeModuleBase, HubRestricted, IFollowModule
Author: Lens Protocol
This follow module charges a fee for every follow.
State Variables
_feeConfig
mapping(uint256 profileId => FeeConfig config) internal _feeConfig;
Functions
constructor
constructor(address hub) FeeModuleBase(hub) HubRestricted(hub);
initializeFollowModule
Initializes a follow module for a given Lens profile.
function initializeFollowModule(uint256 profileId, address, bytes calldata data)
    external
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The Profile ID to initialize this follow module for. | 
| <none> | address | |
| data | bytes | The arbitrary data parameter, decoded into: - address currency: The currency address, must be internally whitelisted. - uint256 amount: The currency total amount to charge. - address recipient: The custom recipient address to direct earnings to. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes The encoded data to be emitted from the hub. | 
processFollow
Processes a follow by charging a fee.
function processFollow(
    uint256,
    uint256 followTokenId,
    address transactionExecutor,
    uint256 targetProfileId,
    bytes calldata data
) external override onlyHub returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | |
| followTokenId | uint256 | The Follow Token ID that is being used to follow. Zero if we are processing a new fresh follow, in this case, the follow ID assigned can be queried from the Follow NFT collection if needed. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| targetProfileId | uint256 | The token ID of the profile being followed. | 
| data | bytes | Arbitrary data passed by the follower. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
getFeeConfig
Returns fee configuration for a given profile.
function getFeeConfig(uint256 profileId) external view returns (FeeConfig memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | FeeConfig | FeeConfig The FeeConfig struct mapped to that profile. | 
RevertFollowModule
Inherits: IFollowModule
Author: Lens Protocol
This follow module rejects all follow attempts.
Functions
initializeFollowModule
Initializes a follow module for a given Lens profile.
function initializeFollowModule(uint256, address, bytes calldata) external pure override returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | |
| <none> | address | |
| <none> | bytes | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes The encoded data to be emitted from the hub. | 
processFollow
Processes a follow by rejecting it, reverting the transaction. Parameters are ignored.
function processFollow(uint256, uint256, address, uint256, bytes calldata)
    external
    pure
    override
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | |
| <none> | uint256 | |
| <none> | address | |
| <none> | uint256 | |
| <none> | bytes | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
Contents
BaseProfilePublicationData
A struct containing the necessary data to execute collect actions on a publication.
struct BaseProfilePublicationData {
    uint160 amount;
    uint96 collectLimit;
    address currency;
    uint96 currentCollects;
    address recipient;
    uint16 referralFee;
    bool followerOnly;
    uint72 endTimestamp;
}
BaseFeeCollectModuleInitData
A struct containing the necessary data to initialize this Base Collect Module.
struct BaseFeeCollectModuleInitData {
    uint160 amount;
    uint96 collectLimit;
    address currency;
    uint16 referralFee;
    bool followerOnly;
    uint72 endTimestamp;
    address recipient;
}
IBaseFeeCollectModule
Inherits: ICollectModule
Functions
getBasePublicationData
Returns the Base publication data for a given publication, or an empty struct if that publication was not initialized with this module.
function getBasePublicationData(uint256 profileId, uint256 pubId)
    external
    view
    returns (BaseProfilePublicationData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile mapped to the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | BaseProfilePublicationData | The BaseProfilePublicationData struct mapped to that publication. | 
calculateFee
Calculates and returns the collect fee of a publication.
Override this function to use a different formula for the fee.
function calculateFee(Types.ProcessCollectParams calldata processCollectParams) external view returns (uint160);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint160 | The collect fee of the specified publication. | 
IWMATIC
Inherits: IERC20
Functions
withdraw
function withdraw(uint256 amountToUnwrap) external;
deposit
function deposit() external payable;
Contents
FollowValidationLib
Author: Lens Protocol
A library contract that verifies that a user is following another user and reverts if not.
Functions
validateIsFollowing
function validateIsFollowing(address hub, uint256 followerProfileId, uint256 followedProfileId) internal view;
Contents
- ModuleConfig
- DegreesOfSeparationReferenceModule
- FollowerOnlyReferenceModule
- IToken
- GateParams
- TokenGatedReferenceModule
ModuleConfig
Struct representing the module configuration for certain publication.
struct ModuleConfig {
    bool setUp;
    bool commentsRestricted;
    bool quotesRestricted;
    bool mirrorsRestricted;
    uint8 degreesOfSeparation;
    uint128 sourceProfile;
}
DegreesOfSeparationReferenceModule
Inherits: HubRestricted, IReferenceModule
Author: Lens Protocol
This reference module allows to set a degree of separation n, and then allows to quote/comment/mirror
only to profiles that are at most at n degrees of separation from the source profile, which is expected to be set
as the author of the root publication.
State Variables
MAX_DEGREES_OF_SEPARATION
Because of the "Six degrees of separation" theory, in the long term, setting up 5, 6 or more degrees of separation will be almost equivalent to turning off the restriction. If we also take into account the gas cost of performing the validations on-chain, and the cost of off-chain computation of the path, makes sense to only support up to 3 degrees of separation.
uint8 public constant MAX_DEGREES_OF_SEPARATION = 2;
_moduleConfig
mapping(uint256 profileId => mapping(uint256 pubId => ModuleConfig config)) internal _moduleConfig;
Functions
constructor
constructor(address hub) HubRestricted(hub);
initializeReferenceModule
Initializes data for the given publication being published with this Reference module.
*The data param should have ABI-encoded the following information:
- bool commentsRestricted: Indicates if the comment operation is restricted or open to everyone.
- bool quotesRestricted: Indicates if the quote operation is restricted or open to everyone.
- bool mirrorsRestricted: Indicates if the mirror operation is restricted or open to everyone.
- uint8 degreesOfSeparation: The max degrees of separation allowed for restricted operations.
- uint128 sourceProfile The ID of the profile from where the follower path should be started. Expected to be set as the author of the root publication.*
function initializeReferenceModule(uint256 profileId, uint256 pubId, address, bytes calldata data)
    external
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| <none> | address | |
| data | bytes | Arbitrary data passed from the user to be decoded by the Reference Module during initialization. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processComment
Processes a comment being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
It will apply the degrees of separation restriction if the publication has commentsRestricted enabled.
The param processCommentParams.data has ABI-encoded the array of profile IDs representing the follower path
between the source profile and the profile authoring the comment.
In addition, if comments were restricted, inheritance of commenting restrictions will be enforced.
function processComment(Types.ProcessCommentParams calldata processCommentParams)
    external
    view
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCommentParams | Types.ProcessCommentParams | The parameters for processing a comment. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processQuote
Processes a quote being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
It will apply the degrees of separation restriction if the publication has quotesRestricted enabled.
The param processQuoteParams.data has ABI-encoded the array of profile IDs representing the follower path
between the source profile and the profile authoring the quote.
function processQuote(Types.ProcessQuoteParams calldata processQuoteParams)
    external
    view
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processQuoteParams | Types.ProcessQuoteParams | The parameters for processing a quote. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processMirror
Processes a mirror being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
It will apply the degrees of separation restriction if the publication has mirrorsRestricted enabled.
The param processMirrorParams.data has ABI-encoded the array of profile IDs representing the follower path
between the source profile and the profile authoring the mirror.
function processMirror(Types.ProcessMirrorParams calldata processMirrorParams)
    external
    view
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processMirrorParams | Types.ProcessMirrorParams | The parameters for processing a mirror. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
getModuleConfig
Gets the module configuration for the given publication.
function getModuleConfig(uint256 profileId, uint256 pubId) external view returns (ModuleConfig memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | ModuleConfig | ModuleConfig The module configuration set for the given publication. | 
_validateDegreesOfSeparationRestriction
The data has encoded an array of integers, each integer is a profile ID, the whole array represents a path
of n profiles.
Let's define X --> Y as The owner of X is following Y. Then, being path[i] the i-th profile in the path,
the following condition must be met for a given path of n profiles:
sourceProfile --> path[0] --> path[1] --> path[2] --> ... --> path[n-2] --> path[n-1] --> profileId
function _validateDegreesOfSeparationRestriction(
    uint256 sourceProfile,
    uint256 profileId,
    uint8 degreesOfSeparation,
    uint256[] memory profilePath
) internal view;
Parameters
| Name | Type | Description | 
|---|---|---|
| sourceProfile | uint256 | The ID of the profile from where the follower path should be started. Most likely to be the root publication's author. | 
| profileId | uint256 | The ID of the publication being published's author. | 
| degreesOfSeparation | uint8 | The degrees of separations configured for the given publication. | 
| profilePath | uint256[] | The array of profile IDs representing the follower path between the source profile and the profile authoring the new publication (it could be a comment, a quote or a mirror of the pointed one). | 
_validateCommentInheritedConfigFromPointedPub
Validates that the comment configuration is inherited from pointed publication.
function _validateCommentInheritedConfigFromPointedPub(ModuleConfig memory pointedPubConfig, uint256 profileId)
    internal
    view;
Parameters
| Name | Type | Description | 
|---|---|---|
| pointedPubConfig | ModuleConfig | The pointed publication's degrees of separation module configuration. | 
| profileId | uint256 | The ID of the profile authoring the publication being processed. | 
Errors
InvalidDegreesOfSeparation
error InvalidDegreesOfSeparation();
OperationDisabled
error OperationDisabled();
ProfilePathExceedsDegreesOfSeparation
error ProfilePathExceedsDegreesOfSeparation();
NotInheritingPointedPubConfig
error NotInheritingPointedPubConfig();
FollowerOnlyReferenceModule
Inherits: HubRestricted, IReferenceModule
Author: Lens Protocol
A simple reference module that validates that comments, quotes or mirrors originate from a profile that follows the profile of the original publication.
Functions
constructor
constructor(address hub) HubRestricted(hub);
initializeReferenceModule
Initializes data for the given publication being published with this Reference module.
There is nothing needed at initialization.
function initializeReferenceModule(uint256, uint256, address, bytes calldata) external pure returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | |
| <none> | uint256 | |
| <none> | address | |
| <none> | bytes | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processComment
Processes a comment being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
Validates that the commenting profile's owner is a follower.
function processComment(Types.ProcessCommentParams calldata processCommentParams)
    external
    view
    override
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCommentParams | Types.ProcessCommentParams | The parameters for processing a comment. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processQuote
Processes a quote being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
Validates that the quoting profile's owner is a follower.
function processQuote(Types.ProcessQuoteParams calldata processQuoteParams)
    external
    view
    override
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processQuoteParams | Types.ProcessQuoteParams | The parameters for processing a quote. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processMirror
Processes a mirror being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
Validates that the mirroring profile's owner is a follower.
function processMirror(Types.ProcessMirrorParams calldata processMirrorParams)
    external
    view
    override
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processMirrorParams | Types.ProcessMirrorParams | The parameters for processing a mirror. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
IToken
Functions
balanceOf
Returns the amount of ERC20/ERC721 tokens owned by account.
function balanceOf(address account) external view returns (uint256);
GateParams
A struct containing the necessary data to execute TokenGated references.
struct GateParams {
    address tokenAddress;
    uint256 minThreshold;
}
TokenGatedReferenceModule
Inherits: HubRestricted, IReferenceModule
Author: Lens Protocol
A reference module that validates that the user who tries to reference has a required minimum balance of ERC20/ERC721 token.
State Variables
UINT256_BYTES
uint256 internal constant UINT256_BYTES = 32;
_gateParams
mapping(uint256 pointedProfileId => mapping(uint256 pointedPubId => GateParams gateParams)) internal _gateParams;
Functions
constructor
constructor(address hub) HubRestricted(hub);
initializeReferenceModule
Initializes data for the given publication being published with this Reference module.
The gating token address and minimum balance threshold is passed during initialization in data field.
function initializeReferenceModule(uint256 profileId, uint256 pubId, address, bytes calldata data)
    external
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile publishing the publication. | 
| pubId | uint256 | The associated publication's LensHub publication ID. | 
| <none> | address | |
| data | bytes | Arbitrary data passed from the user to be decoded by the Reference Module during initialization. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Any custom ABI-encoded data. This will be a LensHub event params that can be used by indexers or UIs. | 
processComment
Processes a comment being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
Validates that the commenting profile's owner has enough balance of the gating token.
function processComment(Types.ProcessCommentParams calldata processCommentParams)
    external
    view
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processCommentParams | Types.ProcessCommentParams | The parameters for processing a comment. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | balance The ABI-encoded gate token balance of the profile trying to comment/quote/mirror. | 
processQuote
Processes a quote being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
Validates that the commenting profile's owner has enough balance of the gating token.
function processQuote(Types.ProcessQuoteParams calldata processQuoteParams)
    external
    view
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processQuoteParams | Types.ProcessQuoteParams | The parameters for processing a quote. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | balance The ABI-encoded gate token balance of the profile trying to comment/quote/mirror. | 
processMirror
Processes a mirror being published. This includes any module logic like transferring tokens, checking for conditions (e.g. token-gated), etc.
Validates that the mirroring profile's owner has enough balance of the gating token.
function processMirror(Types.ProcessMirrorParams calldata processMirrorParams)
    external
    view
    override
    onlyHub
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| processMirrorParams | Types.ProcessMirrorParams | The parameters for processing a mirror. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | balance The ABI-encoded gate token balance of the profile trying to comment/quote/mirror. | 
_validateTokenBalance
Validates the profile's owner balance of gating token. It can work with both ERC20 and ERC721 as both
interfaces shares balanceOf function prototype.
function _validateTokenBalance(uint256 profileId, uint256 pointedProfileId, uint256 pointedPubId)
    internal
    view
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The ID of the profile trying to comment/quote/mirror. | 
| pointedProfileId | uint256 | The ID of the pointed publication's author. | 
| pointedPubId | uint256 | The ID of the pointed publication. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The gate token balance of the profile trying to comment/quote/mirror. | 
Events
TokenGatedReferencePublicationCreated
event TokenGatedReferencePublicationCreated(
    uint256 indexed profileId, uint256 indexed pubId, address tokenAddress, uint256 minThreshold
);
Errors
NotEnoughBalance
error NotEnoughBalance();
ActionRestricted
Author: Lens Protocol
This abstract contract adds a public ACTION_MODULE immutable field, and onlyActionModule modifier,
to inherit from contracts that have functions restricted to be only called by the Action Modules.
State Variables
ACTION_MODULE
address public immutable ACTION_MODULE;
Functions
onlyActionModule
modifier onlyActionModule();
constructor
constructor(address actionModule);
FeeModuleBase
Author: Lens Protocol
This is an abstract contract to be inherited from by modules that require basic fee functionality. It contains getters for module globals parameters as well as a validation function to check expected data.
State Variables
BPS_MAX
uint16 internal constant BPS_MAX = 10000;
HUB
ILensHub private immutable HUB;
MODULE_REGISTRY
IModuleRegistry public immutable MODULE_REGISTRY;
Functions
constructor
constructor(address hub);
_currencyWhitelisted
function _currencyWhitelisted(address currency) internal returns (bool);
_treasuryData
function _treasuryData() internal view returns (address, uint16);
_validateDataIsExpected
function _validateDataIsExpected(bytes calldata data, address currency, uint256 amount) internal pure;
Contents
Contents
RegistryErrors
Errors
NotHandleNorTokenOwner
error NotHandleNorTokenOwner();
OnlyLensHub
error OnlyLensHub();
NotLinked
error NotLinked();
DoesNotExist
error DoesNotExist();
DoesNotHavePermissions
error DoesNotHavePermissions();
HandleAndTokenNotInSameWallet
error HandleAndTokenNotInSameWallet();
SignatureInvalid
error SignatureInvalid();
HandlesErrors
Errors
HandleLengthInvalid
error HandleLengthInvalid();
HandleContainsInvalidCharacters
error HandleContainsInvalidCharacters();
HandleFirstCharInvalid
error HandleFirstCharInvalid();
NotOwnerNorWhitelisted
error NotOwnerNorWhitelisted();
NotOwner
error NotOwner();
NotHub
error NotHub();
DoesNotExist
error DoesNotExist();
NotEOA
error NotEOA();
DisablingAlreadyTriggered
error DisablingAlreadyTriggered();
GuardianEnabled
error GuardianEnabled();
AlreadyEnabled
error AlreadyEnabled();
HandlesEvents
Events
HandleMinted
event HandleMinted(string handle, string namespace, uint256 handleId, address to, uint256 timestamp);
TokenGuardianStateChanged
Emitted when an address' Token Guardian state change is triggered.
event TokenGuardianStateChanged(
    address indexed wallet, bool indexed enabled, uint256 tokenGuardianDisablingTimestamp, uint256 timestamp
);
RegistryEvents
Events
HandleLinked
event HandleLinked(
    RegistryTypes.Handle handle, RegistryTypes.Token token, address transactionExecutor, uint256 timestamp
);
HandleUnlinked
WARNING: If a linked handle or token is burnt, this event will not be emitted.
Indexers should also take into account token burns through ERC-721 Transfer events to track all unlink actions.
The resolveHandle and resolveToken functions will properly reflect the unlink in any case.
event HandleUnlinked(
    RegistryTypes.Handle handle, RegistryTypes.Token token, address transactionExecutor, uint256 timestamp
);
NonceUpdated
Emitted when a signer's nonce is used and, as a consequence, the next available nonce is updated.
event NonceUpdated(address indexed signer, uint256 nonce, uint256 timestamp);
Typehash
State Variables
EIP712_DOMAIN
bytes32 constant EIP712_DOMAIN =
    keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)");
LINK
bytes32 constant LINK = keccak256("Link(uint256 handleId,uint256 profileId,uint256 nonce,uint256 deadline)");
UNLINK
bytes32 constant UNLINK = keccak256("Unlink(uint256 handleId,uint256 profileId,uint256 nonce,uint256 deadline)");
RegistryTypes
Author: Lens Protocol
Structs
Token
struct Token {
    uint256 id;
    address collection;
}
Handle
struct Handle {
    uint256 id;
    address collection;
}
LensHandles
Inherits: ERC721, ImmutableOwnable, ILensHandles
A handle is defined as a local name inside a namespace context. A handle is represented as the local name with its namespace applied as a prefix, using the slash symbol as separator. handle = /${namespace}/${localName} Handle and local name can be used interchangeably once you are in a context of a namespace, as it became redundant. handle === ${localName} ; inside some namespace.
State Variables
MAX_LOCAL_NAME_LENGTH
uint256 internal constant MAX_LOCAL_NAME_LENGTH = 26;
NAMESPACE
string internal constant NAMESPACE = "lens";
NAMESPACE_LENGTH
uint256 internal immutable NAMESPACE_LENGTH = bytes(NAMESPACE).length;
SEPARATOR_LENGTH
uint256 internal constant SEPARATOR_LENGTH = 1;
NAMESPACE_HASH
bytes32 internal constant NAMESPACE_HASH = keccak256(bytes(NAMESPACE));
TOKEN_GUARDIAN_COOLDOWN
uint256 internal immutable TOKEN_GUARDIAN_COOLDOWN;
_tokenGuardianDisablingTimestamp
mapping(address => uint256) internal _tokenGuardianDisablingTimestamp;
_localNames
mapping(uint256 tokenId => string localName) internal _localNames;
Functions
onlyOwnerOrWhitelistedProfileCreator
modifier onlyOwnerOrWhitelistedProfileCreator();
onlyEOA
modifier onlyEOA();
onlyHub
modifier onlyHub();
constructor
constructor(address owner, address lensHub, uint256 tokenGuardianCooldown)
    ERC721("", "")
    ImmutableOwnable(owner, lensHub);
name
function name() public pure override returns (string memory);
symbol
function symbol() public pure override returns (string memory);
tokenURI
See {IERC721Metadata-tokenURI}.
function tokenURI(uint256 tokenId) public view override returns (string memory);
mintHandle
Mints a handle NFT in the given namespace.
function mintHandle(address to, string calldata localName)
    external
    onlyOwnerOrWhitelistedProfileCreator
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| to | address | The address to mint the handle to. | 
| localName | string | The local name of the handle (the part before ".lens"). | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the handle NFT minted. | 
migrateHandle
function migrateHandle(address to, string calldata localName) external onlyHub returns (uint256);
burn
function burn(uint256 tokenId) external;
DANGER__disableTokenGuardian
**** TOKEN GUARDIAN FUNCTIONS ****
function DANGER__disableTokenGuardian() external onlyEOA;
enableTokenGuardian
function enableTokenGuardian() external onlyEOA;
approve
function approve(address to, uint256 tokenId) public override(IERC721, ERC721);
setApprovalForAll
function setApprovalForAll(address operator, bool approved) public override(IERC721, ERC721);
exists
function exists(uint256 tokenId) external view returns (bool);
getNamespace
function getNamespace() external pure returns (string memory);
getNamespaceHash
function getNamespaceHash() external pure returns (bytes32);
getLocalName
function getLocalName(uint256 tokenId) public view returns (string memory);
getHandle
function getHandle(uint256 tokenId) public view returns (string memory);
getTokenId
function getTokenId(string memory localName) public pure returns (uint256);
getTokenGuardianDisablingTimestamp
function getTokenGuardianDisablingTimestamp(address wallet) external view returns (uint256);
_mintHandle
INTERNAL FUNCTIONS ///
function _mintHandle(address to, string calldata localName) internal returns (uint256);
_validateLocalNameMigration
This function is used to validate the local name when migrating from V1 to V2. As in V1 we also allowed the Hyphen '-' character, we need to allow it here as well and use a separate validation function for migration VS newly created handles.
function _validateLocalNameMigration(string memory localName) internal pure;
_validateLocalName
In V2 we only accept the following characters: [a-z0-9_] to be used in newly created handles. We also disallow the first character to be an underscore '_'.
function _validateLocalName(string memory localName) internal pure;
_isAlphaNumeric
We only accept lowercase characters to avoid confusion.
function _isAlphaNumeric(bytes1 char) internal pure returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| char | bytes1 | The character to check. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | True if the character is alphanumeric, false otherwise. | 
_hasTokenGuardianEnabled
function _hasTokenGuardianEnabled(address wallet) internal view returns (bool);
_beforeTokenTransfer
function _beforeTokenTransfer(address from, address to, uint256, uint256 batchSize) internal override;
TokenHandleRegistry
Inherits: ITokenHandleRegistry
Author: Lens Protocol
This contract is used to link a token with a handle.
State Variables
LENS_HUB
address immutable LENS_HUB;
LENS_HANDLES
address immutable LENS_HANDLES;
EIP1271_MAGIC_VALUE
bytes4 internal constant EIP1271_MAGIC_VALUE = 0x1626ba7e;
handleToToken
mapping(bytes32 handle => RegistryTypes.Token token) handleToToken;
tokenToHandle
mapping(bytes32 token => RegistryTypes.Handle handle) tokenToHandle;
nonces
mapping(address signer => uint256 nonce) public nonces;
Functions
constructor
constructor(address lensHub, address lensHandles);
migrationLink
function migrationLink(uint256 handleId, uint256 profileId) external;
link
Links a handle NFT with a profile NFT. Linking means a connection between the two NFTs is created, and the handle NFT can be used to resolve the profile NFT or vice versa.
*In the first version of the registry, the NFT contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one accepting addresses of the handle and token contracts.*
function link(uint256 handleId, uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
| profileId | uint256 | ID of the Lens Protocol Profile NFT | 
linkWithSig
function linkWithSig(uint256 handleId, uint256 profileId, Types.EIP712Signature calldata signature) external;
_link
function _link(uint256 handleId, uint256 profileId, address transactionExecutor) private;
_validateLinkSignature
function _validateLinkSignature(Types.EIP712Signature calldata signature, uint256 handleId, uint256 profileId)
    internal;
_validateUnlinkSignature
function _validateUnlinkSignature(Types.EIP712Signature calldata signature, uint256 handleId, uint256 profileId)
    internal;
_validateRecoveredAddress
Wrapper for ecrecover to reduce code size, used in meta-tx specific functions.
function _validateRecoveredAddress(bytes32 digest, Types.EIP712Signature calldata signature) private view;
_calculateDigest
Calculates EIP712 digest based on the current DOMAIN_SEPARATOR.
function _calculateDigest(bytes32 hashedMessage) private view returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| hashedMessage | bytes32 | The message hash from which the digest should be calculated. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | bytes32 A 32-byte output representing the EIP712 digest. | 
calculateDomainSeparator
function calculateDomainSeparator() internal view returns (bytes32);
unlink
Unlinks a handle NFT from a profile NFT.
*In the first version of the registry, the contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one accepting addresses of the handle and token contracts.*
function unlink(uint256 handleId, uint256 profileId) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
| profileId | uint256 | ID of the Lens Protocol Profile NFT | 
unlinkWithSig
function unlinkWithSig(uint256 handleId, uint256 profileId, Types.EIP712Signature calldata signature) external;
_unlink
function _unlink(uint256 handleId, uint256 profileId, address transactionExecutor) private;
resolve
Resolves a handle NFT to a profile NFT.
*In the first version of the registry, the contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one.*
function resolve(uint256 handleId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| handleId | uint256 | ID of the .lens namespace handle NFT | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | tokenId ID of the Lens Protocol Profile NFT | 
getDefaultHandle
Gets a default handle for a profile NFT (aka reverse resolution).
*In the first version of the registry, the contracts are hard-coded:
- Handle is hard-coded to be of the .lens namespace
- Token is hard-coded to be of the Lens Protocol Profile In future versions, the registry will be more flexible and allow for different namespaces and tokens, so this function might be deprecated and replaced with a new one.*
function getDefaultHandle(uint256 profileId) external view returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | handleId ID of the .lens namespace handle NFT | 
_resolveHandleToToken
INTERNAL FUNCTIONS ///
function _resolveHandleToToken(RegistryTypes.Handle memory handle)
    internal
    view
    returns (RegistryTypes.Token storage);
_resolveTokenToHandle
function _resolveTokenToHandle(RegistryTypes.Token memory token) internal view returns (RegistryTypes.Handle storage);
_executeLinkage
function _executeLinkage(
    RegistryTypes.Handle memory handle,
    RegistryTypes.Token memory token,
    address transactionExecutor
) internal;
_deleteTokenToHandleLinkageIfAny
function _deleteTokenToHandleLinkageIfAny(RegistryTypes.Handle memory handle, address transactionExecutor) internal;
_deleteHandleToTokenLinkageIfAny
function _deleteHandleToTokenLinkageIfAny(RegistryTypes.Token memory token, address transactionExecutor) internal;
_executeUnlinkage
function _executeUnlinkage(
    RegistryTypes.Handle memory handle,
    RegistryTypes.Token memory token,
    address transactionExecutor
) internal;
_handleHash
function _handleHash(RegistryTypes.Handle memory handle) internal pure returns (bytes32);
_tokenHash
function _tokenHash(RegistryTypes.Token memory token) internal pure returns (bytes32);
_getNonceIncrementAndEmitEvent
This fetches a signer's current nonce and increments it so it's ready for the next meta-tx. Also emits
the NonceUpdated event.
function _getNonceIncrementAndEmitEvent(address signer) private returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| signer | address | The address to get and increment the nonce for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The current nonce for the given signer prior to being incremented. | 
FollowNFT
Inherits: HubRestricted, LensBaseERC721, ERC2981CollectionRoyalties, IFollowNFT
State Variables
FOLLOW_NFT_NAME_SUFFIX
string constant FOLLOW_NFT_NAME_SUFFIX = "-Follower";
FOLLOW_NFT_SYMBOL_SUFFIX
string constant FOLLOW_NFT_SYMBOL_SUFFIX = "-Fl";
___DEPRECATED_SLOTS
uint256[5] ___DEPRECATED_SLOTS;
_followedProfileId
uint256 internal _followedProfileId;
_lastFollowTokenId
uint128 internal _lastFollowTokenId;
_followerCount
uint128 internal _followerCount;
_initialized
bool private _initialized;
_followDataByFollowTokenId
mapping(uint256 => Types.FollowData) internal _followDataByFollowTokenId;
_followTokenIdByFollowerProfileId
mapping(uint256 => uint256) internal _followTokenIdByFollowerProfileId;
_followApprovalByFollowTokenId
mapping(uint256 => uint256) internal _followApprovalByFollowTokenId;
_royaltiesInBasisPoints
uint256 internal _royaltiesInBasisPoints;
Functions
whenNotPaused
modifier whenNotPaused();
constructor
constructor(address hub) HubRestricted(hub);
initialize
Initializes the follow NFT.
Sets the targeted profile, and the token royalties.
function initialize(uint256 profileId) external override;
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The ID of the profile targeted by the follow tokens minted by this collection. | 
follow
Makes the passed profile follow the profile targeted in this contract.
function follow(uint256 followerProfileId, address transactionExecutor, uint256 followTokenId)
    external
    override
    onlyHub
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile acting as the follower. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
| followTokenId | uint256 | The ID of the follow token to be used for this follow operation. Zero if a new follow token should be minted. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the token used to follow. | 
unfollow
Makes the passed profile unfollow the profile targeted in this contract.
function unfollow(uint256 unfollowerProfileId, address transactionExecutor) external override onlyHub;
Parameters
| Name | Type | Description | 
|---|---|---|
| unfollowerProfileId | uint256 | The ID of the profile that is performing the unfollow operation. | 
| transactionExecutor | address | The address of the transaction executor (e.g. for any funds to transferFrom). | 
removeFollower
Removes the follower from the given follow NFT.
Only on wrapped token.
function removeFollower(uint256 followTokenId) external override whenNotPaused;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to remove the follower from. | 
approveFollow
Approves the given profile to follow with the given wrapped token.
Only on wrapped tokens. It approves setting a follower on the given wrapped follow token, which lets the follow token owner to allow a profile to follow with his token without losing its ownership. This approval is cleared on transfers, as well as when unwrapping.
function approveFollow(uint256 followerProfileId, uint256 followTokenId) external override;
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | |
| followTokenId | uint256 | The ID of the follow token to be approved for the given profile. | 
wrap
Unties the follow token from the follower's profile one, and wraps it into the ERC-721 untied follow tokens collection. Untied follow tokens will NOT be automatically transferred with their follower profile.
Only on unwrapped follow tokens.
function wrap(uint256 followTokenId, address wrappedTokenReceiver) external override whenNotPaused;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to untie and wrap. | 
| wrappedTokenReceiver | address | 
wrap
Unties the follow token from the follower's profile one, and wraps it into the ERC-721 untied follow tokens collection. Untied follow tokens will NOT be automatically transferred with their follower profile.
Only on unwrapped follow tokens.
function wrap(uint256 followTokenId) external override whenNotPaused;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to untie and wrap. | 
_wrap
function _wrap(uint256 followTokenId, address wrappedTokenReceiver) internal;
unwrap
Unwraps the follow token from the ERC-721 untied follow tokens collection, and ties it to the follower's profile token. Tokens that are tied to the follower profile will be automatically transferred with it.
function unwrap(uint256 followTokenId) external override whenNotPaused;
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token to unwrap and tie to its follower. | 
processBlock
Processes logic when the given profile is being blocked. If it was following the targeted profile, this will make it unfollow.
function processBlock(uint256 followerProfileId) external override onlyHub returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the follow token to unwrap and tie. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the given profile was following and now has unfollowed, false otherwise. | 
getFollowerProfileId
GETTERS ///
function getFollowerProfileId(uint256 followTokenId) external view override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose follower should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the profile following with the given token, zero if it is not being used to follow. | 
isFollowing
Tells if the given profile is following the profile targeted in this contract.
function isFollowing(uint256 followerProfileId) external view override returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile whose following state should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | uint256 The ID of the profile set as a follower in the given token, zero if it is not being used to follow. | 
getFollowTokenId
Gets the ID of the token being used to follow by the given follower.
function getFollowTokenId(uint256 followerProfileId) external view override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile whose follow ID should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the token being used to follow by the given follower, zero if he is not following. | 
getOriginalFollowTimestamp
Gets the original follow timestamp of the given follow token.
function getOriginalFollowTimestamp(uint256 followTokenId) external view override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose original follow timestamp should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The timestamp of the first follow performed with the token, zero if was not used to follow yet. | 
getFollowTimestamp
Gets the current follow timestamp of the given follow token.
function getFollowTimestamp(uint256 followTokenId) external view override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose follow timestamp should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The timestamp of the current follow of the token, zero if it is not being used to follow. | 
getProfileIdAllowedToRecover
Gets the ID of the profile allowed to recover the given follow token.
function getProfileIdAllowedToRecover(uint256 followTokenId) external view override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose allowed profile to recover should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the profile allowed to recover the given follow token, zero if none of them is allowed. | 
getFollowData
Gets the follow data of the given follow token.
function getFollowData(uint256 followTokenId) external view override returns (Types.FollowData memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the follow token whose follow data should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.FollowData | FollowData The token data associated with the given follow token. | 
getFollowApproved
Gets the ID of the profile approved to follow with the given token.
function getFollowApproved(uint256 followTokenId) external view override returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| followTokenId | uint256 | The ID of the token whose approved to follow should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The ID of the profile approved to follow with the given token, zero if none of them is approved. | 
getFollowerCount
Gets the count of the followers of the profile targeted in this contract.
function getFollowerCount() external view override returns (uint256);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 The count of the followers of the profile targeted in this contract. | 
burn
function burn(uint256 followTokenId) public override whenNotPaused;
supportsInterface
See {IERC165-supportsInterface}.
function supportsInterface(bytes4 interfaceId)
    public
    view
    virtual
    override(LensBaseERC721, ERC2981CollectionRoyalties)
    returns (bool);
name
function name() public view override returns (string memory);
symbol
function symbol() public view override returns (string memory);
tokenURI
This returns the follow NFT URI fetched from the hub.
function tokenURI(uint256 followTokenId) public view override returns (string memory);
_followMintingNewToken
function _followMintingNewToken(uint256 followerProfileId) internal returns (uint256);
_followWithWrappedToken
function _followWithWrappedToken(uint256 followerProfileId, address transactionExecutor, uint256 followTokenId)
    internal
    returns (uint256);
_followWithUnwrappedTokenFromBurnedProfile
function _followWithUnwrappedTokenFromBurnedProfile(
    uint256 followerProfileId,
    uint256 followTokenId,
    uint256 currentFollowerProfileId,
    address transactionExecutor
) internal returns (uint256);
_followByRecoveringToken
function _followByRecoveringToken(uint256 followerProfileId, uint256 followTokenId) internal returns (uint256);
_replaceFollower
function _replaceFollower(
    uint256 currentFollowerProfileId,
    uint256 newFollowerProfileId,
    uint256 followTokenId,
    address transactionExecutor
) internal;
_baseFollow
function _baseFollow(uint256 followerProfileId, uint256 followTokenId, bool isOriginalFollow) internal;
_unfollowIfHasFollower
function _unfollowIfHasFollower(uint256 followTokenId, address transactionExecutor) internal;
_unfollow
function _unfollow(uint256 unfollower, uint256 followTokenId) internal;
_approveFollow
function _approveFollow(uint256 approvedProfileId, uint256 followTokenId) internal;
_beforeTokenTransfer
Upon transfers, we clear follow approvals and emit the transfer event in the hub.
function _beforeTokenTransfer(address from, address to, uint256 followTokenId) internal override whenNotPaused;
_getReceiver
function _getReceiver(uint256) internal view override returns (address);
_beforeRoyaltiesSet
function _beforeRoyaltiesSet(uint256) internal view override;
_isFollowTokenWrapped
function _isFollowTokenWrapped(uint256 followTokenId) internal view returns (bool);
_getRoyaltiesInBasisPointsSlot
function _getRoyaltiesInBasisPointsSlot() internal pure override returns (uint256);
tryMigrate
Migrations ///
function tryMigrate(uint256 followerProfileId, address followerProfileOwner, uint256 followTokenId)
    external
    onlyHub
    returns (uint48);
Events
FollowApproval
event FollowApproval(uint256 indexed followerProfileId, uint256 indexed followTokenId);
LensHub
Inherits: LensProfiles, LensGovernable, LensV2Migration, LensImplGetters, LensHubEventHooks, LensHubStorage, ILensProtocol
Author: Lens Protocol
This is the main entry point of the Lens Protocol. It contains governance functionality as well as publishing and profile interaction functionality. NOTE: The Lens Protocol is unique in that frontend operators need to track a potentially overwhelming number of NFT contracts and interactions at once. For that reason, we've made two quirky design decisions:
- Both Follow & Collect NFTs invoke a LensHub callback on transfer with the sole purpose of emitting an event.
- Almost every event in the protocol emits the current block timestamp, reducing the need to fetch it manually.
Functions
onlyProfileOwnerOrDelegatedExecutor
modifier onlyProfileOwnerOrDelegatedExecutor(address expectedOwnerOrDelegatedExecutor, uint256 profileId);
whenPublishingEnabled
modifier whenPublishingEnabled();
constructor
constructor(
    address followNFTImpl,
    address legacyCollectNFTImpl,
    address moduleRegistry,
    uint256 tokenGuardianCooldown,
    Types.MigrationParams memory migrationParams
)
    LensV2Migration(migrationParams)
    LensProfiles(tokenGuardianCooldown)
    LensImplGetters(followNFTImpl, legacyCollectNFTImpl, moduleRegistry);
createProfile
Creates a profile with the specified parameters, minting a Profile NFT to the given recipient.
function createProfile(Types.CreateProfileParams calldata createProfileParams)
    external
    override
    whenNotPaused
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| createProfileParams | Types.CreateProfileParams | A CreateProfileParams struct containing the needed params. | 
setProfileMetadataURI
PROFILE OWNER FUNCTIONS ///
function setProfileMetadataURI(uint256 profileId, string calldata metadataURI)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, profileId);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to set the metadata URI for. | 
| metadataURI | string | The metadata URI to set for the given profile. | 
setProfileMetadataURIWithSig
function setProfileMetadataURIWithSig(
    uint256 profileId,
    string calldata metadataURI,
    Types.EIP712Signature calldata signature
) external override whenNotPaused onlyProfileOwnerOrDelegatedExecutor(signature.signer, profileId);
setFollowModule
Sets the follow module for the given profile.
function setFollowModule(uint256 profileId, address followModule, bytes calldata followModuleInitData)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, profileId);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to set the follow module for. | 
| followModule | address | The follow module to set for the given profile, must be whitelisted. | 
| followModuleInitData | bytes | The data to be passed to the follow module for initialization. | 
setFollowModuleWithSig
function setFollowModuleWithSig(
    uint256 profileId,
    address followModule,
    bytes calldata followModuleInitData,
    Types.EIP712Signature calldata signature
) external override whenNotPaused onlyProfileOwnerOrDelegatedExecutor(signature.signer, profileId);
changeDelegatedExecutorsConfig
Changes the delegated executors configuration for the given profile. It allows setting the approvals for delegated executors in the specified configuration, as well as switching to it.
function changeDelegatedExecutorsConfig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals,
    uint64 configNumber,
    bool switchToGivenConfig
) external override whenNotPaused onlyProfileOwner(msg.sender, delegatorProfileId);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to which the delegated executor is being changed for. | 
| delegatedExecutors | address[] | The array of delegated executors to set the approval for. | 
| approvals | bool[] | The array of booleans indicating the corresponding executor's new approval status. | 
| configNumber | uint64 | The number of the configuration where the executor approval state is being set. | 
| switchToGivenConfig | bool | A boolean indicating if the configuration must be switched to the one with the given number. | 
changeDelegatedExecutorsConfig
function changeDelegatedExecutorsConfig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals
) external override whenNotPaused onlyProfileOwner(msg.sender, delegatorProfileId);
changeDelegatedExecutorsConfigWithSig
function changeDelegatedExecutorsConfigWithSig(
    uint256 delegatorProfileId,
    address[] calldata delegatedExecutors,
    bool[] calldata approvals,
    uint64 configNumber,
    bool switchToGivenConfig,
    Types.EIP712Signature calldata signature
) external override whenNotPaused onlyProfileOwner(signature.signer, delegatorProfileId);
post
PUBLISHING FUNCTIONS ///
function post(Types.PostParams calldata postParams)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, postParams.profileId)
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| postParams | Types.PostParams | A PostParams struct containing the needed parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the post's publication ID. | 
postWithSig
function postWithSig(Types.PostParams calldata postParams, Types.EIP712Signature calldata signature)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, postParams.profileId)
    returns (uint256);
comment
Publishes a comment on the given publication. Comment is a type of reference publication that points to another publication. Comments can have these types of modules initialized:
- Action modules: any number of publication actions (e.g. collect, tip, etc.)
- Reference module: a module handling the rules when referencing this comment (e.g. token-gated mirrors) Comments can have referrers (e.g. publications or profiles that allowed to discover the pointed publication).
function comment(Types.CommentParams calldata commentParams)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, commentParams.profileId)
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| commentParams | Types.CommentParams | A CommentParams struct containing the needed parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the comment's publication ID. | 
commentWithSig
function commentWithSig(Types.CommentParams calldata commentParams, Types.EIP712Signature calldata signature)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, commentParams.profileId)
    returns (uint256);
mirror
Publishes a mirror of the given publication. Mirror is a type of reference publication that points to another publication but doesn't have content. Mirrors don't have any modules initialized. Mirrors can have referrers (e.g. publications or profiles that allowed to discover the pointed publication). You cannot mirror a mirror, comment on a mirror, or quote a mirror.
function mirror(Types.MirrorParams calldata mirrorParams)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, mirrorParams.profileId)
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| mirrorParams | Types.MirrorParams | A MirrorParams struct containing the necessary parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the mirror's publication ID. | 
mirrorWithSig
function mirrorWithSig(Types.MirrorParams calldata mirrorParams, Types.EIP712Signature calldata signature)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, mirrorParams.profileId)
    returns (uint256);
quote
Publishes a quote of the given publication. Quote is a type of reference publication similar to mirror, but it has content and modules. Quotes can have these types of modules initialized:
- Action modules: any number of publication actions (e.g. collect, tip, etc.)
- Reference module: a module handling the rules when referencing this quote (e.g. token-gated comments on quote) Quotes can have referrers (e.g. publications or profiles that allowed to discover the pointed publication). Unlike mirrors, you can mirror a quote, comment on a quote, or quote a quote.
function quote(Types.QuoteParams calldata quoteParams)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, quoteParams.profileId)
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| quoteParams | Types.QuoteParams | A QuoteParams struct containing the needed parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the quote's publication ID. | 
quoteWithSig
function quoteWithSig(Types.QuoteParams calldata quoteParams, Types.EIP712Signature calldata signature)
    external
    override
    whenPublishingEnabled
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, quoteParams.profileId)
    returns (uint256);
follow
PROFILE INTERACTION FUNCTIONS ///
Both the idsOfProfilesToFollow, followTokenIds, and datas arrays must be of the same length,
regardless if the profiles do not have a follow module set.
function follow(
    uint256 followerProfileId,
    uint256[] calldata idsOfProfilesToFollow,
    uint256[] calldata followTokenIds,
    bytes[] calldata datas
)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, followerProfileId)
    returns (uint256[] memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile the follows are being executed for. | 
| idsOfProfilesToFollow | uint256[] | The array of IDs of profiles to follow. | 
| followTokenIds | uint256[] | The array of follow token IDs to use for each follow (0 if you don't own a follow token). | 
| datas | bytes[] | The arbitrary data array to pass to the follow module for each profile if needed. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256[] | uint256[] An array of follow token IDs representing the follow tokens created for each follow. | 
followWithSig
function followWithSig(
    uint256 followerProfileId,
    uint256[] calldata idsOfProfilesToFollow,
    uint256[] calldata followTokenIds,
    bytes[] calldata datas,
    Types.EIP712Signature calldata signature
)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, followerProfileId)
    returns (uint256[] memory);
unfollow
Unfollows given profiles.
function unfollow(uint256 unfollowerProfileId, uint256[] calldata idsOfProfilesToUnfollow)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, unfollowerProfileId);
Parameters
| Name | Type | Description | 
|---|---|---|
| unfollowerProfileId | uint256 | The ID of the profile the unfollows are being executed for. | 
| idsOfProfilesToUnfollow | uint256[] | The array of IDs of profiles to unfollow. | 
unfollowWithSig
function unfollowWithSig(
    uint256 unfollowerProfileId,
    uint256[] calldata idsOfProfilesToUnfollow,
    Types.EIP712Signature calldata signature
) external override whenNotPaused onlyProfileOwnerOrDelegatedExecutor(signature.signer, unfollowerProfileId);
setBlockStatus
Sets the block status for the given profiles. Changing a profile's block status to true (i.e. blocked),
when will also force them to unfollow.
Blocked profiles cannot perform any actions with the profile that blocked them: they cannot comment or mirror
their publications, they cannot follow them, they cannot collect, tip them, etc.
Both the idsOfProfilesToSetBlockStatus and blockStatus arrays must be of the same length.
function setBlockStatus(
    uint256 byProfileId,
    uint256[] calldata idsOfProfilesToSetBlockStatus,
    bool[] calldata blockStatus
) external override whenNotPaused onlyProfileOwnerOrDelegatedExecutor(msg.sender, byProfileId);
Parameters
| Name | Type | Description | 
|---|---|---|
| byProfileId | uint256 | The ID of the profile that is blocking/unblocking somebody. | 
| idsOfProfilesToSetBlockStatus | uint256[] | The array of IDs of profiles to set block status. | 
| blockStatus | bool[] | The array of block statuses to use for each (true is blocked). | 
setBlockStatusWithSig
function setBlockStatusWithSig(
    uint256 byProfileId,
    uint256[] calldata idsOfProfilesToSetBlockStatus,
    bool[] calldata blockStatus,
    Types.EIP712Signature calldata signature
) external override whenNotPaused onlyProfileOwnerOrDelegatedExecutor(signature.signer, byProfileId);
collectLegacy
Collects a given publication via signature with the specified parameters. Collect can have referrers (e.g. publications or profiles that allowed to discover the pointed publication).
function collectLegacy(Types.LegacyCollectParams calldata collectParams)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, collectParams.collectorProfileId)
    returns (uint256);
Parameters
| Name | Type | Description | 
|---|---|---|
| collectParams | Types.LegacyCollectParams | A CollectParams struct containing the parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint256 | uint256 An integer representing the minted token ID. | 
collectLegacyWithSig
function collectLegacyWithSig(
    Types.LegacyCollectParams calldata collectParams,
    Types.EIP712Signature calldata signature
)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, collectParams.collectorProfileId)
    returns (uint256);
act
Acts on a given publication with the specified parameters. You can act on a publication except a mirror (if it has at least one action module initialized). Actions can have referrers (e.g. publications or profiles that allowed to discover the pointed publication).
function act(Types.PublicationActionParams calldata publicationActionParams)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(msg.sender, publicationActionParams.actorProfileId)
    returns (bytes memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| publicationActionParams | Types.PublicationActionParams | A PublicationActionParams struct containing the parameters. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes | bytes Arbitrary data the action module returns. | 
actWithSig
function actWithSig(
    Types.PublicationActionParams calldata publicationActionParams,
    Types.EIP712Signature calldata signature
)
    external
    override
    whenNotPaused
    onlyProfileOwnerOrDelegatedExecutor(signature.signer, publicationActionParams.actorProfileId)
    returns (bytes memory);
isFollowing
EXTERNAL VIEW FUNCTIONS ///
function isFollowing(uint256 followerProfileId, uint256 followedProfileId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| followerProfileId | uint256 | The ID of the profile whose following state should be queried. | 
| followedProfileId | uint256 | The ID of the profile whose followed state should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if followerProfileIdis followingfollowedProfileId, false otherwise. | 
isDelegatedExecutorApproved
Returns whether the given address is approved as delegated executor, in the configuration with the given number, to act on behalf of the given profile.
function isDelegatedExecutorApproved(uint256 delegatorProfileId, address delegatedExecutor, uint64 configNumber)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to check the delegated executor approval for. | 
| delegatedExecutor | address | The address to query the delegated executor approval for. | 
| configNumber | uint64 | The number of the configuration where the executor approval state is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the address is approved as a delegated executor to act on behalf of the profile in the given configuration, false otherwise. | 
isDelegatedExecutorApproved
Returns whether the given address is approved as delegated executor, in the configuration with the given number, to act on behalf of the given profile.
function isDelegatedExecutorApproved(uint256 delegatorProfileId, address delegatedExecutor)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile to check the delegated executor approval for. | 
| delegatedExecutor | address | The address to query the delegated executor approval for. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the address is approved as a delegated executor to act on behalf of the profile in the given configuration, false otherwise. | 
getDelegatedExecutorsConfigNumber
Returns the current delegated executor config number for the given profile.
function getDelegatedExecutorsConfigNumber(uint256 delegatorProfileId) external view returns (uint64);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile from which the delegated executors config number is being queried | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint64 | uint256 The current delegated executor configuration number. | 
getDelegatedExecutorsPrevConfigNumber
Returns the previous used delegated executor config number for the given profile.
function getDelegatedExecutorsPrevConfigNumber(uint256 delegatorProfileId) external view returns (uint64);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile from which the delegated executors' previous configuration number set is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint64 | uint256 The delegated executor configuration number previously set. It will coincide with the current configuration set if it was never switched from the default one. | 
getDelegatedExecutorsMaxConfigNumberSet
Returns the maximum delegated executor config number for the given profile. This is the maximum config number that was ever used by this profile. When creating a new clean configuration, you can only use a number that is maxConfigNumber + 1.
function getDelegatedExecutorsMaxConfigNumberSet(uint256 delegatorProfileId) external view returns (uint64);
Parameters
| Name | Type | Description | 
|---|---|---|
| delegatorProfileId | uint256 | The ID of the profile from which the delegated executors' maximum configuration number set is being queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | uint64 | uint256 The delegated executor maximum configuration number set. | 
isBlocked
Returns whether profileId is blocked by byProfileId.
See setBlockStatus() for more information on how blocking works on the platform.
function isBlocked(uint256 profileId, uint256 byProfileId) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The ID of the profile whose blocked status should be queried. | 
| byProfileId | uint256 | The ID of the profile whose blocker status should be queried. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if profileIdis blocked bybyProfileId, false otherwise. | 
getContentURI
Returns the URI associated with a given publication. This is used to store the publication's metadata, e.g.: content, images, etc.
function getContentURI(uint256 profileId, uint256 pubId) external view override returns (string memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | string | string The URI associated with a given publication. | 
getProfile
Returns the full profile struct associated with a given profile token ID.
function getProfile(uint256 profileId) external view override returns (Types.Profile memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.Profile | Profile The profile struct of the given profile. | 
getPublication
Returns the full publication struct for a given publication.
function getPublication(uint256 profileId, uint256 pubId)
    external
    pure
    override
    returns (Types.PublicationMemory memory);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.PublicationMemory | Publication The publication struct associated with the queried publication. | 
isActionModuleEnabledInPublication
Returns wether a given Action Module is enabled for a given publication.
function isActionModuleEnabledInPublication(uint256 profileId, uint256 pubId, address module)
    external
    view
    returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
| module | address | The address of the Action Module to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | bool True if the Action Module is enabled for the queried publication, false if not. | 
getPublicationType
Returns the type of a given publication. The type can be one of the following (see PublicationType enum):
- Nonexistent
- Post
- Comment
- Mirror
- Quote
function getPublicationType(uint256 profileId, uint256 pubId) external view override returns (Types.PublicationType);
Parameters
| Name | Type | Description | 
|---|---|---|
| profileId | uint256 | The token ID of the profile that published the publication to query. | 
| pubId | uint256 | The publication ID of the publication to query. | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | Types.PublicationType | PublicationType The publication type of the queried publication. |