Merge branch 'sentry-context' into 'main'

Sentry: add Soapbox context

See merge request soapbox-pub/soapbox!2804
This commit is contained in:
Alex Gleason 2023-10-13 03:06:12 +00:00
commit 5acdca6d75
3 changed files with 17 additions and 2 deletions

View file

@ -17,6 +17,7 @@ import { startOnboarding } from 'soapbox/actions/onboarding';
import { custom } from 'soapbox/custom';
import { queryClient } from 'soapbox/queries/client';
import { selectAccount } from 'soapbox/selectors';
import { unsetSentryAccount } from 'soapbox/sentry';
import KVStore from 'soapbox/storage/kv-store';
import toast from 'soapbox/toast';
import { getLoggedInAccount, parseBaseURL } from 'soapbox/utils/auth';
@ -220,6 +221,9 @@ export const logOut = () =>
queryClient.invalidateQueries();
queryClient.clear();
// Clear the account from Sentry.
unsetSentryAccount();
dispatch({ type: AUTH_LOGGED_OUT, account, standalone });
toast.success(messages.loggedOut);

View file

@ -1,3 +1,5 @@
import sourceCode from 'soapbox/utils/code';
import type { Account } from './schemas';
/** Start Sentry. */
@ -36,6 +38,8 @@ async function startSentry(dsn: string): Promise<void> {
// for finer control
tracesSampleRate: 1.0,
});
Sentry.setContext('soapbox', sourceCode);
}
/** Associate the account with Sentry events. */
@ -45,7 +49,14 @@ async function setSentryAccount(account: Account) {
Sentry.setUser({
id: account.id,
username: account.acct,
url: account.url,
});
}
export { startSentry, setSentryAccount };
/** Remove the account from Sentry events. */
async function unsetSentryAccount() {
const Sentry = await import('@sentry/react');
Sentry.setUser(null);
}
export { startSentry, setSentryAccount, unsetSentryAccount };

View file

@ -15,7 +15,7 @@ const tryGit = (cmd: string): string | undefined => {
}
};
const version = (pkg: Record<string, any>) => {
const version = (pkg: { version: string }): string => {
// Try to discern from GitLab CI first
if (CI_COMMIT_TAG === `v${pkg.version}` || CI_COMMIT_REF_NAME === 'stable') {
return pkg.version;