私はフラッターで作られた単純なゲームを持っていて、私はユーザーにログインすることができますが、ユーザーがログに記録されているかどうかを確認する方法と、ユーザーのデータを取得する方法はわかりません。
ログインするにはこのメソッドを使用している場合は、ユーザーにログインしてからデータを取得できます。
Future<String> signInWithGoogle() async{
print("INICIALIZANDO LOGIN COM GOOGLE...");
googleSignInAccount = await googleSignIn.signIn();
googleSignInAuthentication = await googleSignInAccount.authentication;
final AuthCredential credential = GoogleAuthProvider.getCredential(
accessToken: googleSignInAuthentication.accessToken,
idToken: googleSignInAuthentication.idToken,
);
AuthResult authResult = await _auth.signInWithCredential(credential);
user = authResult.user;
assert(!user.isAnonymous);
assert(await user.getIdToken() != null);
currentUser = await _auth.currentUser();
assert(user.uid == currentUser.uid);
uid = user.uid;
name = user.displayName;
email = user.email;
imageUrl = user.photoUrl;
print(uid);
print(email);
print(name);
print(imageUrl);
return 'signInWithGoogle succeded: $user';
}
_
そしてサインアウトのためにこれを:
void signOutGoogle() async{
print("DESLOGOU!");
await googleSignIn.signOut();
}
_
ユーザーがログインしているかどうかを確認している間に、私は空白のページであるルーツスクリーンを使用し、ユーザーはそれをほとんど見ません。これが私のコードです
class RootScreen extends StatefulWidget {
@override
State<StatefulWidget> createState() => new _RootScreenState();
}
class _RootScreenState extends State<RootScreen> {
@override
Widget build(BuildContext context) {
return new StreamBuilder<FirebaseUser>(
stream: FirebaseAuth.instance.onAuthStateChanged,
builder: (BuildContext context, snapshot) {
if (snapshot.connectionState == ConnectionState.waiting) {
return new Container(
color: Colors.white,
);
} else {
if (snapshot.hasData) {
//user is logged in
return new MainScreen(
firebaseUser: snapshot.data,
);
} else {
//user not logged in
return Login();
}
}
},
);
}
}
_
ユーザーデータを取得するために
class MainScreen extends StatelessWidget {
final GoogleSignInAccount googleUser;
final FirebaseUser firebaseUser;
const MainScreen(
{Key key, @required this.googleUser, @required this.firebaseUser})
: assert(googleUser != null),
assert(firebaseUser != null),
super(key: key);
@override
Widget build(BuildContext context) {
final theme = Theme.of(context);
return Scaffold(
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Offstage(
offstage: firebaseUser.photoUrl == null,
child: CircleAvatar(
backgroundImage: NetworkImage(firebaseUser.photoUrl)),
),
SizedBox(height: 8.0),
Text(firebaseUser.displayName, style: theme.textTheme.title),
Text(firebaseUser.email),
Text(firebaseUser.phoneNumber, style: theme.textTheme.subhead),
SizedBox(height: 16.0),
FlatButton(
child: Text("Sign out", style: theme.textTheme.button),
onPressed: () async {
await GoogleSignIn().signOut();
await FirebaseAuth.instance.signOut();
Navigator.of(context).pushAndRemoveUntil(
CupertinoPageRoute(builder: (context) => AuthScreen()),
(route) => false,
);
},
)
],
),
),
);
}
}
_