mirror of
https://github.com/bitwarden/android.git
synced 2025-01-11 18:57:39 +03:00
provide credential implementations
This commit is contained in:
parent
cc9a4a288a
commit
2732fc93f9
2 changed files with 73 additions and 3 deletions
|
@ -21,7 +21,7 @@ namespace Bit.iOS.Autofill
|
||||||
{
|
{
|
||||||
public partial class CredentialProviderViewController : ASCredentialProviderViewController
|
public partial class CredentialProviderViewController : ASCredentialProviderViewController
|
||||||
{
|
{
|
||||||
private Context _context = new Context();
|
private Context _context;
|
||||||
private bool _setupHockeyApp = false;
|
private bool _setupHockeyApp = false;
|
||||||
private IGoogleAnalyticsService _googleAnalyticsService;
|
private IGoogleAnalyticsService _googleAnalyticsService;
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@ namespace Bit.iOS.Autofill
|
||||||
SetIoc();
|
SetIoc();
|
||||||
SetCulture();
|
SetCulture();
|
||||||
base.ViewDidLoad();
|
base.ViewDidLoad();
|
||||||
|
_context = new Context();
|
||||||
_context.ExtContext = ExtensionContext;
|
_context.ExtContext = ExtensionContext;
|
||||||
_googleAnalyticsService = Resolver.Resolve<IGoogleAnalyticsService>();
|
_googleAnalyticsService = Resolver.Resolve<IGoogleAnalyticsService>();
|
||||||
|
|
||||||
|
@ -90,11 +91,57 @@ namespace Bit.iOS.Autofill
|
||||||
public override void ProvideCredentialWithoutUserInteraction(ASPasswordCredentialIdentity credentialIdentity)
|
public override void ProvideCredentialWithoutUserInteraction(ASPasswordCredentialIdentity credentialIdentity)
|
||||||
{
|
{
|
||||||
base.ProvideCredentialWithoutUserInteraction(credentialIdentity);
|
base.ProvideCredentialWithoutUserInteraction(credentialIdentity);
|
||||||
|
|
||||||
|
bool canGetCredentials = false;
|
||||||
|
var authService = Resolver.Resolve<IAuthService>();
|
||||||
|
if (authService.IsAuthenticated)
|
||||||
|
{
|
||||||
|
var lockService = Resolver.Resolve<ILockService>();
|
||||||
|
var lockType = lockService.GetLockTypeAsync(false).GetAwaiter().GetResult();
|
||||||
|
canGetCredentials = lockType == App.Enums.LockType.None;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!canGetCredentials) {
|
||||||
|
var err = new NSError(new NSString("ASExtensionErrorDomain"),
|
||||||
|
Convert.ToInt32(ASExtensionErrorCode.UserInteractionRequired), null);
|
||||||
|
ExtensionContext.CancelRequest(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_context.CredentialIdentity = credentialIdentity;
|
||||||
|
ProvideCredential();
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void PrepareInterfaceToProvideCredential(ASPasswordCredentialIdentity credentialIdentity)
|
public override void PrepareInterfaceToProvideCredential(ASPasswordCredentialIdentity credentialIdentity)
|
||||||
{
|
{
|
||||||
base.PrepareInterfaceToProvideCredential(credentialIdentity);
|
var authService = Resolver.Resolve<IAuthService>();
|
||||||
|
if (!authService.IsAuthenticated)
|
||||||
|
{
|
||||||
|
var alert = Dialogs.CreateAlert(null, AppResources.MustLogInMainApp, AppResources.Ok, (a) =>
|
||||||
|
{
|
||||||
|
CompleteRequest();
|
||||||
|
});
|
||||||
|
PresentViewController(alert, true, null);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_context.CredentialIdentity = credentialIdentity;
|
||||||
|
var lockService = Resolver.Resolve<ILockService>();
|
||||||
|
var lockType = lockService.GetLockTypeAsync(false).GetAwaiter().GetResult();
|
||||||
|
switch (lockType)
|
||||||
|
{
|
||||||
|
case App.Enums.LockType.Fingerprint:
|
||||||
|
PerformSegue("lockFingerprintSegue", this);
|
||||||
|
break;
|
||||||
|
case App.Enums.LockType.PIN:
|
||||||
|
PerformSegue("lockPinSegue", this);
|
||||||
|
break;
|
||||||
|
case App.Enums.LockType.Password:
|
||||||
|
PerformSegue("lockPasswordSegue", this);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
ProvideCredential();
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void PrepareInterfaceForExtensionConfiguration()
|
public override void PrepareInterfaceForExtensionConfiguration()
|
||||||
|
@ -169,8 +216,30 @@ namespace Bit.iOS.Autofill
|
||||||
{
|
{
|
||||||
DismissViewController(false, () =>
|
DismissViewController(false, () =>
|
||||||
{
|
{
|
||||||
|
if(_context.CredentialIdentity != null) {
|
||||||
|
ProvideCredential();
|
||||||
|
return;
|
||||||
|
}
|
||||||
PerformSegue("loginListSegue", this);
|
PerformSegue("loginListSegue", this);
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ProvideCredential()
|
||||||
|
{
|
||||||
|
var cipherService = Resolver.Resolve<ICipherService>();
|
||||||
|
var cipher = cipherService.GetByIdAsync(_context.CredentialIdentity.RecordIdentifier).GetAwaiter().GetResult();
|
||||||
|
if (cipher == null || cipher.Type != App.Enums.CipherType.Login)
|
||||||
|
{
|
||||||
|
var err = new NSError(new NSString("ASExtensionErrorDomain"),
|
||||||
|
Convert.ToInt32(ASExtensionErrorCode.CredentialIdentityNotFound), null);
|
||||||
|
ExtensionContext.CancelRequest(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
CompleteRequest(
|
||||||
|
cipher.Login.Username?.Decrypt(cipher.OrganizationId),
|
||||||
|
cipher.Login.Password?.Decrypt(cipher.OrganizationId),
|
||||||
|
cipher.Login.Totp?.Decrypt(cipher.OrganizationId));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetIoc()
|
private void SetIoc()
|
||||||
|
|
|
@ -7,6 +7,7 @@ namespace Bit.iOS.Autofill.Models
|
||||||
public class Context : AppExtensionContext
|
public class Context : AppExtensionContext
|
||||||
{
|
{
|
||||||
public NSExtensionContext ExtContext { get; set; }
|
public NSExtensionContext ExtContext { get; set; }
|
||||||
public ASCredentialServiceIdentifier[] ServiceIdentifiers { get; set; }
|
public ASCredentialServiceIdentifier[] ServiceIdentifiers { get; set; }
|
||||||
|
public ASPasswordCredentialIdentity CredentialIdentity { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue