A Flutter wrapper for Appwrite's Accounts service, makes it easy to use manage authentication and account features.
This is really very easy to use
dependencies:
appwrite_auth_kit: <version>
AppwriteAuthKit
passing 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(),
),
);
}
}
authNotifier
from context
. authNotifier
is an instance of AuthNotifier
that provides all the functions of Appwrite's Account service and some easy way to handle authentication.context.authNotifier.status
gets the authentication status which can be one of the AuthStatus.uninitialized
, AuthStatus.unauthenticated
, AuthStatus.authenticating
and AuthStatus.authenticated
. You can check the status and display the appropriate UI, for exampleclass 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;
}
}
context.authNotifier
instead default Account service from Appwrite SDK to create user, create session (login), delete session (logout), so that the context.authNotifier?.status
is properly updated and your UI updates accordingly.