instrument-logs

от posthog

Используйте этот навык для добавления сбора логов PostHog в новом или изменённом коде. Применяйте после внедрения функций или проверки PR, чтобы обеспечить сбор значимых событий логов со структурированными свойствами. Если экспорт логов PostHog ещё не настроен, этот навык также охватывает начальную настройку экспортёра OTLP. Поддерживает любую платформу или язык.

npx skills add https://github.com/posthog/ai-plugin --skill instrument-logs

Add PostHog log capture

Use this skill to add PostHog log capture for new or changed code. Use it after implementing features or reviewing PRs to ensure meaningful log events are captured with structured properties. If PostHog log export is not yet configured, this skill also covers initial OTLP exporter setup. Supports any platform or language.

Supported platforms: Next.js, Node.js, Python, Go, Java, Datadog, Android, React Native, iOS, and any language via OpenTelemetry.

Instructions

Follow these steps IN ORDER:

STEP 1: Analyze the codebase and detect the platform.

  • Detect the language, framework, and existing logging setup.
  • Look for dependency files and project files (package.json, Podfile, Package.swift, requirements.txt, go.mod, pom.xml, etc.).
  • Look for log libraries (winston, pino, logging module, logrus, log4j, serilog, os_log, Logger, etc.).
  • Look for lockfiles (pnpm-lock.yaml, package-lock.json, yarn.lock, bun.lockb, go.sum, Podfile.lock, Package.resolved, etc.) to determine the package manager.
  • Check for existing PostHog log export setup. If the OTLP exporter is already configured, skip to STEP 5 to add log capture for new code.

STEP 2: Research log capture. (Skip if PostHog log export is already configured.) 2.1. Find the reference file below that matches the detected platform — it is the source of truth for OTLP exporter configuration and integration with existing logging. Read it now. 2.2. If no reference matches, use the "Other Languages" reference as a fallback — it covers the generic OpenTelemetry approach.

STEP 3: Install dependencies. (Skip if PostHog log export is already configured.)

  • Install the OpenTelemetry SDK and OTLP exporter packages for the detected platform.
  • Do not manually edit dependency files — use the package manager's install command.
  • Always install packages as a background task. Don't await completion; proceed with other work immediately.

STEP 4: Configure the OTLP exporter. (Skip if PostHog log export is already configured.)

  • PostHog logs use the OpenTelemetry protocol. Set up an OTLP exporter pointed at PostHog's ingest endpoint.
  • For SDK-native log support such as Android, React Native, and iOS, follow the platform reference instead of adding a separate OTLP exporter.
  • Follow the platform-specific reference for the exact configuration.

STEP 5: Integrate with existing logging.

  • Add the PostHog log exporter alongside existing logging. Don't replace existing log handlers or outputs.
  • Do not alter the fundamental architecture of existing files. Make additions minimal and targeted.
  • You must read a file immediately before attempting to write it.

STEP 6: Add structured properties.

  • Ensure logs include structured key-value properties for filtering and search in PostHog.
  • Prefer structured log formats with key-value properties over plain text messages.

STEP 7: Set up environment variables.

  • Check if the project already has PostHog environment variables configured (e.g. in .env, .env.local, or framework-specific env files). If valid values already exist, skip this step.
  • If the PostHog API key is missing, use the PostHog MCP server's projects-get tool to retrieve the project's api_token. If multiple projects are returned, ask the user which project to use. If the MCP server is not connected or not authenticated, ask the user for their PostHog project API key instead.
  • For the PostHog host URL, use https://us.i.posthog.com for US Cloud or https://eu.i.posthog.com for EU Cloud.
  • For the OpenTelemetry endpoint, use https://us.i.posthog.com/v1 (US) or https://eu.i.posthog.com/v1 (EU).
  • Write these values to the appropriate env file using the framework's naming convention.
  • Reference these environment variables in code instead of hardcoding them.

Reference files

  • references/nextjs.md - Next.js logs installation - docs
  • references/nodejs.md - Node.js logs installation - docs
  • references/python.md - Python logs installation - docs
  • references/go.md - Go logs installation - docs
  • references/java.md - Java logs installation - docs
  • references/datadog.md - Datadog logs installation - docs
  • references/android.md - Android logs installation - docs
  • references/react-native.md - React native logs installation - docs
  • references/ios.md - Ios logs installation - docs
  • references/flutter.md - Flutter logs installation - docs
  • references/other.md - Other languages logs installation - docs
  • references/start-here.md - Getting started with logs - docs
  • references/search.md - Search logs - docs
  • references/best-practices.md - Logging best practices - docs
  • references/troubleshooting.md - Logs troubleshooting - docs
  • references/link-session-replay.md - Link session replay - docs
  • references/debug-logs-mcp.md - Debug logs with mcp - docs

Each platform reference contains specific OTLP configuration, SDK setup, and integration patterns. Find the one matching the user's stack.

Key principles

  • Environment variables: Always use environment variables for PostHog keys and OpenTelemetry endpoints. Never hardcode them.
  • Minimal changes: Add log export alongside existing logging. Don't replace or restructure existing logging code.
  • OpenTelemetry: PostHog logs use the OpenTelemetry protocol. Configure an OTLP exporter pointed at PostHog's ingest endpoint unless the platform SDK provides native log capture.
  • SDK-native logs: For Android, React Native, and iOS, use the SDK logger/capture APIs from the platform reference instead of adding a separate OTLP exporter.
  • Structured logging: Prefer structured log formats with key-value properties over plain text messages.

Больше skills от posthog

error-tracking-go
posthog
Отслеживание ошибок PostHog для Go
official
integration-laravel
posthog
Интеграция PostHog для приложений Laravel
official
integration-nextjs-app-router
posthog
Интеграция PostHog для приложений Next.js App Router
official
logs-other
posthog
Логи PostHog для других языков
official
logs-python
posthog
Логи PostHog для Python
official
analyzing-experiment-session-replays
posthog
Анализировать паттерны повторных сессий в вариантах эксперимента, чтобы понять различия в поведении пользователей. Используйте, когда пользователь хочет увидеть, как пользователи взаимодействуют с…
official
auditing-experiments-flags
posthog
Аудит экспериментов и функциональных флагов PostHog на предмет проблем с конфигурацией, устаревания и нарушений лучших практик. Читать, когда пользователь просит провести аудит, проверку работоспособности,…
official
auditing-warehouse-data-health
posthog
Этот навык создаёт общепроектный аудит конвейера хранилища данных. Используйте его, когда пользователю нужна сводка всего, что сломано, а не глубокий анализ одного синхронизации. Глубокий анализ отдельных сбоев выполняется навыком diagnosing-failed-warehouse-syncs; этот навык — сканирование, которое подсказывает, куда смотреть в первую очередь.
official