Skip to main content

Authentication

The concept of authentication in FCL is tied closely to FCL's concept of currentUser. In fact fcl.authenticate and fcl.unauthenticate are both aliases to fcl.currentUser.authenticate() and fcl.currentUser.unauthenticate() respectively. So let's look at currentUser.

As a dapp developer, using FCL, our current thought is to enable three main pieces of functionality.

  • How to know the currentUser and if they are logged in.
  • How to log a user in.
  • How to log a user out.

Due to the nature of how FCL works, logging a user in and signing a user up are the same thing.

Knowing things about the current user

FCL provides two ways of getting the current users information. One way is a promise that returns a snapshot of the info, while the other way allows you to subscribe to info, calling a callback function with the latest info anytime it changes.

Snapshot of Current User


_10
import * as fcl from "@onflow/fcl"
_10
_10
const currentUser = await fcl.currentUser.snapshot()
_10
console.log("The Current User", currentUser)

Subscribe to Current User


_10
import * as fcl from "@onflow/fcl"
_10
_10
// Returns an unsubscribe function
_10
const unsubscribe = fcl.currentUser.subscribe(currentUser => {
_10
console.log("The Current User", currentUser)
_10
})

Actually Authenticating and Unauthenticating

The TL;DR is to call fcl.authenticate() and fcl.unauthenticate() respectively.

On Flow mainnet, you wont even need to configure anything for this to work, the users of your dapp will go through the authentication process and be able to use any FCL compatible wallet providers.

During development you will probably want to configure your dapp to use @onflow/dev-wallet. The Quick Start guide will walk you through using it.

We know this can all be fairly overwhelming, we are committed to help though. If you run into any problems, reach out to us on Discord, we are more than happy to help out.