{
  "openapi": "3.0.1",
  "info": {
    "title": "SEC Form D Monitor — Private Placement Alerts",
    "description": "Real-time alerts on SEC Form D filings — track which startups raised, which hedge funds opened to LPs, which fund managers filed their first vehicle. Granular filtering by industry, offering size, exemption type, related persons. The\n  PitchBook / CB Insights alternative built on EDGAR.",
    "version": "0.0",
    "x-build-id": "9KxeCUA1F5xuyRMu8"
  },
  "servers": [
    {
      "url": "https://api.apify.com/v2"
    }
  ],
  "paths": {
    "/acts/incontrovertible_gate~form-d-monitor/run-sync-get-dataset-items": {
      "post": {
        "operationId": "run-sync-get-dataset-items-incontrovertible_gate-form-d-monitor",
        "x-openai-isConsequential": false,
        "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
        "tags": [
          "Run Actor"
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/inputSchema"
              }
            }
          }
        },
        "parameters": [
          {
            "name": "token",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Enter your Apify token here"
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/acts/incontrovertible_gate~form-d-monitor/runs": {
      "post": {
        "operationId": "runs-sync-incontrovertible_gate-form-d-monitor",
        "x-openai-isConsequential": false,
        "summary": "Executes an Actor and returns information about the initiated run in response.",
        "tags": [
          "Run Actor"
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/inputSchema"
              }
            }
          }
        },
        "parameters": [
          {
            "name": "token",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Enter your Apify token here"
          }
        ],
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/runsResponseSchema"
                }
              }
            }
          }
        }
      }
    },
    "/acts/incontrovertible_gate~form-d-monitor/run-sync": {
      "post": {
        "operationId": "run-sync-incontrovertible_gate-form-d-monitor",
        "x-openai-isConsequential": false,
        "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
        "tags": [
          "Run Actor"
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/inputSchema"
              }
            }
          }
        },
        "parameters": [
          {
            "name": "token",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Enter your Apify token here"
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    }
  },
  "components": {
    "schemas": {
      "inputSchema": {
        "type": "object",
        "required": [
          "userAgent"
        ],
        "properties": {
          "industryGroupTypes": {
            "title": "Industry groups to watch",
            "uniqueItems": true,
            "type": "array",
            "description": "Filter Form D filings to these issuer-reported industries. Leave empty to match all.",
            "items": {
              "type": "string",
              "enum": [
                "Other Technology",
                "Computers",
                "Telecommunications",
                "Other Health Care",
                "Biotechnology",
                "Pharmaceuticals",
                "Health Insurance",
                "Hospitals & Physicians",
                "Investing",
                "Investment Banking",
                "Pooled Investment Fund",
                "Hedge Fund",
                "Private Equity Fund",
                "Venture Capital Fund",
                "Other Banking & Financial Services",
                "Commercial Banking",
                "Insurance",
                "Real Estate Funds",
                "REITS & Finance",
                "Residential",
                "Commercial",
                "Energy",
                "Coal Mining",
                "Electric Utilities",
                "Oil & Gas",
                "Other Energy",
                "Manufacturing",
                "Restaurants",
                "Retailing",
                "Travel",
                "Airlines & Airports",
                "Lodging & Conventions",
                "Other Travel",
                "Construction",
                "Other Real Estate",
                "Agriculture",
                "Business Services",
                "Other"
              ]
            }
          },
          "minOfferingAmount": {
            "title": "Minimum total offering amount (USD)",
            "minimum": 0,
            "type": "integer",
            "description": "Only alert on filings with `totalOfferingAmount` ≥ this value. Filters out tiny friends-and-family rounds. Set 0 for no filter.",
            "default": 1000000
          },
          "maxOfferingAmount": {
            "title": "Maximum total offering amount (USD, optional)",
            "minimum": 0,
            "type": "integer",
            "description": "Cap by offering size. Useful for early-stage scouting (e.g. set 10000000 to see only sub-$10M raises). Leave 0 for no cap.",
            "default": 0
          },
          "requireAmountSold": {
            "title": "Require amount actually sold > 0",
            "type": "boolean",
            "description": "If true, only include filings where `totalAmountSold > 0` (i.e. capital actually closed, not just offered).",
            "default": false
          },
          "entityTypes": {
            "title": "Issuer entity types",
            "uniqueItems": true,
            "type": "array",
            "description": "Filter by issuer's legal entity type. Most VC/PE deals = Corporation or Limited Partnership. Hedge funds = Limited Partnership or LLC.",
            "items": {
              "type": "string",
              "enum": [
                "Corporation",
                "Limited Partnership",
                "Limited Liability Company",
                "General Partnership",
                "Business Trust",
                "Other"
              ]
            }
          },
          "investmentFundOnly": {
            "title": "Investment funds only (3(c)(1) / 3(c)(7))",
            "type": "boolean",
            "description": "If true, only include filings where issuer claimed an Investment Company Act exemption (3(c)(1) for ≤100 LPs, 3(c)(7) for qualified purchasers). This is the canonical signal for hedge funds + PE/VC funds raising LP capital.",
            "default": false
          },
          "operatingCompanyOnly": {
            "title": "Operating companies only (skip funds)",
            "type": "boolean",
            "description": "If true, EXCLUDE pooled-investment-vehicle filings. Use this for VC deal-flow scouting (you want startups, not other VCs' fund raises).",
            "default": false
          },
          "federalExemptions": {
            "title": "Federal exemption types",
            "uniqueItems": true,
            "type": "array",
            "description": "Filter by Reg D rule cited. 506(b) = traditional accredited-only private placement. 506(c) = general solicitation allowed. 504 = small offerings up to $10M.",
            "items": {
              "type": "string",
              "enum": [
                "06b",
                "06c",
                "04",
                "04(a)(5)",
                "04(a)(6)"
              ],
              "enumTitles": [
                "Rule 506(b) — Traditional Reg D",
                "Rule 506(c) — General solicitation OK",
                "Rule 504 — Up to $10M",
                "Section 4(a)(5)",
                "Section 4(a)(6) — Crowdfunding"
              ]
            }
          },
          "states": {
            "title": "Limit to issuers in these US states (optional)",
            "type": "array",
            "description": "2-letter state codes (e.g. CA, NY, MA). Filters by issuer's primary address. Empty = include all states + international.",
            "items": {
              "type": "string"
            }
          },
          "excludeAmendments": {
            "title": "Exclude amendments (Form D/A)",
            "type": "boolean",
            "description": "If true, only count first-filed Form D. Form D/A = re-filing with updated info. Default true for clean deal-flow signal.",
            "default": true
          },
          "firstTimeFilerOnly": {
            "title": "First-time filers only",
            "type": "boolean",
            "description": "If true, only alert when this CIK has never filed any SEC document before. Strong signal for brand-new entities (just-formed startups, just-launched funds).",
            "default": false
          },
          "relatedPersonNames": {
            "title": "Track specific persons by name (optional)",
            "type": "array",
            "description": "Match if any of these strings appears (case-insensitive) in the related-persons list (officers, directors, promoters). Use to track GPs, board members, repeat founders.",
            "items": {
              "type": "string"
            }
          },
          "issuerNameKeywords": {
            "title": "Issuer name keywords (optional)",
            "type": "array",
            "description": "Substring match on issuer name. Useful for tracking specific fund families (e.g. 'Sequoia', 'Andreessen', 'Tiger'). Empty = match all.",
            "items": {
              "type": "string"
            }
          },
          "lookbackHours": {
            "title": "Lookback window (hours)",
            "minimum": 1,
            "maximum": 168,
            "type": "integer",
            "description": "Each run checks the most recent EDGAR filings. The actor's RSS-only window is the last ~100 Form Ds (≈last day during peak Q1). Dedup ensures no duplicate alerts even if you run frequently.",
            "default": 24
          },
          "notificationChannel": {
            "title": "Notification channel",
            "enum": [
              "none",
              "slack",
              "email",
              "webhook"
            ],
            "type": "string",
            "description": "Where to push alerts. 'none' = dataset only (use Apify integrations like Zapier or Make to wire alerts to your stack).",
            "default": "none"
          },
          "slackWebhookUrl": {
            "title": "Slack webhook URL",
            "type": "string",
            "description": "Incoming-webhook URL from your Slack app. Required when channel is 'slack'."
          },
          "emailRecipient": {
            "title": "Email recipient address",
            "type": "string",
            "description": "Email address to send alerts to. Required when channel is 'email'. Sent via Apify's mail-sending service (no SMTP config needed)."
          },
          "emailSubjectPrefix": {
            "title": "Email subject prefix",
            "type": "string",
            "description": "Prepended to every email alert subject. e.g. '[Form D]'.",
            "default": "[Form D Monitor]"
          },
          "customWebhookUrl": {
            "title": "Custom webhook URL",
            "type": "string",
            "description": "Any HTTPS endpoint receiving JSON POST per match. Pipe to Affinity, Salesforce, Notion, or your own backend."
          },
          "userAgent": {
            "title": "SEC User-Agent",
            "type": "string",
            "description": "SEC requires a real User-Agent with name + email per their fair-access policy. Format: 'Your Name your@email.com'."
          },
          "testMode": {
            "title": "Test mode",
            "type": "boolean",
            "description": "Ignore dedup state and fire one alert for the most recent matching filing. Use this to confirm your channel works before scheduling.",
            "default": false
          }
        }
      },
      "runsResponseSchema": {
        "type": "object",
        "properties": {
          "data": {
            "type": "object",
            "properties": {
              "id": {
                "type": "string"
              },
              "actId": {
                "type": "string"
              },
              "userId": {
                "type": "string"
              },
              "startedAt": {
                "type": "string",
                "format": "date-time",
                "example": "2025-01-08T00:00:00.000Z"
              },
              "finishedAt": {
                "type": "string",
                "format": "date-time",
                "example": "2025-01-08T00:00:00.000Z"
              },
              "status": {
                "type": "string",
                "example": "READY"
              },
              "meta": {
                "type": "object",
                "properties": {
                  "origin": {
                    "type": "string",
                    "example": "API"
                  },
                  "userAgent": {
                    "type": "string"
                  }
                }
              },
              "stats": {
                "type": "object",
                "properties": {
                  "inputBodyLen": {
                    "type": "integer",
                    "example": 2000
                  },
                  "rebootCount": {
                    "type": "integer",
                    "example": 0
                  },
                  "restartCount": {
                    "type": "integer",
                    "example": 0
                  },
                  "resurrectCount": {
                    "type": "integer",
                    "example": 0
                  },
                  "computeUnits": {
                    "type": "integer",
                    "example": 0
                  }
                }
              },
              "options": {
                "type": "object",
                "properties": {
                  "build": {
                    "type": "string",
                    "example": "latest"
                  },
                  "timeoutSecs": {
                    "type": "integer",
                    "example": 300
                  },
                  "memoryMbytes": {
                    "type": "integer",
                    "example": 1024
                  },
                  "diskMbytes": {
                    "type": "integer",
                    "example": 2048
                  }
                }
              },
              "buildId": {
                "type": "string"
              },
              "defaultKeyValueStoreId": {
                "type": "string"
              },
              "defaultDatasetId": {
                "type": "string"
              },
              "defaultRequestQueueId": {
                "type": "string"
              },
              "buildNumber": {
                "type": "string",
                "example": "1.0.0"
              },
              "containerUrl": {
                "type": "string"
              },
              "usage": {
                "type": "object",
                "properties": {
                  "ACTOR_COMPUTE_UNITS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_WRITES": {
                    "type": "integer",
                    "example": 1
                  },
                  "KEY_VALUE_STORE_LISTS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_INTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_EXTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_SERPS": {
                    "type": "integer",
                    "example": 0
                  }
                }
              },
              "usageTotalUsd": {
                "type": "number",
                "example": 0.00005
              },
              "usageUsd": {
                "type": "object",
                "properties": {
                  "ACTOR_COMPUTE_UNITS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_WRITES": {
                    "type": "number",
                    "example": 0.00005
                  },
                  "KEY_VALUE_STORE_LISTS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_INTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_EXTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_SERPS": {
                    "type": "integer",
                    "example": 0
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}