# CocoaPods Scraper (`crawlerbros/cocoapods-scraper`) Actor

Scrape CocoaPods package registry - search pods by name or fetch specific pods with full metadata including platforms, dependencies, and source URLs.

- **URL**: https://apify.com/crawlerbros/cocoapods-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Developer tools, Automation
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $3.00 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

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

## CocoaPods Scraper

Extract detailed metadata for CocoaPods packages — including summary, description, platforms, Swift version support, dependencies, authors, and source URLs.

### What is CocoaPods Scraper?

[CocoaPods](https://cocoapods.org) is the dependency manager for Swift and Objective-C projects on Apple platforms. It hosts tens of thousands of open-source libraries for iOS, macOS, tvOS, watchOS, and visionOS. This actor lets you search the CocoaPods registry by name and retrieve full podspec metadata for any pod.

### Features

- **Search Pods**: Find pods by name (substring match against full registry)
- **Get By Name**: Retrieve complete metadata for specific pods by name
- **Full Podspec Metadata**: Version, platforms, dependencies, authors, Swift version support, and source/repository URLs
- **No auth required**: Uses the public CocoaPods trunk API
- **Handles all license formats**: String and dict-style license fields

### Use Cases

- Audit iOS/macOS dependency ecosystems
- Research popular CocoaPod libraries for specific platforms
- Track Swift version compatibility across packages
- Monitor dependencies for security or licensing compliance
- Build package discovery tools for mobile developers

### Input

| Field | Type | Description | Default |
|-------|------|-------------|---------|
| `mode` | Select | `searchPods` or `getByName` | `searchPods` |
| `searchQuery` | String | Filter pods by name (case-insensitive substring) | `networking` |
| `podNames` | Array | Pod names for `getByName` mode | `["Alamofire", "Moya"]` |
| `maxItems` | Integer | Maximum records to return (1–500) | `50` |

#### Input Example — Search Pods

```json
{
  "mode": "searchPods",
  "searchQuery": "networking",
  "maxItems": 20
}
````

#### Input Example — Get By Name

```json
{
  "mode": "getByName",
  "podNames": ["Alamofire", "Moya", "Kingfisher", "RxSwift"]
}
```

### Output

```json
{
  "podName": "Alamofire",
  "summary": "Elegant HTTP Networking in Swift",
  "homepage": "https://github.com/Alamofire/Alamofire",
  "license": "MIT",
  "authors": ["Alamofire Software Foundation"],
  "platforms": {
    "ios": "10.0",
    "osx": "10.12",
    "tvos": "10.0",
    "visionos": "1.0",
    "watchos": "3.0"
  },
  "version": "5.11.2",
  "sourceUrl": "https://cocoapods.org/pods/Alamofire",
  "repositoryUrl": "https://github.com/Alamofire/Alamofire.git",
  "downloadUrl": "https://github.com/Alamofire/Alamofire.git#5.11.2",
  "swiftVersions": ["5"],
  "recordType": "pod",
  "scrapedAt": "2026-05-30T07:51:06.235383+00:00"
}
```

### Output Fields

| Field | Type | Description |
|-------|------|-------------|
| `podName` | String | Pod name |
| `summary` | String | One-line description |
| `description` | String | Full description (if provided) |
| `homepage` | String | Project homepage URL |
| `license` | String | License identifier (e.g. `MIT`, `Apache-2.0`) |
| `authors` | Array | List of author names |
| `platforms` | Object | Supported platforms with minimum version (e.g. `{"ios": "12.0"}`) |
| `version` | String | Latest published version |
| `sourceUrl` | String | CocoaPods.org page URL |
| `repositoryUrl` | String | Git repository URL |
| `downloadUrl` | String | Git repository URL with version tag |
| `swiftVersions` | Array | Supported Swift versions |
| `dependencies` | Array | Names of declared dependencies |
| `recordType` | String | Always `"pod"` |
| `scrapedAt` | String | ISO 8601 timestamp |

### FAQs

**Does this require an API key?**
No. The CocoaPods trunk API and CDN are completely public.

**How many pods can I search?**
The CocoaPods registry contains 90,000+ pods. Use `maxItems` to control how many you retrieve (up to 500).

**What does `searchQuery` match against?**
It performs a case-insensitive substring match against pod names from the full registry list.

**What platforms are supported?**
CocoaPods supports iOS, macOS (osx), tvOS, watchOS, and visionOS. The `platforms` field shows the minimum version for each supported platform.

**Why might some fields be missing?**
Fields are only included when the pod's podspec actually declares them. For example, older pods may not declare `swiftVersions` or `description`.

**How current is the data?**
The actor fetches live data from the CocoaPods trunk API and CDN which are updated when pod authors publish new versions.

**Can I get all pods?**
Yes — leave `searchQuery` empty to get the first `maxItems` pods from the registry alphabetically.

# Actor input Schema

## `mode` (type: `string`):

Scraping mode: search pods by query or fetch specific pod(s) by name.

## `searchQuery` (type: `string`):

Filter pods by name (case-insensitive substring match). Leave empty to get top results up to maxItems.

## `podNames` (type: `array`):

List of CocoaPod names to fetch (used in getByName mode). e.g. \["Alamofire", "AFNetworking"].

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

Maximum number of pod records to return (1–500).

## Actor input object example

```json
{
  "mode": "searchPods",
  "searchQuery": "networking",
  "podNames": [
    "Alamofire",
    "Moya"
  ],
  "maxItems": 10
}
```

# 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 = {
    "mode": "searchPods",
    "searchQuery": "networking",
    "podNames": [
        "Alamofire",
        "Moya"
    ],
    "maxItems": 10
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/cocoapods-scraper").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 = {
    "mode": "searchPods",
    "searchQuery": "networking",
    "podNames": [
        "Alamofire",
        "Moya",
    ],
    "maxItems": 10,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/cocoapods-scraper").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 '{
  "mode": "searchPods",
  "searchQuery": "networking",
  "podNames": [
    "Alamofire",
    "Moya"
  ],
  "maxItems": 10
}' |
apify call crawlerbros/cocoapods-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=crawlerbros/cocoapods-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "CocoaPods Scraper",
        "description": "Scrape CocoaPods package registry - search pods by name or fetch specific pods with full metadata including platforms, dependencies, and source URLs.",
        "version": "1.0",
        "x-build-id": "ZhJUsRqcDdB8vqxXh"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~cocoapods-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-cocoapods-scraper",
                "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/crawlerbros~cocoapods-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-cocoapods-scraper",
                "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/crawlerbros~cocoapods-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-cocoapods-scraper",
                "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": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "searchPods",
                            "getByName"
                        ],
                        "type": "string",
                        "description": "Scraping mode: search pods by query or fetch specific pod(s) by name.",
                        "default": "searchPods"
                    },
                    "searchQuery": {
                        "title": "Search Query",
                        "type": "string",
                        "description": "Filter pods by name (case-insensitive substring match). Leave empty to get top results up to maxItems."
                    },
                    "podNames": {
                        "title": "Pod Names",
                        "type": "array",
                        "description": "List of CocoaPod names to fetch (used in getByName mode). e.g. [\"Alamofire\", \"AFNetworking\"].",
                        "items": {
                            "type": "string"
                        }
                    },
                    "maxItems": {
                        "title": "Max Items",
                        "minimum": 1,
                        "maximum": 500,
                        "type": "integer",
                        "description": "Maximum number of pod records to return (1–500).",
                        "default": 100
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
