Fetching analytics userId, when api_key entered
This commit is contained in:
parent
04923a6ef0
commit
8aad7eb49d
|
@ -1,5 +1,6 @@
|
||||||
import * as Sentry from "@sentry/browser"
|
import * as Sentry from "@sentry/browser"
|
||||||
import posthog from "posthog-js"
|
import posthog from "posthog-js"
|
||||||
|
import api from "builderStore/api"
|
||||||
|
|
||||||
function activate() {
|
function activate() {
|
||||||
Sentry.init({ dsn: process.env.SENTRY_DSN })
|
Sentry.init({ dsn: process.env.SENTRY_DSN })
|
||||||
|
@ -9,6 +10,30 @@ function activate() {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function identify(id) {
|
||||||
|
if (!id) return
|
||||||
|
posthog.identify(id)
|
||||||
|
Sentry.configureScope(scope => {
|
||||||
|
scope.setUser({ id: id })
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
async function identifyByApiKey(apiKey) {
|
||||||
|
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
|
||||||
|
}
|
||||||
|
|
||||||
function captureException(err) {
|
function captureException(err) {
|
||||||
Sentry.captureException(err)
|
Sentry.captureException(err)
|
||||||
}
|
}
|
||||||
|
@ -20,6 +45,8 @@ function captureEvent(event) {
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
activate,
|
activate,
|
||||||
|
identify,
|
||||||
|
identifyByApiKey,
|
||||||
captureException,
|
captureException,
|
||||||
captureEvent,
|
captureEvent,
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,13 +3,21 @@
|
||||||
import { store } from "builderStore"
|
import { store } from "builderStore"
|
||||||
import api from "builderStore/api"
|
import api from "builderStore/api"
|
||||||
import posthog from "posthog-js"
|
import posthog from "posthog-js"
|
||||||
|
import analytics from "../../../analytics"
|
||||||
|
|
||||||
let keys = { budibase: "", sendGrid: "" }
|
let keys = { budibase: "", sendGrid: "" }
|
||||||
|
|
||||||
async function updateKey([key, value]) {
|
async function updateKey([key, value]) {
|
||||||
|
if (key === "budibase") {
|
||||||
|
const isValid = await analytics.identifyByApiKey(value)
|
||||||
|
if (!isValid) {
|
||||||
|
// TODO: add validation message
|
||||||
|
keys = { ...keys }
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
const response = await api.put(`/api/keys/${key}`, { value })
|
const response = await api.put(`/api/keys/${key}`, { value })
|
||||||
const res = await response.json()
|
const res = await response.json()
|
||||||
if (key === "budibase") posthog.identify(value)
|
|
||||||
keys = { ...keys, ...res }
|
keys = { ...keys, ...res }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,6 +25,8 @@
|
||||||
async function fetchKeys() {
|
async function fetchKeys() {
|
||||||
const response = await api.get(`/api/keys/`)
|
const response = await api.get(`/api/keys/`)
|
||||||
const res = await response.json()
|
const res = await response.json()
|
||||||
|
// dont want this to ever be editable, as its fetched based on Api Key
|
||||||
|
if (res.userId) delete res.userId
|
||||||
keys = res
|
keys = res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,12 +22,31 @@
|
||||||
|
|
||||||
export let hasKey
|
export let hasKey
|
||||||
|
|
||||||
|
let isApiKeyValid
|
||||||
|
let lastApiKey
|
||||||
|
let fetchApiKeyPromise
|
||||||
|
const validateApiKey = async apiKey => {
|
||||||
|
if (!apiKey) return false
|
||||||
|
|
||||||
|
// make sure we only fetch once
|
||||||
|
if (isApiKeyValid === undefined || apiKey !== lastApiKey) {
|
||||||
|
if (!fetchApiKeyPromise) {
|
||||||
|
fetchApiKeyPromise = analytics.identifyByApiKey(apiKey)
|
||||||
|
}
|
||||||
|
isApiKeyValid = await fetchApiKeyPromise
|
||||||
|
fetchApiKeyPromise = undefined
|
||||||
|
}
|
||||||
|
return isApiKeyValid
|
||||||
|
}
|
||||||
|
|
||||||
let submitting = false
|
let submitting = false
|
||||||
let errors = {}
|
let errors = {}
|
||||||
let validationErrors = {}
|
let validationErrors = {}
|
||||||
let validationSchemas = [
|
let validationSchemas = [
|
||||||
{
|
{
|
||||||
apiKey: string().required("Please enter your API key."),
|
apiKey: string()
|
||||||
|
.required("Please enter your API key.")
|
||||||
|
.test("valid-apikey", "This API key is invalid", validateApiKey),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
applicationName: string().required("Your application must have a name."),
|
applicationName: string().required("Your application must have a name."),
|
||||||
|
@ -160,6 +179,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
function extractErrors({ inner }) {
|
function extractErrors({ inner }) {
|
||||||
|
if (!inner) return {}
|
||||||
return inner.reduce((acc, err) => {
|
return inner.reduce((acc, err) => {
|
||||||
return { ...acc, [err.path]: err.message }
|
return { ...acc, [err.path]: err.message }
|
||||||
}, {})
|
}, {})
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
import Spinner from "components/common/Spinner.svelte"
|
import Spinner from "components/common/Spinner.svelte"
|
||||||
import CreateAppModal from "components/start/CreateAppModal.svelte"
|
import CreateAppModal from "components/start/CreateAppModal.svelte"
|
||||||
import { Button } from "@budibase/bbui"
|
import { Button } from "@budibase/bbui"
|
||||||
|
import analytics from "../analytics"
|
||||||
|
|
||||||
let promise = getApps()
|
let promise = getApps()
|
||||||
|
|
||||||
|
@ -36,6 +37,7 @@
|
||||||
const apps = await getApps()
|
const apps = await getApps()
|
||||||
if (key) {
|
if (key) {
|
||||||
hasKey = true
|
hasKey = true
|
||||||
|
analytics.identify(key.userId)
|
||||||
} else {
|
} else {
|
||||||
showCreateAppModal()
|
showCreateAppModal()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue