PostHog · Schema

Subscription

Standard Subscription serializer.

A/B TestingAnalyticsFeature FlagsOpen SourceProduct AnalyticsSession Recording

Properties

Name Type Description
id integer
dashboard integer Dashboard ID to subscribe to (mutually exclusive with insight on create).
insight integer Insight ID to subscribe to (mutually exclusive with dashboard on create).
insight_short_id string
resource_name string
dashboard_export_insights array List of insight IDs from the dashboard to include. Required for dashboard subscriptions, max 6.
target_type object Delivery channel: email, slack, or webhook. * `email` - Email * `slack` - Slack * `webhook` - Webhook
target_value string Recipient(s): comma-separated email addresses for email, Slack channel name/ID for slack, or full URL for webhook.
frequency object How often to deliver: daily, weekly, monthly, or yearly. * `daily` - Daily * `weekly` - Weekly * `monthly` - Monthly * `yearly` - Yearly
interval integer Interval multiplier (e.g. 2 with weekly frequency means every 2 weeks). Default 1.
byweekday array Days of week for weekly subscriptions: monday, tuesday, wednesday, thursday, friday, saturday, sunday.
bysetpos integer Position within byweekday set for monthly frequency (e.g. 1 for first, -1 for last).
count integer Total number of deliveries before the subscription stops. Null for unlimited.
start_date string When to start delivering (ISO 8601 datetime).
until_date string When to stop delivering (ISO 8601 datetime). Null for indefinite.
created_at string
created_by object
deleted boolean Set to true to soft-delete. Subscriptions cannot be hard-deleted.
title string Human-readable name for this subscription.
summary string Human-readable schedule summary, e.g. 'sent daily'.
next_delivery_date string
integration_id integer ID of a connected Slack integration. Required when target_type is slack.
invite_message string Optional message included in the invitation email when adding new recipients.
summary_enabled boolean
summary_prompt_guide string
View JSON Schema on GitHub

JSON Schema

posthog-subscription-schema.json Raw ↑
{
  "$schema": "https://json-schema.org/draft/2020-12/schema",
  "$id": "#/components/schemas/Subscription",
  "title": "Subscription",
  "type": "object",
  "description": "Standard Subscription serializer.",
  "properties": {
    "id": {
      "type": "integer",
      "readOnly": true
    },
    "dashboard": {
      "type": "integer",
      "nullable": true,
      "description": "Dashboard ID to subscribe to (mutually exclusive with insight on create)."
    },
    "insight": {
      "type": "integer",
      "nullable": true,
      "description": "Insight ID to subscribe to (mutually exclusive with dashboard on create)."
    },
    "insight_short_id": {
      "type": "string",
      "nullable": true,
      "readOnly": true
    },
    "resource_name": {
      "type": "string",
      "nullable": true,
      "readOnly": true
    },
    "dashboard_export_insights": {
      "type": "array",
      "items": {
        "type": "integer"
      },
      "description": "List of insight IDs from the dashboard to include. Required for dashboard subscriptions, max 6."
    },
    "target_type": {
      "allOf": [
        {
          "$ref": "#/components/schemas/TargetTypeEnum"
        }
      ],
      "description": "Delivery channel: email, slack, or webhook.\n\n* `email` - Email\n* `slack` - Slack\n* `webhook` - Webhook"
    },
    "target_value": {
      "type": "string",
      "description": "Recipient(s): comma-separated email addresses for email, Slack channel name/ID for slack, or full URL for webhook."
    },
    "frequency": {
      "allOf": [
        {
          "$ref": "#/components/schemas/SubscriptionFrequencyEnum"
        }
      ],
      "description": "How often to deliver: daily, weekly, monthly, or yearly.\n\n* `daily` - Daily\n* `weekly` - Weekly\n* `monthly` - Monthly\n* `yearly` - Yearly"
    },
    "interval": {
      "type": "integer",
      "maximum": 2147483647,
      "minimum": -2147483648,
      "description": "Interval multiplier (e.g. 2 with weekly frequency means every 2 weeks). Default 1."
    },
    "byweekday": {
      "type": "array",
      "items": {
        "$ref": "#/components/schemas/ByweekdayEnum"
      },
      "nullable": true,
      "description": "Days of week for weekly subscriptions: monday, tuesday, wednesday, thursday, friday, saturday, sunday."
    },
    "bysetpos": {
      "type": "integer",
      "maximum": 2147483647,
      "minimum": -2147483648,
      "nullable": true,
      "description": "Position within byweekday set for monthly frequency (e.g. 1 for first, -1 for last)."
    },
    "count": {
      "type": "integer",
      "maximum": 2147483647,
      "minimum": -2147483648,
      "nullable": true,
      "description": "Total number of deliveries before the subscription stops. Null for unlimited."
    },
    "start_date": {
      "type": "string",
      "format": "date-time",
      "description": "When to start delivering (ISO 8601 datetime)."
    },
    "until_date": {
      "type": "string",
      "format": "date-time",
      "nullable": true,
      "description": "When to stop delivering (ISO 8601 datetime). Null for indefinite."
    },
    "created_at": {
      "type": "string",
      "format": "date-time",
      "readOnly": true
    },
    "created_by": {
      "allOf": [
        {
          "$ref": "#/components/schemas/UserBasic"
        }
      ],
      "readOnly": true
    },
    "deleted": {
      "type": "boolean",
      "description": "Set to true to soft-delete. Subscriptions cannot be hard-deleted."
    },
    "title": {
      "type": "string",
      "nullable": true,
      "description": "Human-readable name for this subscription.",
      "maxLength": 100
    },
    "summary": {
      "type": "string",
      "readOnly": true,
      "description": "Human-readable schedule summary, e.g. 'sent daily'."
    },
    "next_delivery_date": {
      "type": "string",
      "format": "date-time",
      "readOnly": true,
      "nullable": true
    },
    "integration_id": {
      "type": "integer",
      "nullable": true,
      "description": "ID of a connected Slack integration. Required when target_type is slack."
    },
    "invite_message": {
      "type": "string",
      "nullable": true,
      "description": "Optional message included in the invitation email when adding new recipients."
    },
    "summary_enabled": {
      "type": "boolean"
    },
    "summary_prompt_guide": {
      "type": "string",
      "maxLength": 500
    }
  },
  "required": [
    "created_at",
    "created_by",
    "frequency",
    "id",
    "insight_short_id",
    "next_delivery_date",
    "resource_name",
    "start_date",
    "summary",
    "target_type",
    "target_value"
  ]
}