Access

Open up Aft and navigate to the Access section.

Click on the role labeled User.

This is the default role for a signed in user, though of course you can change that to suit your application's needs. Starting out, the User role is granted access to some of the login methods, the API methods, and to read and update their own user object.

You should see an Add button under Models. Click that, and select Todo from the dropdown.

This grants access to all Todos to the user role, which is too broad.

Click Detail to expand the policy editor. You should see three sections, labeled Read Create and Update.

Under each, add the following policy.

{
"user": {"id": "$USER_ID"}
}

This indicates that a user can create, read or update only their own Todos.

Hit Save to update the permissions for this role.

Roles#

Let's connect our test user with the role we just created. Ordinarily this connection would be done by the Signup RPC, but since we created this user by ourselves in the terminal, we'll just do it by hand.

Start by going to the Terminal and run the following update statement.

def main():
return update("user", {
"where": {"email": "user@example.com"},
"data": {"role": {"connect": {"name":"user"}}}
})

Restart Aft as before, but this time with access controls enabled.

aft -db ./tutorial.dbl -authed=true -serve_dir=client

If you open up Aft, you'll notice that no data is displayed, since we don't have access rights to read the schema or other Aft resources. But test out the Todo app, and you should see that everything works!

Congrats on building your first app with Aft!

In the last section, we'll review what we've gone over in this tutorial.