Skip to content
This repository was archived by the owner on Feb 22, 2023. It is now read-only.

Conversation

@collinjackson
Copy link
Contributor

@collinjackson collinjackson commented Jul 26, 2019

Description

This change adds new AuthResult and AdditionalUserInfo classes, bringing the API in line with how things work on Android. We don't expose the credential on the AuthResult class (yet).

This is a Breaking Change because sign-in methods now return AuthResult instead of FirebaseUser. Pretty much every user of this plugin will have to update their code. We're getting this out of the way prior to 1.0.

Related Issues

This change should be landed instead of #1614

Another breaking change that should land at the same time: #1871

Checklist

Before you create this PR confirm that it meets all requirements listed below by checking the relevant checkboxes ([x]). This will ensure a smooth and quick review process.

  • I read the [Contributor Guide] and followed the process outlined there for submitting PRs.
  • My PR includes unit or integration tests for all changed/updated/fixed behaviors (See [Contributor Guide]).
  • All existing and new tests are passing.
  • I updated/added relevant documentation (doc comments with ///).
  • The analyzer (flutter analyze) does not report any problems on my PR.
  • I read and followed the [Flutter Style Guide].
  • The title of the PR starts with the name of the plugin surrounded by square brackets, e.g. [shared_preferences]
  • I updated pubspec.yaml with an appropriate new version according to the [pub versioning philosophy].
  • I updated CHANGELOG.md to add a description of the change.
  • I signed the [CLA].
  • I am willing to follow-up on review comments in a timely manner.

Breaking Change

Does your PR require plugin users to manually update their apps to accommodate your change?

  • Yes, this is a breaking change (please indicate a breaking change in CHANGELOG.md and increment major revision).
  • No, this is not a breaking change.

@collinjackson collinjackson requested a review from kroikie as a code owner July 26, 2019 02:23
@collinjackson collinjackson changed the title Sign-in methods now return AuthResult instead of FirebaseUser. [firebase_auth] Sign-in methods now return AuthResult instead of FirebaseUser. Jul 26, 2019
Copy link
Contributor

@kroikie kroikie left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, with small readability nit.

FirebaseUser user = await auth.currentUser();
user = await user.linkWithCredential(credential);
AuthResult result = await user.linkWithCredential(credential);
user = result.user;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In some cases the user is extracted in one statement and in other cases it is extracted in two statements. Maybe it would be more readable to keep it consistent.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good call. I've updated the tests. In the process I wrote some more tests of the new code I added and fixed some issues (I had missed reauthenticate on my first pass, and the getter for profile lacked an appropriate cast)

@collinjackson collinjackson changed the title [firebase_auth] Sign-in methods now return AuthResult instead of FirebaseUser. [firebase_auth] Update auth methods to return AuthResult instead of FirebaseUser Jul 28, 2019
@collinjackson collinjackson merged commit 533ee02 into flutter:master Jul 28, 2019
@collinjackson collinjackson deleted the auth_authresult branch July 28, 2019 02:17
mithun-mondal pushed a commit to bKash-developer/archived_plugins that referenced this pull request Aug 6, 2019
…irebaseUser (flutter#1911)

* Sign-in methods now return `AuthResult` instead of `FirebaseUser`.

* Change `reauthenticateWithCredential` to return AuthResult as well

* Update tests
julianscheel pushed a commit to jusst-engineering/plugins that referenced this pull request Mar 11, 2020
…irebaseUser (flutter#1911)

* Sign-in methods now return `AuthResult` instead of `FirebaseUser`.

* Change `reauthenticateWithCredential` to return AuthResult as well

* Update tests
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants