budibase/packages/builder/src/analytics.js

72 lines
1.9 KiB
JavaScript
Raw Normal View History

2020-07-14 17:00:58 +02:00
import * as Sentry from "@sentry/browser"
import posthog from "posthog-js"
import api from "builderStore/api"
2020-07-14 17:00:58 +02:00
let analyticsEnabled
const posthogConfigured = process.env.POSTHOG_TOKEN && process.env.POSTHOG_URL
const sentryConfigured = process.env.SENTRY_DSN
async function activate() {
if (analyticsEnabled === undefined) {
// only the server knows the true NODE_ENV
// this was an issue as NODE_ENV = 'cypress' on the server,
// but 'production' on the client
const response = await api.get("/api/analytics")
analyticsEnabled = (await response.json()) === true
}
if (!analyticsEnabled) return
if (sentryConfigured) Sentry.init({ dsn: process.env.SENTRY_DSN })
if (posthogConfigured) {
posthog.init(process.env.POSTHOG_TOKEN, {
api_host: process.env.POSTHOG_URL,
})
posthog.set_config({ persistence: "cookie" })
}
2020-07-14 17:00:58 +02:00
}
function identify(id) {
if (!analyticsEnabled || !id) return
if (posthogConfigured) posthog.identify(id)
if (sentryConfigured)
Sentry.configureScope(scope => {
scope.setUser({ id: id })
})
}
async function identifyByApiKey(apiKey) {
if (!analyticsEnabled) return true
const response = await fetch(
`https://03gaine137.execute-api.eu-west-1.amazonaws.com/prod/account/id?api_key=${apiKey.trim()}`
)
if (response.status === 200) {
const id = await response.json()
await api.put("/api/keys/userId", { value: id })
identify(id)
return true
}
return false
}
2020-07-14 17:00:58 +02:00
function captureException(err) {
if (!analyticsEnabled) return
2020-07-14 17:00:58 +02:00
Sentry.captureException(err)
captureEvent("Error", { error: err.message ? err.message : err })
2020-07-14 17:00:58 +02:00
}
function captureEvent(eventName, props = {}) {
if (!analyticsEnabled || !process.env.POSTHOG_TOKEN) return
props.sourceApp = "builder"
posthog.capture(eventName, props)
}
2020-07-14 17:00:58 +02:00
export default {
activate,
identify,
identifyByApiKey,
2020-07-14 17:00:58 +02:00
captureException,
2020-07-16 16:19:46 +02:00
captureEvent,
2020-07-14 17:00:58 +02:00
}