# List all platform domains with full metadata GET https://api2.freecustom.email/v1/domains/all Same domain list as `GET /v1/domains` but always includes full expiry metadata for every domain — useful for dashboard integrations that monitor domain health or want to proactively alert users before a domain expires. Plan gating is identical: Growth / Enterprise see pro-tier domains, all other plans see free-tier only. > This endpoint covers **platform domains** only. For your own verified > custom domains use `GET /v1/custom-domains`. Reference: https://docs.freecustom.email/free-custom-email-api/v-1/domains/all/list-all-platform-domains-with-full-metadata ## OpenAPI Specification ```yaml openapi: 3.1.0 info: title: collection version: 1.0.0 paths: /v1/domains/all: get: operationId: list-all-platform-domains-with-full-metadata summary: List all platform domains with full metadata description: | Same domain list as `GET /v1/domains` but always includes full expiry metadata for every domain — useful for dashboard integrations that monitor domain health or want to proactively alert users before a domain expires. Plan gating is identical: Growth / Enterprise see pro-tier domains, all other plans see free-tier only. > This endpoint covers **platform domains** only. For your own verified > custom domains use `GET /v1/custom-domains`. tags: - subpackage_v1.subpackage_v1/domains.subpackage_v1/domains/all parameters: - name: Authorization in: header description: Bearer authentication required: true schema: type: string responses: '200': description: OK content: application/json: schema: $ref: >- #/components/schemas/v1_domains_all_List all platform domains with full metadata_Response_200 '401': description: Unauthorized content: application/json: schema: $ref: '#/components/schemas/GetV1DomainsAllRequestUnauthorizedError' '429': description: Too Many Requests content: application/json: schema: $ref: >- #/components/schemas/GetV1DomainsAllRequestTooManyRequestsError servers: - url: https://api2.freecustom.email components: schemas: V1DomainsAllGetResponsesContentApplicationJsonSchemaDataItems: type: object properties: tags: type: array items: type: string tier: type: string domain: type: string expired: type: boolean expires_at: type: string format: date expiring_soon: type: boolean expires_in_days: type: integer required: - tags - tier - domain - expired - expires_at - expiring_soon - expires_in_days title: V1DomainsAllGetResponsesContentApplicationJsonSchemaDataItems v1_domains_all_List all platform domains with full metadata_Response_200: type: object properties: data: type: array items: $ref: >- #/components/schemas/V1DomainsAllGetResponsesContentApplicationJsonSchemaDataItems count: type: integer success: type: boolean required: - data - count - success title: v1_domains_all_List all platform domains with full metadata_Response_200 GetV1DomainsAllRequestUnauthorizedError: type: object properties: error: type: string message: type: string success: type: boolean required: - error - message - success title: GetV1DomainsAllRequestUnauthorizedError GetV1DomainsAllRequestTooManyRequestsError: type: object properties: hint: type: string error: type: string message: type: string success: type: boolean credits_url: type: string format: uri upgrade_url: type: string format: uri required: - hint - error - message - success - credits_url - upgrade_url title: GetV1DomainsAllRequestTooManyRequestsError securitySchemes: bearerAuth: type: http scheme: bearer ``` ## SDK Code Examples ```python v1_domains_all_List all platform domains with full metadata_example import requests url = "https://api2.freecustom.email/v1/domains/all" headers = {"Authorization": "Bearer "} response = requests.get(url, headers=headers) print(response.json()) ``` ```javascript v1_domains_all_List all platform domains with full metadata_example const url = 'https://api2.freecustom.email/v1/domains/all'; const options = {method: 'GET', headers: {Authorization: 'Bearer '}}; try { const response = await fetch(url, options); const data = await response.json(); console.log(data); } catch (error) { console.error(error); } ``` ```go v1_domains_all_List all platform domains with full metadata_example package main import ( "fmt" "net/http" "io" ) func main() { url := "https://api2.freecustom.email/v1/domains/all" req, _ := http.NewRequest("GET", url, nil) req.Header.Add("Authorization", "Bearer ") res, _ := http.DefaultClient.Do(req) defer res.Body.Close() body, _ := io.ReadAll(res.Body) fmt.Println(res) fmt.Println(string(body)) } ``` ```ruby v1_domains_all_List all platform domains with full metadata_example require 'uri' require 'net/http' url = URI("https://api2.freecustom.email/v1/domains/all") http = Net::HTTP.new(url.host, url.port) http.use_ssl = true request = Net::HTTP::Get.new(url) request["Authorization"] = 'Bearer ' response = http.request(request) puts response.read_body ``` ```java v1_domains_all_List all platform domains with full metadata_example import com.mashape.unirest.http.HttpResponse; import com.mashape.unirest.http.Unirest; HttpResponse response = Unirest.get("https://api2.freecustom.email/v1/domains/all") .header("Authorization", "Bearer ") .asString(); ``` ```php v1_domains_all_List all platform domains with full metadata_example request('GET', 'https://api2.freecustom.email/v1/domains/all', [ 'headers' => [ 'Authorization' => 'Bearer ', ], ]); echo $response->getBody(); ``` ```csharp v1_domains_all_List all platform domains with full metadata_example using RestSharp; var client = new RestClient("https://api2.freecustom.email/v1/domains/all"); var request = new RestRequest(Method.GET); request.AddHeader("Authorization", "Bearer "); IRestResponse response = client.Execute(request); ``` ```swift v1_domains_all_List all platform domains with full metadata_example import Foundation let headers = ["Authorization": "Bearer "] let request = NSMutableURLRequest(url: NSURL(string: "https://api2.freecustom.email/v1/domains/all")! as URL, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0) request.httpMethod = "GET" request.allHTTPHeaderFields = headers let session = URLSession.shared let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in if (error != nil) { print(error as Any) } else { let httpResponse = response as? HTTPURLResponse print(httpResponse) } }) dataTask.resume() ```