# Microsoft AppSource Listings Scraper (`crawlerbros/microsoft-appsource-scraper`) Actor

Scrape app and solution listings from Microsoft AppSource (Azure Marketplace). Search by keyword, filter by product type, pricing, supported products, and publisher type

- **URL**: https://apify.com/crawlerbros/microsoft-appsource-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Developer tools, Automation, Other
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 4 bookmarks
- **User rating**: 5.00 out of 5 stars

## 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

## Microsoft AppSource Listings Scraper

Scrape app listings from [Microsoft AppSource](https://appsource.microsoft.com) — Microsoft's marketplace for business applications that integrate with Microsoft 365, Dynamics 365, and Azure. Extract app names, descriptions, ratings, pricing, publisher details, and more.

### Features

- **Keyword search** — find apps matching any query (e.g. "CRM", "project management", "AI")
- **Product type filters** — filter by app category (SaaS, Add-in, Dynamics module, etc.)
- **Pricing type filters** — filter by Free, FreeTrial, Paid, BYOL (Bring Your Own License)
- **Publisher type filter** — Microsoft, ThirdParty, or all
- **Supported products** — filter by Microsoft product (Teams, Excel, Word, etc.)
- **Minimum rating filter** — only return apps above a star threshold
- **Market support** — 10 markets: US, UK, Germany, France, Japan, Australia, Canada, India, Brazil, Singapore
- **Sort options** — by relevance, name, rating, or last modified
- Up to 1,000 results per run

### Input

| Field | Type | Description |
|-------|------|-------------|
| `searchQuery` | string | Keyword to search in app listings |
| `productTypes` | array | Filter by product categories |
| `pricingTypes` | array | Filter by pricing: Free, FreeTrial, Paid, BYOL |
| `publisherTypes` | select | Publisher type: Microsoft, ThirdParty, or all |
| `supportedProducts` | array | Filter by Microsoft product integration |
| `minRating` | number | Minimum average rating (0–5) |
| `market` | select | Market/region: US, GB, DE, FR, JP, AU, CA, IN, BR, SG |
| `orderBy` | select | Sort order |
| `maxItems` | integer | Maximum results to return (1–1000, default 20) |

### Output

Each record contains:

| Field | Description |
|-------|-------------|
| `uniqueProductId` | Unique AppSource product identifier |
| `displayName` | App display name |
| `description` | Full app description (HTML-cleaned, max 2000 chars) |
| `summary` | Short one-line summary |
| `publisherId` | Publisher unique ID |
| `publisherDisplayName` | Publisher name |
| `publisherType` | Publisher type (Microsoft/ThirdParty) |
| `productType` | Product category |
| `pricingTypes` | List of pricing models |
| `ratingAverage` | Average star rating (0–5) |
| `ratingCount` | Number of ratings |
| `supportedProducts` | List of supported Microsoft products |
| `iconUrl` | App icon image URL |
| `badges` | Achievement/quality badges |
| `lastModifiedDateTime` | Last update timestamp |
| `url` | Direct link to AppSource listing |
| `scrapedAt` | ISO 8601 scrape timestamp |

### Example Output

```json
{
  "uniqueProductId": "WA104380862",
  "displayName": "Salesforce",
  "description": "Salesforce integration for Microsoft Teams and Office 365.",
  "summary": "Connect your Salesforce CRM with Microsoft 365.",
  "publisherDisplayName": "Salesforce.com",
  "publisherType": "ThirdParty",
  "productType": "SaaS",
  "pricingTypes": ["FreeTrial", "Paid"],
  "ratingAverage": 4.2,
  "ratingCount": 1847,
  "supportedProducts": ["Teams", "Office 365"],
  "iconUrl": "https://store-images.s-microsoft.com/image/...",
  "url": "https://appsource.microsoft.com/en-us/product/office/WA104380862",
  "scrapedAt": "2026-05-22T10:00:00+00:00",
  "recordType": "app"
}
````

### FAQ

**Does this require a Microsoft account or API key?**
No — the scraper uses the same public catalog API that the AppSource website itself uses. No authentication required.

**How many apps are available on AppSource?**
Microsoft AppSource has thousands of listings. The API supports up to 100,000 results.

**What does "market" do?**
Different markets may surface different apps or pricing. The US market has the most listings.

**What are pricing types?**

- `Free` — completely free
- `FreeTrial` — free trial period available
- `Paid` — requires payment
- `BYOL` — Bring Your Own License (use existing software license)

# Actor input Schema

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

How to find apps: search by keyword, browse by category, browse by Microsoft product, or get all apps.

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

Search term for apps (e.g. 'CRM', 'project management', 'analytics'). Used in 'search' mode.

## `category` (type: `string`):

App category to browse (used in 'byCategory' mode).

## `product` (type: `string`):

Filter by supported Microsoft product (used in 'byProduct' mode).

## `productTypes` (type: `array`):

Filter by product type. Leave empty for all types.

## `pricingTypes` (type: `array`):

Filter by pricing model (e.g. Free, FreeTrial, Paid, BYOL).

## `publisherTypes` (type: `string`):

Filter by publisher type.

## `supportedProducts` (type: `array`):

Filter by supported Microsoft product (e.g. Office 365, Dynamics 365). Used in 'search' mode for fine-grained filtering.

## `minRating` (type: `number`):

Minimum average star rating (1-5). Leave as 0 for no minimum.

## `market` (type: `string`):

Market/region for pricing. Use 'US' for United States.

## `orderBy` (type: `string`):

Sort order for results.

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

Maximum number of app listings to return.

## Actor input object example

```json
{
  "mode": "search",
  "searchQuery": "CRM",
  "category": "",
  "product": "",
  "productTypes": [],
  "pricingTypes": [],
  "publisherTypes": "",
  "supportedProducts": [],
  "minRating": 0,
  "market": "US",
  "orderBy": "",
  "maxItems": 5
}
```

# 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": "search",
    "searchQuery": "CRM",
    "productTypes": [],
    "pricingTypes": [],
    "publisherTypes": "",
    "supportedProducts": [],
    "minRating": 0,
    "market": "US",
    "orderBy": "",
    "maxItems": 5
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/microsoft-appsource-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": "search",
    "searchQuery": "CRM",
    "productTypes": [],
    "pricingTypes": [],
    "publisherTypes": "",
    "supportedProducts": [],
    "minRating": 0,
    "market": "US",
    "orderBy": "",
    "maxItems": 5,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/microsoft-appsource-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": "search",
  "searchQuery": "CRM",
  "productTypes": [],
  "pricingTypes": [],
  "publisherTypes": "",
  "supportedProducts": [],
  "minRating": 0,
  "market": "US",
  "orderBy": "",
  "maxItems": 5
}' |
apify call crawlerbros/microsoft-appsource-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Microsoft AppSource Listings Scraper",
        "description": "Scrape app and solution listings from Microsoft AppSource (Azure Marketplace). Search by keyword, filter by product type, pricing, supported products, and publisher type",
        "version": "1.0",
        "x-build-id": "CfKnemwsZlsfIALeO"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~microsoft-appsource-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-microsoft-appsource-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~microsoft-appsource-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-microsoft-appsource-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~microsoft-appsource-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-microsoft-appsource-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": "Scrape Mode",
                        "enum": [
                            "search",
                            "byCategory",
                            "byProduct",
                            "allApps"
                        ],
                        "type": "string",
                        "description": "How to find apps: search by keyword, browse by category, browse by Microsoft product, or get all apps.",
                        "default": "search"
                    },
                    "searchQuery": {
                        "title": "Search Query",
                        "type": "string",
                        "description": "Search term for apps (e.g. 'CRM', 'project management', 'analytics'). Used in 'search' mode.",
                        "default": ""
                    },
                    "category": {
                        "title": "Category",
                        "enum": [
                            "",
                            "Analytics",
                            "Collaboration",
                            "Finance",
                            "Human Resources",
                            "IT & Management Tools",
                            "Marketing",
                            "Operations & Supply Chain",
                            "Sales",
                            "Customer Service",
                            "Project Management",
                            "Productivity",
                            "Security",
                            "Commerce"
                        ],
                        "type": "string",
                        "description": "App category to browse (used in 'byCategory' mode).",
                        "default": ""
                    },
                    "product": {
                        "title": "Microsoft Product",
                        "enum": [
                            "",
                            "Microsoft Teams",
                            "Microsoft 365",
                            "Power BI",
                            "Power Apps",
                            "Power Automate",
                            "Dynamics 365",
                            "Azure",
                            "SharePoint",
                            "Excel",
                            "Outlook",
                            "Word",
                            "Business Central"
                        ],
                        "type": "string",
                        "description": "Filter by supported Microsoft product (used in 'byProduct' mode).",
                        "default": ""
                    },
                    "productTypes": {
                        "title": "Product Types",
                        "type": "array",
                        "description": "Filter by product type. Leave empty for all types.",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "pricingTypes": {
                        "title": "Pricing Types",
                        "type": "array",
                        "description": "Filter by pricing model (e.g. Free, FreeTrial, Paid, BYOL).",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "publisherTypes": {
                        "title": "Publisher Type",
                        "enum": [
                            "",
                            "Microsoft",
                            "ThirdParty"
                        ],
                        "type": "string",
                        "description": "Filter by publisher type.",
                        "default": ""
                    },
                    "supportedProducts": {
                        "title": "Supported Products",
                        "type": "array",
                        "description": "Filter by supported Microsoft product (e.g. Office 365, Dynamics 365). Used in 'search' mode for fine-grained filtering.",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "minRating": {
                        "title": "Minimum Rating",
                        "minimum": 0,
                        "maximum": 5,
                        "type": "number",
                        "description": "Minimum average star rating (1-5). Leave as 0 for no minimum.",
                        "default": 0
                    },
                    "market": {
                        "title": "Market",
                        "enum": [
                            "US",
                            "GB",
                            "DE",
                            "FR",
                            "JP",
                            "AU",
                            "CA",
                            "IN",
                            "BR",
                            "SG"
                        ],
                        "type": "string",
                        "description": "Market/region for pricing. Use 'US' for United States.",
                        "default": "US"
                    },
                    "orderBy": {
                        "title": "Sort By",
                        "enum": [
                            "",
                            "RatingAverage desc",
                            "RatingCount desc",
                            "LastModifiedDateTime desc"
                        ],
                        "type": "string",
                        "description": "Sort order for results.",
                        "default": ""
                    },
                    "maxItems": {
                        "title": "Maximum Results",
                        "minimum": 1,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Maximum number of app listings to return.",
                        "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
