Skip to main content

Access Control

With the exception of the admin functions, all functionalities in Sablier can only be triggered by users. The Protocol Admin has no control over any stream or any part of the protocol.

This article will provide a comprehensive overview of the actions that can be performed on streams once they are created, as well as the corresponding user permissions for each action.

note

Every stream has a sender and a recipient. Recipients can approve third parties to take actions on their behalf. An 'unknown' caller is any address outside of sender and recipient.

Overview

The table below offers a quick overview of the access control for each action that can be performed on a stream.

ActionSenderRecipient / Approved third partyUnknown Caller
Burn NFT
Cancel
Cancel Multiple
Renounce
Transfer NFT
Withdraw to recipient
Withdraw to any address
Withdraw Multiple

Burn NFT

Either the recipient or an approved operator can burn the NFT associated with a stream.

Cancel

Only the sender can cancel a stream.

Cancel Multiple

Only the sender can cancel multiple streams.

Renounce

Only the sender can renounce a stream.

Transfer NFT

Either the recipient or an approved operator can transfer the NFT associated with a stream.

  • Only if the stream is transferable.

Withdraw Multiple

Anybody can withdraw assets from multiple streams to the recipients of each stream.

Withdraw to Any Address

The assets in a stream can be withdrawn to any address only by the recipient or an approved third party.

Withdraw to Recipient

The assets in a stream can be withdrawn to the recipient by anyone including the sender, recipient, or an approved third party.