about summary refs log tree commit diff
path: root/src/lib/bitdrift.ts
diff options
context:
space:
mode:
authordan <dan.abramov@gmail.com>2024-12-13 17:14:41 +0000
committerGitHub <noreply@github.com>2024-12-13 17:14:41 +0000
commite2a7965e438db9f70d76d2d7a911aa4c4a42c122 (patch)
treed75b04cf03ad3300feb221341580cca36a9c7005 /src/lib/bitdrift.ts
parent5655241bef22264ad9da3d9ba2074af4e9ba7dd0 (diff)
downloadvoidsky-e2a7965e438db9f70d76d2d7a911aa4c4a42c122.tar.zst
Gate bitdrift integration (#7088)
* Move Statsig init call earlier

* Gate Bitdrift init call

* Remove IS_TEST env constant

* Mock statsig
Diffstat (limited to 'src/lib/bitdrift.ts')
-rw-r--r--src/lib/bitdrift.ts19
1 files changed, 16 insertions, 3 deletions
diff --git a/src/lib/bitdrift.ts b/src/lib/bitdrift.ts
index 2b22155e7..02d074e76 100644
--- a/src/lib/bitdrift.ts
+++ b/src/lib/bitdrift.ts
@@ -1,7 +1,20 @@
 import {init} from '@bitdrift/react-native'
+import {Statsig} from 'statsig-react-native-expo'
+
+import {initPromise} from './statsig/statsig'
 
 const BITDRIFT_API_KEY = process.env.BITDRIFT_API_KEY
 
-if (BITDRIFT_API_KEY) {
-  init(BITDRIFT_API_KEY, {url: 'https://api-bsky.bitdrift.io'})
-}
+initPromise.then(() => {
+  let isEnabled = false
+  try {
+    if (Statsig.checkGate('enable_bitdrift')) {
+      isEnabled = true
+    }
+  } catch (e) {
+    // Statsig may complain about it being called too early.
+  }
+  if (isEnabled && BITDRIFT_API_KEY) {
+    init(BITDRIFT_API_KEY, {url: 'https://api-bsky.bitdrift.io'})
+  }
+})