Back to Projects
Appwrite Auth Kit
Making Appwrite authentication easy for Flutter Developers.
Stay in Touch
Share
A Flutter wrapper for Appwrite's Accounts service, makes it easy to use manage authentication and account features.
Getting Started
This is really very easy to use
- Add dependency
 
dependencies:
    appwrite_auth_kit: <version>
- Wrap your MaterialApp 
AppwriteAuthKitpassing a properly initialized Appwrite Client. Example below: 
class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
  late Client client;
  @override
  void initState() {
    super.initState();
    //initialize your client
    client = Client();
    client
        .setEndpoint('https://localhost/v1')
        .setProject('60793ca4ce59e')
        .setSelfSigned();
  }
  @override
  Widget build(BuildContext context) {
    return AppwriteAuthKit(
      client: client,
      child: MaterialApp(
        title: 'Flutter Demo',
        theme: ThemeData(
          primarySwatch: Colors.blue,
        ),
        home: MainScreen(),
      ),
    );
  }
}
- Access 
authNotifierfromcontext.authNotifieris an instance ofAuthNotifierthat provides all the functions of Appwrite's Account service and some easy way to handle authentication. - Get 
context.authNotifier.statusgets the authentication status which can be one of theAuthStatus.uninitialized,AuthStatus.unauthenticated,AuthStatus.authenticatingandAuthStatus.authenticated. You can check the status and display the appropriate UI, for example 
class MainScreen extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final authNotifier = context.authNotifier;
    Widget widget;
    switch (authNotifier.status) {
      case AuthStatus.authenticated:
        widget = AdminPage();
        break;
      case AuthStatus.unauthenticated:
      case AuthStatus.authenticating:
        widget = LoginPage();
        break;
      case AuthStatus.uninitialized:
      default:
        widget = LoadingPage();
        break;
    }
    return widget;
  }
}
- You must use the functions from the 
context.authNotifierinstead default Account service from Appwrite SDK to create user, create session (login), delete session (logout), so that thecontext.authNotifier?.statusis properly updated and your UI updates accordingly.