Upload source maps for web
- 1Install the PostHog CLIRequiredInstall posthog-cli:
- 2Authenticate the PostHog CLIRequiredTo authenticate the CLI, you can call the logincommand and follow the instructions:TerminalIf you are using the CLI in a CI/CD environment such as GitHub Actions, you can set environment variables to authenticate: Environment Variable Description Source POSTHOG_CLI_ENV_IDPostHog project ID Environment settings POSTHOG_CLI_TOKENPersonal API key with error tracking writescopeAPI key settings Use the --hostoption in subsequent commands to specify a different PostHog instance / or region. For EU users:Terminal
- 3Output source maps for webRequiredIf you serve minified bundles in production, PostHog requires source maps to generate accurate stack traces. Here are instructions to enable source map generation for popular build tools: Build Tool Documentation Vite Source Map Configuration webpack Source Map Configuration Rollup Source Map Options For other build tools, consult their documentation to enable source maps. 
- 4Inject source mapRequiredYour goal in this step: Add metadata to associate maps with your code.Once you've built your application and have bundled assets, inject the context required by PostHog to associate the maps with the served code. TerminalThe CLI will create or reuse the release for the detected or supplied project and version. The CLI will try to detect project and version information, but you can set them explicitly with --projectand--version. We recommend setting the project, and letting the CLI detect the version, if your project is continuously deployed (the version will be the git commit hash at build time).
- Verify source map injectionCheckpointConfirm source map comments are present- Confirm that the served files are injected with the correct source map comment in production in dev tools. JavaScript
- 5Upload source mapRequiredYour goal in this step: Send the processed source maps to PostHog.You will then need to upload the modified assets to PostHog. TerminalThe CLI reuses the release stored during injection, so you don't need to pass --projector--versionagain.💡 Tip: You can use --delete-afteroption to clean up sourcemaps after uploading them.Serve injected assetsYou must serve the injected assets in deployed production app. The injected metadata is used during error capture to identify the correct source map to use. We suggest you upload source maps right after your production build in CI. If you serve a copy of the bundled assets as they were prior to running posthog-cli sourcemap inject, we won't be able to use the uploaded sourcemap to unminify or demangle your stack traces.