Authentication
In this section, we have created a simple Twitter clone and discuss how authentication is implemented in both Solidity and Rell.
Solidity
In Solidity, authentication is inherently built into the language. By using msg.sender
, you can get the address of the
entity (person or contract) that initiated the current function call. This is commonly used to authenticate and
authorize function calls.
For example, to add a post to a user's account:
function createPost(string memory _text) public {
Post memory newPost = Post(_text, block.timestamp);
users[msg.sender].posts.push(newPost);
}
You can also restrict access to certain functions by using msg.sender
. For instance, administrative functions can be
restricted to the contract deployer using the require function:
require(msg.sender == owner, "Only the owner can call this function.");
Rell
In Rell, authentication is handled using the FT4 library. It operates similarly to Solidity's msg.sender
but requires
setting up an authentication handler. You have to use auth.authenticate()
to authenticate and fetch the user. Note
that a user must be registered in the dapp before you can call the auth.authenticate()
operation.
First, set up the auth handler as an extension:
import lib.ft4.auth;
@extend(auth.auth_handler)
function () = auth.add_auth_handler(
flags = ["MySession"]
);
Here's an example of how to modify a create_post
operation with authentication in Rell:
entity user {
mutable name;
key id: byte_array;
key account: byte_array;
}
operation create_post(user_id : byte_array, content: text) {
var account = auth.authenticate();
create Post ( user @ { account }, content = content );
}
Just like in Solidity, the authentication process in Rell is straightforward and integrates seamlessly into the code.
For owner-specific operations, you can define an owner user in your blockchain configuration and use require
to
enforce restrictions:
require(op_context.is_signer(owner), "Only the owner can call this operation");
Both Solidity and Rell provide efficient ways to handle authentication:
- Solidity: Uses msg.sender for authentication and authorization.
- Rell: Utilizes the FT4 library for authentication, with
auth.authenticate()
to fetch the authenticated user.
You can learn more about FT4 and Authentication in Rell here.