{
  "openapi": "3.0.1",
  "info": {
    "title": "APAC IPO Calendar Sweep — Pan-Asia Listings Tracker",
    "description": "Pan-Asia IPO aggregator across HKEX + TWSE + TSE + KRX + NSE/BSE + SGX + ASEAN. Forward + recent listings with sponsors, cornerstones, offer prices, FX-normalised proceeds, post-IPO returns. Hedge funds, IPO traders, financial journalists.",
    "version": "0.0",
    "x-build-id": "bkLkyh4bg7wXhyMY8"
  },
  "servers": [
    {
      "url": "https://api.apify.com/v2"
    }
  ],
  "paths": {
    "/acts/nexgendata~apac-ipo-calendar-sweep/run-sync-get-dataset-items": {
      "post": {
        "operationId": "run-sync-get-dataset-items-nexgendata-apac-ipo-calendar-sweep",
        "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/nexgendata~apac-ipo-calendar-sweep/runs": {
      "post": {
        "operationId": "runs-sync-nexgendata-apac-ipo-calendar-sweep",
        "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/nexgendata~apac-ipo-calendar-sweep/run-sync": {
      "post": {
        "operationId": "run-sync-nexgendata-apac-ipo-calendar-sweep",
        "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",
        "properties": {
          "country": {
            "title": "Country / region filter",
            "enum": [
              "ALL",
              "ASEAN",
              "HK",
              "TW",
              "JP",
              "KR",
              "IN",
              "SG",
              "ID",
              "MY",
              "TH",
              "VN",
              "PH"
            ],
            "type": "string",
            "description": "Which APAC market(s) to sweep. 'ALL' returns the full pan-Asia book — every IPO from HKEX (Hong Kong) + TWSE/TPEx (Taiwan) + TSE (Japan) + KRX KOSPI/KOSDAQ (Korea) + NSE/BSE (India) + SGX (Singapore) + IDX (Indonesia) + Bursa Malaysia + SET (Thailand) + HOSE (Vietnam) + PSE (Philippines). 'ASEAN' = SG + ID + MY + TH + VN + PH only (excludes North Asia). Individual ISO-2 codes (HK / TW / JP / KR / IN / SG / ID / MY / TH / VN / PH) drill down to a single jurisdiction — useful when you're running country-specific allocator dashboards or sector models that don't cross-FX.",
            "default": "ALL"
          },
          "status": {
            "title": "Listing-pipeline status",
            "enum": [
              "all",
              "proof",
              "approved",
              "listed"
            ],
            "type": "string",
            "description": "Which slice of the IPO lifecycle to return. 'proof' = early-stage filings (Application Proof / draft prospectus / DRHP filed, not yet priced — typically 60-180 days before listing). 'approved' = listing-committee-approved deals with confirmed pricing date or final allotment (book-build phase, typically 5-30 days before listing). 'listed' = already-trading IPOs (post-debut). 'all' (default) = full lifecycle in one pull. Note: status semantics differ slightly across exchanges — HKEX uses Application Proof/PHIP, SEBI uses DRHP/RHP, SGX uses Lodgement/Registration, TSE uses TDnet/JPX filings, KRX uses KIND disclosures. We normalise across all of them.",
            "default": "all"
          },
          "lookbackDays": {
            "title": "Lookback window (days, for 'listed' / 'all' bucket)",
            "minimum": 1,
            "maximum": 1825,
            "type": "integer",
            "description": "How many days of completed APAC IPOs (already-trading names) to include. Default 90 = the recent quarter — typically 30-100 completed deals across the bloc. 365 = full-year vintage study (good for league-table research: which sponsor / cornerstone / underwriter dominated the Asia primary calendar). 7-30 = daily/weekly trader dashboards. APAC collectively prices ~600-1000 IPOs/year across the 11 markets covered.",
            "default": 90
          },
          "lookaheadDays": {
            "title": "Lookahead window (days, for 'proof' / 'approved' / 'all' bucket)",
            "minimum": 1,
            "maximum": 730,
            "type": "integer",
            "description": "How many days of forward APAC IPO calendar to include. Default 90 = next-quarter pipeline of confirmed/imminent deals. 180+ days surfaces the soft pipeline (rumored / sponsor-mandated but not yet priced). Use 30 for the active book-build window only. India alone is the world's most active IPO market by deal count (~200+ NSE+BSE listings/year); China's HKEX has been the global #1 by proceeds in 5 of the last 15 years; Korea KOSDAQ runs at ~100 listings/year. The forward pipeline is dense.",
            "default": 90
          },
          "sector": {
            "title": "GICS-style sector filter",
            "enum": [
              "all",
              "Technology",
              "Healthcare",
              "Financials",
              "Consumer Discretionary",
              "Consumer Staples",
              "Industrials",
              "Energy",
              "Real Estate",
              "Materials",
              "Communication Services",
              "Utilities"
            ],
            "type": "string",
            "description": "Filter by sector classification. APAC IPO sector mix in 2024-2026 is heavily concentrated in (1) Consumer Discretionary — China auto / HK consumer-brand listings (Mixue Bingcheng, Chery Auto, Laopu Gold), Korea LG/Hyundai secondaries, India retail IPOs; (2) Technology — Taiwan semi supply chain, Japan AI cloud (Sakura Internet, Kioxia), HK Chapter 18C Specialist Tech; (3) Healthcare — HK Chapter 18A pre-revenue biotech wave, KOSDAQ K-biotech; (4) Industrials — China A+H industrials, Korea HD Hyundai class; (5) Real Estate — SGX data-centre REITs (NTT DC REIT, Centurion). 'all' = no filter.",
            "default": "all"
          },
          "minProceedsUsdMillion": {
            "title": "Minimum gross proceeds (USD millions, FX-normalised)",
            "minimum": 0,
            "maximum": 100000,
            "type": "number",
            "description": "Lower bound on gross IPO proceeds normalised to USD millions. Use to focus on institutional-grade deals. Typical thresholds: '50' = scaleable mid-cap; '250' = significant deal; '500' = mega-deal class (Hyundai Motor India $3.3bn, Midea HK ~$4bn, Tokyo Metro ~$2.3bn, Kioxia ~$770M, 99 Speed Mart ~$900M). Leave 0 for no lower bound — useful for SME/Catalist/KOSDAQ/SET-mai watching. FX rates are conservative spot marks; portfolio users should re-FX at their own latest.",
            "default": 0
          },
          "limit": {
            "title": "Max IPO records returned",
            "minimum": 1,
            "maximum": 500,
            "type": "integer",
            "description": "Hard cap on total APAC IPO records returned (1-500). Each IPO is one dataset row. Premium per-record pricing reflects the pan-Asia aggregator tier — Bloomberg APAC IPO / Refinitiv Eikon / Dealogic equivalents cost USD 24,000+/seat/year for comparable coverage. APAC collectively prices 600-1000 IPOs/year across the 11 markets — most institutional desks pull 50-200 per run. Records are sorted Upcoming-first by listing_date ascending, then completed-IPOs by listing_date descending.",
            "default": 50
          }
        }
      },
      "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
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}