Better Apps Through Better Privacy
Better Apps Through Better Privacy
WWDC 2018
Privacy Is About People
- Build trust with your users
- Respect users in handling their data
- Apply privacy thinking to engineering decisions
Ask Questions about Data
- Why do we need this data ?
- Would this surprise our users ?
- Could we use less granular data ?
- How long do we need this data ?
data:image/s3,"s3://crabby-images/94456/944566086ad902c5078d6baf04d997280b982dae" alt=""
data:image/s3,"s3://crabby-images/441e2/441e217711d10a4df73a6953ab2dc2ff236830d6" alt=""
Recognize Data Assumptions 😡
- “Of course we should log this for all users.”
- “This data couldn’t possibly be sensitive.”
- “It’s fine to apply this data in a new use case.”
- “There’s no PII, so don’t worry about it.”
- “We already protect this with encryption.”
Create Privacy Guarantees 😆
- Write high-level statements about privacy expectations
- Decide in planning, verify in implementation
- Examples:
- “We can’t read your messages in transit between devices.”
- “Analytics data doesn’t identify you personally.”
- “We only retain aggregate usage data.”
Handle Data with Caution
- Data brings power 💪 — and danger ⚠️
- Gathering data adds overhead and liability
- Unexpected data adds more risks and distrust
data:image/s3,"s3://crabby-images/f8ba9/f8ba9e133a2f3d423fdd266d44b3eedaac850ca0" alt=""
Use Proportional Data Collection
- Collect only what is needed to achieve the goal
- Collect consistently with user expectations
- Don’t collect without a clear reason 😱
Use Privacy Techniques
- Develop a toolbox
- Adjust to match use case
- Apply across systems
- Build technical enforcements
data:image/s3,"s3://crabby-images/6c95d/6c95dc40f8be4c45428bd1d297c787be3df18372" alt=""
Big Ideas to Remember
- Privacy is about people
- Ask the “should” questions
- Align data practices with use cases
Building Privacy in Your App
- Accessing User Data
- Data Stewardship
Use Out-of-Process Pickers
- Available for Contacts, Camera, and Photos
- Will not trigger a permission prompt
- Default method for accessing data
data:image/s3,"s3://crabby-images/fbcbf/fbcbf4f45dc14540b89aef7331f731539059be72" alt=""
Protected Resources
data:image/s3,"s3://crabby-images/cf48a/cf48a068488c6f47b1c64dfeb903930a928d0929" alt=""
Requesting Access
- Only what you need
- Only when you need it
- Only rely on the API for status
data:image/s3,"s3://crabby-images/ba60d/ba60d0b2d62cecb7e481adc9c3ae0e9b0763084d" alt=""
Include Purpose Strings
- Required for requesting access
- One method for transparency
- Explains the reason for a request
data:image/s3,"s3://crabby-images/a01da/a01da168446c86e415515b7b1940fb373d3ef79f" alt=""
Unhelpful Purpose Strings 😡
- “”
- “_”
- “true”
- “NSLocationAlwaysUsageDescription”
- “Advertising”
- “This app requires location”
- “Used to provide you more relevant content”
Helpful Purpose Strings 😊
data:image/s3,"s3://crabby-images/8ace7/8ace7798b02d8a60cb000122a47c7f28553be026" alt=""
data:image/s3,"s3://crabby-images/e3101/e31019c1e834979164e25b4a7551022072c44dee" alt=""
data:image/s3,"s3://crabby-images/07683/076838ccd5bbfb183d09b1c987150c62fd136c14" alt=""
Managing Access
- Apps should not require access to protected resources
- Build fallbacks if user declines access
- Verify in case user revokes access
- Stay aware of 3rd-party SDKs
- Provide ongoing transparency
WiFi Network Information (new)
- Now requires AccessWiFiInformation capability
- Used to check if an accessory is on the network
- Enable only when necessary for your use case
Health Records (new)
Protected Resources (new)
data:image/s3,"s3://crabby-images/39bc9/39bc9c528d29abaa5efb9aa270100c85c8954d29" alt=""
Protected Resources (new)
- Access to resources may now trigger a prompt
- Prompts apply to any 3rd-party app process
- Includes apps outside the App Store
- Purpose strings will be required
- Your Apps and the Future of macOS Security ( WWD 2018 )
data:image/s3,"s3://crabby-images/6ddeb/6ddeba9a528a047d0298fb9c0687bfd9bc605b82" alt=""
Storage Access API
- Engage with logged-in content from embedded 3rd — parties
- Including from domains classified as trackers
data:image/s3,"s3://crabby-images/7f115/7f115dd00e37f5f9d52ffd1300baa23972ee7b41" alt=""
data:image/s3,"s3://crabby-images/4e11c/4e11c08a20bb12bb5582afec17fbb8f8495359a7" alt=""
Intelligent Tracking Prevention 2.0
Cookies from domains classified as trackers partitioned immediately
data:image/s3,"s3://crabby-images/ade26/ade26500c76b93a48102ccaa007295fe759a4280" alt=""
data:image/s3,"s3://crabby-images/dcd33/dcd33ed12532abe8b4d2556d2e840f6fffe18440" alt=""
Data Stewardship
- Deletion
- Device Tracking
- 3rd-Party Partners
- Machine Learning
Clean Up Deleted Data
- Recognize data flow going outside your app
- Ensure consistency across systems
- Update data shared with Operating System
- Siri Shortcuts
- Notifications
- Passwords
data:image/s3,"s3://crabby-images/b5c48/b5c482e3d3b22e411f3c908809f670d9a1048106" alt=""
Siri Shortcuts
INInteraction
data:image/s3,"s3://crabby-images/97161/97161ac0207520afc8251fff0855722e11d82e63" alt=""
Notifications
UNUserNotificationCenter
data:image/s3,"s3://crabby-images/31329/3132906515955e438427904ad878363ced65afbe" alt=""
Passwords
ASCredentialIdentityStore
data:image/s3,"s3://crabby-images/284dd/284dd82992e5c1cfcc71f0886a9c992b2b51db23" alt=""
Device Tracking
You Might Want to Know…
- Did this device already consume a free trial ?
- Has this device paid for content but not linked that purchase to an account ?
- Was this device previously used by an abusive user ?
- Was this device previously used for fraudulent activities ?
DeviceCheck
- Set 2 bits of data per device
- Stored by Apple with timestamp
- Persist across reset or erase install
- Do not rely on unsupported device tracking methods
- Continuing to remove entropy (unique device attributes)
- Continuing to remove functionality being abused to uniquely identify users
data:image/s3,"s3://crabby-images/b0b3b/b0b3b032f1e2e3b0e633257b7d7bffac6c9581d5" alt=""
3rd-Party Code
- You’re responsible for all code in your app
- Understand data access or transfers
- Be complete when giving transparency
- Avoid unnecessary requests for resources
3rd-Party Vendors
- Data flow to 3rd parties from yours servers
- Know your partners’ data practices
- Be transparent about all use cases
Face ID
- Built with privacy-friendly machine learning
- Easy to add Face ID authentication to your app
- Use the LocalAuthentication framework
data:image/s3,"s3://crabby-images/47d23/47d23c6458fa95b2743dbd18b25813f077b2ecf6" alt=""
ARKit 2
- Uses machine learning to model the environment
- Create, persist, and share map of environment
- Collect this map only if needed for your feature
- Use MultipeerConnectivity API for end-to-end encryption
data:image/s3,"s3://crabby-images/e35cc/e35cc1fc2f8ccc527baa38965833bb91d6760bff" alt=""
Create ML + Core ML 2
- Easier than ever to add on-device machine learning to your app
- Train models on your Mac
- Evaluate models on your user’s device
- Avoid collecting sensitive user data
data:image/s3,"s3://crabby-images/895b1/895b1579f95af7e573a802c4a5dd7d3574bc89bc" alt=""
Does my model reveal training data ?
data:image/s3,"s3://crabby-images/94f7f/94f7fce4a27837167a8979b3df2a365cd7461d64" alt=""
Can I infer more about my users than they expected?
data:image/s3,"s3://crabby-images/c6710/c6710dc0cec50bca64fcc231c0113cdb52eb03bf" alt=""
Mitigations
- Ensure you train on the right data
- Keep model complexity proportional to goal