mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-04 06:20:26 +00:00
Check JWT username
This commit is contained in:
parent
36e23c67c2
commit
430027e895
1 changed files with 17 additions and 5 deletions
|
@ -384,6 +384,9 @@ public class FragmentOAuth extends FragmentBase {
|
||||||
String personal = args.getString("personal");
|
String personal = args.getString("personal");
|
||||||
String address = args.getString("address");
|
String address = args.getString("address");
|
||||||
|
|
||||||
|
EmailProvider provider = EmailProvider.getProvider(context, id);
|
||||||
|
String aprotocol = (provider.imap.starttls ? "imap" : "imaps");
|
||||||
|
|
||||||
if (jwt != null) {
|
if (jwt != null) {
|
||||||
// https://docs.microsoft.com/en-us/azure/active-directory/develop/id-tokens
|
// https://docs.microsoft.com/en-us/azure/active-directory/develop/id-tokens
|
||||||
String[] segments = jwt.split("\\.");
|
String[] segments = jwt.split("\\.");
|
||||||
|
@ -394,8 +397,20 @@ public class FragmentOAuth extends FragmentBase {
|
||||||
JSONObject jpayload = new JSONObject(payload);
|
JSONObject jpayload = new JSONObject(payload);
|
||||||
if (jpayload.has("email")) {
|
if (jpayload.has("email")) {
|
||||||
String email = jpayload.getString("email");
|
String email = jpayload.getString("email");
|
||||||
if (!TextUtils.isEmpty(email))
|
if (!TextUtils.isEmpty(email) && !email.equals(address)) {
|
||||||
address = email;
|
try (EmailService iservice = new EmailService(
|
||||||
|
context, aprotocol, null, false, EmailService.PURPOSE_CHECK, true)) {
|
||||||
|
iservice.connect(
|
||||||
|
provider.imap.host, provider.imap.port,
|
||||||
|
EmailService.AUTH_TYPE_OAUTH, provider.id,
|
||||||
|
email, state,
|
||||||
|
null, null);
|
||||||
|
address = email;
|
||||||
|
Log.i("jwt email=" + email);
|
||||||
|
} catch (Throwable ex) {
|
||||||
|
Log.w(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
Log.e(ex);
|
Log.e(ex);
|
||||||
|
@ -418,12 +433,9 @@ public class FragmentOAuth extends FragmentBase {
|
||||||
for (Pair<String, String> identity : identities)
|
for (Pair<String, String> identity : identities)
|
||||||
Log.i("OAuth identity=" + identity.first + "/" + identity.second);
|
Log.i("OAuth identity=" + identity.first + "/" + identity.second);
|
||||||
|
|
||||||
EmailProvider provider = EmailProvider.getProvider(context, id);
|
|
||||||
|
|
||||||
List<EntityFolder> folders;
|
List<EntityFolder> folders;
|
||||||
|
|
||||||
Log.i("OAuth checking IMAP provider=" + provider.id);
|
Log.i("OAuth checking IMAP provider=" + provider.id);
|
||||||
String aprotocol = (provider.imap.starttls ? "imap" : "imaps");
|
|
||||||
try (EmailService iservice = new EmailService(
|
try (EmailService iservice = new EmailService(
|
||||||
context, aprotocol, null, false, EmailService.PURPOSE_CHECK, true)) {
|
context, aprotocol, null, false, EmailService.PURPOSE_CHECK, true)) {
|
||||||
iservice.connect(
|
iservice.connect(
|
||||||
|
|
Loading…
Reference in a new issue