# Public Webinar & Event Page Intelligence Agent (`jacksu/public-webinar-event-signal-agent`) Actor

Extract public webinar, event, demo, workshop, and registration page evidence: date/time, CTA links, speakers, host hints, agenda, topics, location, status, and change hashes.

- **URL**: https://apify.com/jacksu/public-webinar-event-signal-agent.md
- **Developed by:** [jack su](https://apify.com/jacksu) (community)
- **Categories:** Marketing, Business, AI
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

Pay per event

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

## Public Webinar & Event Page Intelligence Agent

Extract structured evidence from public webinar, event, demo, workshop, conference, replay, and registration pages: title, event type, date/time hints, timezone hints, registration CTAs, platform links, speakers, host hints, agenda, topics, audience, location, status, evidence URLs, and stable change hashes.

This Actor is built for AI agents, sales teams, partnerships, event marketers, SDR workflows, market researchers, and newsletter/report generators that need compact event intelligence without crawling a full website or touching a registration form.

### What It Returns

- Event title, type, and status such as upcoming, past, on-demand, postponed, or unknown.
- Visible date/time hints, timezone hints, registration CTAs, replay links, and event platform links.
- Speaker, host, agenda, audience, topic, and location evidence from visible HTML.
- Optional Schema.org Event JSON-LD as an evidence source.
- `matchedFocusTopics`, risk labels, missing fields, recommended next action, evidence snippets, evidence URLs, and a stable `eventHash`.

### Pricing Behavior

The Actor uses pay-per-event pricing and only charges the useful result event when it finds useful public webinar or event evidence.

Paid event:

- `useful-webinar-event-result`

It does not charge the useful event for:

- invalid or private-network URLs;
- failed fetches;
- pages with no useful event signals;
- `focusTopics` misses;
- `eventTypeFilter` or `allowedStatuses` misses;
- unchanged records when you pass a previous `eventHash`.

`apify-default-dataset-item` is intentionally not used.

### Scope And Safety

- Public HTTP/HTTPS pages only.
- Private-network hosts, credentials, query strings, fragments, path parameters, and token-like account paths are rejected.
- JavaScript is not executed.
- Forms are not submitted.
- Registration pages, alternate pages, calendar files, videos, PDFs, iframes, and external assets are not fetched.
- The Actor does not scrape attendee lists, private registrations, calendars, emails, tickets, or platform accounts.
- Output is evidence-based and should be reviewed before outreach, calendar enrichment, or event reporting.

### Example Input

```json
{
  "eventPageUrls": [
    "https://www.hubspot.com/resources/webinar"
  ],
  "focusTopics": [
    "AI",
    "security"
  ],
  "eventTypeFilter": [
    "webinar"
  ],
  "allowedStatuses": [
    "upcoming",
    "on-demand"
  ],
  "requestTimeoutSecs": 20
}
````

### Best Use Cases

- Turn a public event page into AI-ready evidence for outreach or account research.
- Find date/time, registration, speaker, agenda, and topic signals without manual page reading.
- Monitor event page changes without paying for unchanged results.
- Quickly separate useful event pages from generic landing pages or thin announcement pages.

# Actor input Schema

## `eventPageUrls` (type: `array`):

Public HTTP/HTTPS webinar, event, registration, replay, conference, demo, or workshop page URLs. Query parameters, fragments, credentials, path params, private-network hosts, and token-like account paths are rejected.

## `focusTopics` (type: `array`):

Optional topic terms that must appear in public event evidence before the useful result event is charged, such as AI, security, sales, automation, compliance, or developer.

## `eventTypeFilter` (type: `array`):

Optional event types that must match before the useful event is charged, such as webinar, workshop, conference, demo, roundtable, on-demand, or event.

## `allowedStatuses` (type: `array`):

Optional event statuses that must match before the useful event is charged, such as upcoming, on-demand, past, cancelled, postponed, or unknown.

## `previousEventRecords` (type: `array`):

Optional previous records from this Actor. If the stable eventHash is unchanged, the result is written without charging the useful event.

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

Maximum time in seconds to wait for the public page response.

## Actor input object example

```json
{
  "eventPageUrls": [
    "https://www.hubspot.com/resources/webinar"
  ],
  "focusTopics": [],
  "eventTypeFilter": [],
  "allowedStatuses": [],
  "previousEventRecords": [],
  "requestTimeoutSecs": 20
}
```

# Actor output Schema

## `datasetId` (type: `string`):

No description

# 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 = {};

// Run the Actor and wait for it to finish
const run = await client.actor("jacksu/public-webinar-event-signal-agent").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 = {}

# Run the Actor and wait for it to finish
run = client.actor("jacksu/public-webinar-event-signal-agent").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 '{}' |
apify call jacksu/public-webinar-event-signal-agent --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=jacksu/public-webinar-event-signal-agent",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Public Webinar & Event Page Intelligence Agent",
        "description": "Extract public webinar, event, demo, workshop, and registration page evidence: date/time, CTA links, speakers, host hints, agenda, topics, location, status, and change hashes.",
        "version": "0.1",
        "x-build-id": "WZavdgoREHpYf18RO"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/jacksu~public-webinar-event-signal-agent/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-jacksu-public-webinar-event-signal-agent",
                "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/jacksu~public-webinar-event-signal-agent/runs": {
            "post": {
                "operationId": "runs-sync-jacksu-public-webinar-event-signal-agent",
                "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/jacksu~public-webinar-event-signal-agent/run-sync": {
            "post": {
                "operationId": "run-sync-jacksu-public-webinar-event-signal-agent",
                "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": [
                    "eventPageUrls"
                ],
                "properties": {
                    "eventPageUrls": {
                        "title": "Event page URLs",
                        "minItems": 1,
                        "maxItems": 20,
                        "type": "array",
                        "description": "Public HTTP/HTTPS webinar, event, registration, replay, conference, demo, or workshop page URLs. Query parameters, fragments, credentials, path params, private-network hosts, and token-like account paths are rejected.",
                        "items": {
                            "type": "string"
                        },
                        "default": [
                            "https://www.hubspot.com/resources/webinar"
                        ]
                    },
                    "focusTopics": {
                        "title": "Focus topics",
                        "type": "array",
                        "description": "Optional topic terms that must appear in public event evidence before the useful result event is charged, such as AI, security, sales, automation, compliance, or developer.",
                        "items": {
                            "type": "string"
                        },
                        "default": []
                    },
                    "eventTypeFilter": {
                        "title": "Event type filter",
                        "type": "array",
                        "description": "Optional event types that must match before the useful event is charged, such as webinar, workshop, conference, demo, roundtable, on-demand, or event.",
                        "items": {
                            "type": "string"
                        },
                        "default": []
                    },
                    "allowedStatuses": {
                        "title": "Allowed statuses",
                        "type": "array",
                        "description": "Optional event statuses that must match before the useful event is charged, such as upcoming, on-demand, past, cancelled, postponed, or unknown.",
                        "items": {
                            "type": "string"
                        },
                        "default": []
                    },
                    "previousEventRecords": {
                        "title": "Previous event records",
                        "type": "array",
                        "description": "Optional previous records from this Actor. If the stable eventHash is unchanged, the result is written without charging the useful event.",
                        "items": {
                            "type": "object"
                        },
                        "default": []
                    },
                    "requestTimeoutSecs": {
                        "title": "Request timeout",
                        "minimum": 5,
                        "maximum": 60,
                        "type": "integer",
                        "description": "Maximum time in seconds to wait for the public page response.",
                        "default": 20
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
