ios-client-sdk icon indicating copy to clipboard operation
ios-client-sdk copied to clipboard

Feature flag values are inaccessible from extensions that don't have network access

Open jayhickey opened this issue 11 months ago • 2 comments

Describe the bug

I have an app with a Safari extension and it can't access any LaunchDarkly feature flag values. Safari extensions don't have network access and the SDK is caching flags in a custom user default suite that is inaccessible from app extensions. This is non-configurable from what I can tell (this protocol and implementation is internal):

https://github.com/launchdarkly/ios-client-sdk/blob/cb42f92df22a3d17fb165f5c0241e8f75f6c81a6/LaunchDarkly/LaunchDarkly/ServiceObjects/Cache/FeatureFlagCache.swift#L23

https://github.com/launchdarkly/ios-client-sdk/blob/cb42f92df22a3d17fb165f5c0241e8f75f6c81a6/LaunchDarkly/LaunchDarkly/ServiceObjects/ClientServiceFactory.swift#L28-L30

There should be some way to configure this UserDefaults suite to point to the app group ID so extensions can also read from the defaults.

Am I overlooking something? How can I access cached LD flags from extensions that don't have network access?

To reproduce

  1. Create an iOS app that has a main app target and a Safari extension.
  2. Set up the LDClient in both the main app and the extension.
  3. Launch the main app and log the allFlags value from the client.
  4. Launch the Safari extension target and log the allFlags value from the client.
  5. Observe that the Safari extension doesn't have any of the fetched or cached flag values from the main app target—it only has the default fallback values.

Expected behavior Flag values fetched from the main app should be cached in such a way that extension targets can also access the cached values.

SDK version 9.0.0

Language version, developer tools Xcode 14.3.1

OS/platform iOS 16.6

jayhickey avatar Aug 04 '23 18:08 jayhickey