Skip to content
Scrappa Get API key

Trustpilot Company Reviews

Get reviews for a company on Trustpilot. Filters are applied after fetch; pagination counts reflect Trustpilot results. Review language defaults to languages=all; pass a 2-letter language code such as languages=de for German reviews.

Run this endpoint

Trustpilot Company Reviews 1 credit/request

Endpoint

GET https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all
Request preview GET
https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all
Auth header x-api-key
Cost 1 credit/request
company_domain = amazon.com
Response preview 200 OK
{
    "reviews": []
}

Parameters

Start with the required fields, then add optional filters only when your use case needs them.

Runnable path

1 required parameter needed before sending a request.

9 optional filters available.

company_domain string Required

Company domain

Example value amazon.com
page integer Optional

Page number (1-999)

Example value 1
verified boolean Optional

Filter verified reviews

Example value true
with_replies boolean Optional

Only reviews with replies

Example value true
sort string Optional

Sort order. Valid values: "relevance" for Trustpilot relevance ranking or "recency" for newest reviews first. No other sort values are accepted.

Example value relevance
query string Optional

Search within review text/title

Example value coffee shops
rating string Optional

Comma-separated ratings (e.g. 4,5)

Example value example
locale string Optional

Locale (e.g. en-US, de-DE)

Example value en-US
languages string Optional

Review language filter. Defaults to "all". Use "all" to fetch reviews in all languages, or a 2-letter code like en or de. Trustpilot expects language codes here, not locale codes: use de, not de-DE.

Example value all
fields string Optional

Comma-separated fields to include (e.g., reviews,businessUnit.displayName). Use dot notation for nested fields. Omit to get all fields.

Example value title,link,snippet

Request Examples

<?php

$curl = curl_init();

curl_setopt_array($curl, [
    CURLOPT_URL => "https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all",
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_ENCODING => "",
    CURLOPT_MAXREDIRS => 10,
    CURLOPT_TIMEOUT => 30,
    CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
    CURLOPT_CUSTOMREQUEST => "GET",
    CURLOPT_HTTPHEADER => [
        "x-api-key: YOUR_API_KEY_HERE"
    ],
]);

$response = curl_exec($curl);
$err = curl_error($curl);

curl_close($curl);

if ($err) {
    echo "cURL Error #:" . $err;
} else {
    echo $response;
}
<?php

use Illuminate\Support\Facades\Http;

$response = Http::timeout(30)
    ->withHeaders(['x-api-key' => 'YOUR_API_KEY_HERE'])
    ->get('https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all');

if ($response->successful()) {
    echo $response->body();
} else {
    echo "Error: " . $response->status();
}
const options = {
    method: 'GET',
    headers: {
        'x-api-key': 'YOUR_API_KEY_HERE'
    }
};

fetch('https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all', options)
    .then(response => {
        if (!response.ok) {
            throw new Error(`HTTP error! status: ${response.status}`);
        }
        return response.text();
    })
    .then(data => console.log(data))
    .catch(error => console.error('Error:', error));
const axios = require('axios');

const options = {
    method: 'GET',
    url: 'https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all',
    headers: {
        x-api-key: 'YOUR_API_KEY_HERE',
    }
};

try {
    const response = await axios(options);
    console.log(response.data);
} catch (error) {
    console.error('Error:', error.message);
}
require 'net/http'
require 'uri'

uri = URI.parse("https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all")
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = uri.scheme == 'https'

request = Net::HTTP::Get.new(uri.request_uri)
request['x-api-key'] = 'YOUR_API_KEY_HERE'

begin
    response = http.request(request)
    puts response.body
rescue => e
    puts "Error: #{e.message}"
end
import http.client
import json

conn = http.client.HTTPSConnection("scrappa.co")

headers = {
    'x-api-key': 'YOUR_API_KEY_HERE',
}

try:
    conn.request("GET", "/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all", headers=headers)
    res = conn.getresponse()
    data = res.read()
    print(data.decode("utf-8"))
except Exception as e:
    print(f"Error: {e}")
finally:
    conn.close()
import requests

headers = {
    'x-api-key': 'YOUR_API_KEY_HERE',
}

try:
    response = requests.get('https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all', headers=headers)
    response.raise_for_status()
    print(response.text)
except requests.exceptions.RequestException as e:
    print(f"Error: {e}")
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import java.io.IOException;

public class ApiExample {
    public static void main(String[] args) {
        OkHttpClient client = new OkHttpClient();

        Request request = new Request.Builder()
            .url("https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all")
        .addHeader("x-api-key", "YOUR_API_KEY_HERE")
            .build();

        try (Response response = client.newCall(request).execute()) {
            if (response.isSuccessful()) {
                System.out.println(response.body().string());
            } else {
                System.out.println("Error: " + response.code());
            }
        } catch (IOException e) {
            System.out.println("Error: " + e.getMessage());
        }
    }
}
package main

import (
    "fmt"
    "net/http"
    "io/ioutil"
)

func main() {
    client := &http.Client{}
    req, err := http.NewRequest("GET", "https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all", nil)
    if err != nil {
        fmt.Println("Error creating request:", err)
        return
    }
    req.Header.Set("x-api-key", "YOUR_API_KEY_HERE")

    resp, err := client.Do(req)
    if err != nil {
        fmt.Println("Error making request:", err)
        return
    }
    defer resp.Body.Close()

    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        fmt.Println("Error reading response:", err)
        return
    }

    fmt.Println(string(body))
}
#!/bin/bash

curl -X GET \
    -H "x-api-key: YOUR_API_KEY_HERE" \
    "https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all"
using System;
using System.Net.Http;
using System.Threading.Tasks;

class Program
{
    static async Task Main()
    {
        using var client = new HttpClient();
        client.DefaultRequestHeaders.Add("x-api-key", "YOUR_API_KEY_HERE");

        try
        {
            var response = await client.SendAsync(new HttpRequestMessage(HttpMethod.Get, "https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all"));
            var content = await response.Content.ReadAsStringAsync();
            Console.WriteLine(content);
        }
        catch (Exception ex)
        {
            Console.WriteLine($"Error: {ex.Message}");
        }
    }
}
import axios from 'axios';

async function run(): Promise<void> {
    try {
        const response = await axios({
            method: 'GET',
            url: 'https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all',
            headers: {
        'x-api-key': 'YOUR_API_KEY_HERE',
            },
        });

        console.log(response.data);
    } catch (error) {
        console.error('Error:', error);
    }
}

void run();
use reqwest::Client;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let client = Client::new();

    let response = client
        .get("https://scrappa.co/api/trustpilot/company-reviews?company_domain=amazon.com&languages=all")
        .header("x-api-key", "YOUR_API_KEY_HERE")
        .send()
        .await?;

    println!("{}", response.text().await?);

    Ok(())
}

Response Schema

Example response fields are illustrative; inspect the JSON before integrating.

Example response fields

Scan these fields before integrating.

reviews
JSON Response
200 OK
{
    "reviews": []
}

Errors

Handle these documented responses before retrying or showing customer-facing failures.

422

Validation Error

The company_domain parameter is required and review filters such as page, rating, sort, verified, with_replies, languages, and date_posted must be valid.

{
    "errors": {
        "company_domain": [
            "The company_domain field is required."
        ]
    },
    "message": "The request validation failed"
}
402

Insufficient Credits

Your API key is valid, but the account has no free, subscription, or package credits available.

{
    "error": "You've ran out of credits to use please purchase a subscription or a package."
}
500

Trustpilot Service Error

The Trustpilot endpoint could not complete the current scrape attempt.

{
    "code": "SERVICE_ERROR",
    "error": "fallback_chain_exhausted",
    "message": "Service temporarily unavailable. Please try again.",
    "success": false,
    "status_code": 500
}
503

Trustpilot Reviews WAF Or Cascade Exhausted

Trustpilot WAF protection or the bounded in-house/RapidAPI cascade exhausted the available fetch path for this endpoint.

{
    "code": "TRUSTPILOT_BLOCKED",
    "error": "fallback_chain_exhausted",
    "message": "Trustpilot company reviews are temporarily unavailable after WAF-protected fetch and fallback tiers were exhausted.",
    "success": false,
    "status_code": 503
}

Generate Code with AI

Copy a ready-made prompt with all the endpoint details, parameters, and example responses. Paste it into ChatGPT, Claude, or any AI assistant to instantly generate working code.

Try It Live

Test this endpoint in our interactive playground with real data.