# Event Ticket Price Monitor (`technicaldost/event-ticket-price-monitor`) Actor

Track ticket prices and availability for events from public event pages (schema.org Event/Offer). Structured JSON: event, venue, date, price range, currency, availability.

- **URL**: https://apify.com/technicaldost/event-ticket-price-monitor.md
- **Developed by:** [Technical Dost Solutions](https://apify.com/technicaldost) (community)
- **Categories:** E-commerce, Business
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $10.00 / 1,000 tracked events

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## Event Ticket Price Monitor

### What this Actor does

Track ticket prices and availability for events from public event pages you supply.

It processes user-provided public event URLs, prioritizes JSON-LD/schema.org `Event` and `Offer` structured data (including `MusicEvent`, `SportsEvent`, and `TheaterEvent`), and can optionally run a conservative fallback price scan over visible page text. It normalizes useful fields, deduplicates rows, and saves structured records to the Apify dataset for recurring price monitoring.

### Why this Actor is useful

Buyers pay for this kind of extraction when it saves manual checking, creates repeatable price monitoring, feeds spreadsheets or dashboards, and turns public event pages into clean API-ready datasets.

### Who this is for

- Event resellers and brokers monitoring their own permitted listings
- Promoters and venues tracking public price signals
- Price-comparison and deal-alert builders
- Analysts and researchers studying public event pricing
- Fans tracking price/availability for events they follow

### Common use cases

- Monitor ticket price ranges and availability over time
- Build price-comparison or deal-alert datasets
- Feed dashboards or spreadsheets with public event pricing
- Track availability status changes for events you follow
- Create recurring public event pricing snapshots

### Input

- `startUrls`: Public event page URLs to extract from. Use only pages you are permitted to access without login or bypassing access controls.
- `maxItems`: Maximum number of rows to save.
- `maxConcurrency`: Number of pages processed in parallel. The default is intentionally conservative.
- `extractionMode`: Use `structuredDataOnly` or `structuredDataWithFallback`. The default enables a safe public price fallback when no `Event` structured data is present.
- `requestTimeoutSecs`: Maximum time to spend on a single page.
- `proxyConfiguration`: Optional Apify proxy configuration where permitted by your source review.

### Output

- `eventName`: Event name from structured data or page title/heading.
- `performer`: Performer or act name when exposed in structured data.
- `venue`: Venue name from the event location.
- `eventLocation`: Event address or locality string.
- `eventDate`: Event start date/time.
- `ticketPriceMin`: Lowest ticket price found across offers.
- `ticketPriceMax`: Highest ticket price found across offers.
- `currency`: Price currency code such as USD, GBP, or EUR.
- `ticketAvailability`: Availability status such as InStock or SoldOut when published.
- `ticketUrl`: Ticket or offer URL, or the source page URL.
- `platform`: Hostname of the source page.
- `sourceUrl`: URL where the data was extracted.
- `detectedAt`: Timestamp when this Actor extracted the row.
- `extractionMethod`: `structured_data` for valid Event/Offer schema, or `fallback_price_scan` for visible public price text.
- `confidenceScore`: Heuristic confidence score based on structured data availability.
- `missingFields`: Output fields that were not available from the source page.

### Sample input

```json
{
  "startUrls": [
    {
      "url": "https://example.com/events/indie-night-live"
    }
  ],
  "maxItems": 25,
  "maxConcurrency": 3,
  "extractionMode": "structuredDataWithFallback",
  "requestTimeoutSecs": 30
}
````

### Sample output

```json
{
  "eventName": "Indie Night Live",
  "performer": "The Examples",
  "venue": "Example Arena",
  "eventLocation": "Boston, MA, US",
  "eventDate": "2026-08-15T20:00:00-04:00",
  "ticketPriceMin": 45,
  "ticketPriceMax": 150,
  "currency": "USD",
  "ticketAvailability": "InStock",
  "ticketUrl": "https://example.com/events/indie-night-live/tickets",
  "platform": "example.com",
  "sourceUrl": "https://example.com/events/indie-night-live",
  "detectedAt": "2026-06-27T00:00:00.000Z",
  "extractionMethod": "structured_data",
  "confidenceScore": 0.95,
  "missingFields": []
}
```

### How to use

Run this Actor on Apify with public event URLs, export the dataset as JSON, CSV, Excel, or through the Apify API, then connect the output to Google Sheets, Make, Zapier, a webhook, or a dashboard. For price monitoring, save the input as an Apify task and schedule recurring runs.

### Pricing

This Actor uses a pay-per-event pricing model: $0.01 per tracked event row saved to the dataset. You pay only for the normalized event rows the Actor produces.

### Best practices

- Start with a small set of reviewed public event URLs.
- Prefer pages that expose schema.org `Event` and `Offer` JSON-LD.
- Use `structuredDataOnly` when you want the highest precision and can tolerate empty output.
- Use `structuredDataWithFallback` for reviewed public pages that show visible prices but no Event schema.
- Keep `maxConcurrency` low for smaller websites.
- Review source website rules before scheduling recurring runs.

### Compliance and responsible use

This Actor is for public data only. It must not be used to bypass logins, paywalls, CAPTCHAs, or security systems, collect private data, or support spam or abuse. Many ticket resale platforms (for example StubHub and Viagogo) use bot protection and have restrictive terms of service; this Actor is not designed to defeat those protections. It works on public event pages that expose `Event`/`Offer` JSON-LD and is intended for monitoring pages you are permitted to access. You are responsible for following applicable laws and source website rules.

### Limitations

- Output quality depends on the public structured data available on the source pages.
- The fallback price scan is intentionally conservative; it derives a price range from visible currency-and-number patterns and infers a name from the title/heading. It does not claim universal event-page support.
- Many resale sites use bot protection and restrictive ToS and are not supported targets.
- Some fields may be empty when the source does not publish them.
- Website markup and access policies can change.

### Troubleshooting

- Empty output usually means the page has no public `Event` JSON-LD and no visible price text.
- Invalid URL errors mean one or more input URLs are malformed.
- Slow runs can usually be improved by lowering `maxConcurrency`.
- Missing fields are source-data limitations, not inferred values.

### Changelog

- v0.1.0: Initial release with Event/Offer structured-data extraction and conservative public price fallback.

# Actor input Schema

## `startUrls` (type: `array`):

Public event pages to extract ticket prices and availability from. Use only URLs you are permitted to access without login, paywall bypass, CAPTCHA bypass, or security circumvention.

## `maxItems` (type: `integer`):

Maximum number of normalized dataset rows to save. The Actor stops pushing new rows when this limit is reached.

## `maxConcurrency` (type: `integer`):

How many event pages to process at once. Lower this for small websites or cautious monitoring.

## `extractionMode` (type: `string`):

Use structured data only, or allow a conservative fallback price scan of visible text on public event pages.

## `requestTimeoutSecs` (type: `integer`):

Maximum time to spend processing a single page before it is treated as failed.

## `proxyConfiguration` (type: `object`):

Optional Apify proxy configuration. Use only where permitted by the source website and your compliance process.

## Actor input object example

```json
{
  "startUrls": [
    {
      "url": "https://example.com/events/sample-concert"
    }
  ],
  "maxItems": 50,
  "maxConcurrency": 3,
  "extractionMode": "structuredDataWithFallback",
  "requestTimeoutSecs": 30
}
```

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "startUrls": [
        {
            "url": "https://example.com/events/sample-concert"
        }
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("technicaldost/event-ticket-price-monitor").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = { "startUrls": [{ "url": "https://example.com/events/sample-concert" }] }

# Run the Actor and wait for it to finish
run = client.actor("technicaldost/event-ticket-price-monitor").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "startUrls": [
    {
      "url": "https://example.com/events/sample-concert"
    }
  ]
}' |
apify call technicaldost/event-ticket-price-monitor --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=technicaldost/event-ticket-price-monitor",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Event Ticket Price Monitor",
        "description": "Track ticket prices and availability for events from public event pages (schema.org Event/Offer). Structured JSON: event, venue, date, price range, currency, availability.",
        "version": "0.1",
        "x-build-id": "dxep2qey370xPpaZa"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/technicaldost~event-ticket-price-monitor/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-technicaldost-event-ticket-price-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/technicaldost~event-ticket-price-monitor/runs": {
            "post": {
                "operationId": "runs-sync-technicaldost-event-ticket-price-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/technicaldost~event-ticket-price-monitor/run-sync": {
            "post": {
                "operationId": "run-sync-technicaldost-event-ticket-price-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": [
                    "startUrls"
                ],
                "properties": {
                    "startUrls": {
                        "title": "Public event page URLs",
                        "type": "array",
                        "description": "Public event pages to extract ticket prices and availability from. Use only URLs you are permitted to access without login, paywall bypass, CAPTCHA bypass, or security circumvention.",
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "maxItems": {
                        "title": "Maximum results",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of normalized dataset rows to save. The Actor stops pushing new rows when this limit is reached.",
                        "default": 50
                    },
                    "maxConcurrency": {
                        "title": "Maximum concurrency",
                        "minimum": 1,
                        "maximum": 20,
                        "type": "integer",
                        "description": "How many event pages to process at once. Lower this for small websites or cautious monitoring.",
                        "default": 3
                    },
                    "extractionMode": {
                        "title": "Extraction mode",
                        "enum": [
                            "structuredDataOnly",
                            "structuredDataWithFallback"
                        ],
                        "type": "string",
                        "description": "Use structured data only, or allow a conservative fallback price scan of visible text on public event pages.",
                        "default": "structuredDataWithFallback"
                    },
                    "requestTimeoutSecs": {
                        "title": "Request timeout seconds",
                        "minimum": 5,
                        "maximum": 180,
                        "type": "integer",
                        "description": "Maximum time to spend processing a single page before it is treated as failed.",
                        "default": 30
                    },
                    "proxyConfiguration": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Optional Apify proxy configuration. Use only where permitted by the source website and your compliance process."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
