Implementing AutoFill Credential Provider Extensions
Implementing AutoFill Credential Provider Extensions
WWDC 2018
data:image/s3,"s3://crabby-images/006e2/006e23645817e2f84c2b9693395943d98d75598f" alt=""
data:image/s3,"s3://crabby-images/7f2f6/7f2f679d789492b025659d3e9d3a7763beb800e2" alt=""
data:image/s3,"s3://crabby-images/e7537/e7537bd07e71d4d09becb1a35e4c5d6be1a57855" alt=""
data:image/s3,"s3://crabby-images/9297c/9297c35867cae4581ec7994ef63876a0f3745517" alt=""
Password AutoFill Integration
- Configure your project
- Implement a credential list
- Show credentials in the QuickType bar
- Allow users to configure your extension in Settings
Step1: Configure Your Project
data:image/s3,"s3://crabby-images/9fc00/9fc00b7e291b1b90c57f04c8d3b99bd7a6797010" alt=""
data:image/s3,"s3://crabby-images/04c22/04c221b74e317cac38e7a57acda767ee4aea95a8" alt=""
data:image/s3,"s3://crabby-images/c00ff/c00ffbaecd8ebaf6d8dcef78a7ee36fa922061bb" alt=""
Step2: Implement a credential list
data:image/s3,"s3://crabby-images/21dd0/21dd00fb829ef866db695805f098625f1ac1dafd" alt=""
data:image/s3,"s3://crabby-images/5ef1e/5ef1e7d4632ea35f18b244bab9de52997c1ba3b7" alt=""
data:image/s3,"s3://crabby-images/dac1c/dac1ccb5519eb4e8364ea30b08ebb439f0a7a611" alt=""
data:image/s3,"s3://crabby-images/a796d/a796df024eafbf6c172a332e37ef4228288e41a5" alt=""
data:image/s3,"s3://crabby-images/ae7a2/ae7a24e264798af760b19ac65e401283a6ab9dee" alt=""
Best Practice
- Add a cancel button
- Allow users to see all their credentials
- Authenticate the user if needed
Step3: Show credentials in the QuickType bar
data:image/s3,"s3://crabby-images/2fc23/2fc2362932ca5bef799f264fd7fc3eb22c1ff096" alt=""
What you need to do
- Provide credential identities to AutoFill
- Return passwords from extension
- Show custom authentication UI (optional)
Provide credential identities to AutoFill
data:image/s3,"s3://crabby-images/eb878/eb8787d96302fa584b58865c8265456be627c55d" alt=""
Use the credential identity store
- Secure, never leaves device
- Writable only by your app and extension
- Read only by AutoFill
- Modifiable only when extension is enabled
- Update the store as needed
- New credentials are available
- Credentials are modified
- Credentials are no longer available
data:image/s3,"s3://crabby-images/99d61/99d616b32559b05c6f18abaad344ea24a42098e2" alt=""
- The store may be unexpectedly deleted
- Extension is disabled, re-enabled
- App provides stale credential identities
- User restores from backup ASCredentialIdentityStore
can help
data:image/s3,"s3://crabby-images/c9ef9/c9ef973210d6a03eb7bfca0af062f40598d4a605" alt=""
data:image/s3,"s3://crabby-images/6781c/6781c57c29333f5422d58964fec4c26c50ce8011" alt=""
data:image/s3,"s3://crabby-images/01396/01396ca105117172781667384c5915bf72eab1f0" alt=""
Provide passwords from your extension
- Respond to the initial request quickly
- Users don’t see your UI yet
- AutoFill will cancel the request after a timeout
- Except simulator and debug builds
Best practices
- Keep the credential identity store up-to-date
- Use
ASCredentialIdentityStore
incremental update APIs - Keep extension UI to a minimum
- Avoid expensive setup in every
viewDidLoad()
Step4: Allow Users to Configure Your Extension in Settings
- Your extension may require additional setup after being enabled
- Provide credential identities for QuickType
- Sign user into online service
- Get user authentication or confirmation for QuickType - AuthenticationServices provides API for this
data:image/s3,"s3://crabby-images/e244c/e244c2e4b784620948d2928d66d942e6f35c2dcc" alt=""
data:image/s3,"s3://crabby-images/714a4/714a4091751a14cf2a49d092c727ed22e0eaa81d" alt=""
Extension Development ⚠️
Best practices
- User separate view controllers
- Present or user view controller containment
data:image/s3,"s3://crabby-images/fcdd3/fcdd3c46aeee58ddf9395e4528a57cb17bab70b9" alt=""
- Extensions should be lightweight
- Use App Groups, shared keychains
Debugging AutoFill Credential Provider extensions
Use “Debug” > Attach to Process” for other cases
Use Safari to test filling credentials
1. Select your extension’s scheme
data:image/s3,"s3://crabby-images/fe34c/fe34c18beef9598db5e0753549af5663595a3e7e" alt=""
2. Run with Safari as a target
data:image/s3,"s3://crabby-images/eee17/eee17e85c1761dd1176ec0d0a87be516a1a062ae" alt=""
3. Invoke your extension
data:image/s3,"s3://crabby-images/e5705/e570561612681fc255e732fe9721649bc3955591" alt=""