Skip to contentSkip to navigationSkip to topbar
On this page

Retrieve all IP addresses



API Overview

api-overview page anchor

Elements that can be shared among more than one endpoint definition.


GET/v3/ips

Base url: https://api.sendgrid.com (for global users and subusers)

Base url: https://api.eu.sendgrid.com (for EU regional subusers)

This endpoint allows you to retrieve a paginated list of all assigned and unassigned IPs.

Response includes warm up status, pools, assigned subusers, and reverse DNS info. The start_date field corresponds to when warmup started for that IP.

A single IP address or a range of IP addresses may be dedicated to an account in order to send email for multiple domains. The reputation of this IP is determined by the aggregate performance of all email traffic sent from it.

You can use the limit query parameter to set the page size. If your list contains more items than the page size permits, you can make multiple requests. Use the offset query parameter to control the position in the list from which to start retrieving additional items.


Authentication

authentication page anchor
Property nameTypeRequiredDescription
Authorizationstringrequired
Default: Bearer <<YOUR_API_KEY_HERE>>
Property nameTypeRequiredDescription
ipstring

Optional

The IP address to get


exclude_whitelabelsboolean

Optional

Should we exclude reverse DNS records (whitelabels)?


limitinteger

Optional

limit sets the page size, i.e. maximum number of items from the list to be returned for a single API request. If omitted, the default page size is used.

Minimum: 1Default: 10

offsetinteger

Optional

The number of items in the list to skip over before starting to retrieve the items for the requested page. The default offset of 0 represents the beginning of the list, i.e. the start of the first page. To request the second page of the list, set the offset to the page size as determined by limit. Use multiples of the page size as your offset to request further consecutive pages. E.g. assume your page size is set to 10. An offset of 10 requests the second page, an offset of 20 requests the third page and so on, provided there are sufficiently many items in your list.

Minimum: 0Default: 0

subuserstring

Optional

The subuser you are requesting for.


sort_by_directionenum<string>

Optional

The direction to sort the results.

Possible values:
descasc
200
SchemaExample

Array of:

Property nameTypeRequiredDescriptionChild properties
ipstring

An IP address.


subusersarray[string]

The subusers that are able to send email from this IP.


rdnsstring

The reverse DNS record for this IP address.


poolsarray[string]

The IP pools that this IP has been added to.


warmupboolean

Indicates if this IP address is currently warming up.


start_datenumber or null

The date that the IP address was entered into warmup.


whitelabeledboolean

Indicates if this IP address is associated with a reverse DNS record.


assigned_atinteger or null

The date that the IP address was assigned to the user.


Retrieving paginated results

retrieving-paginated-results page anchor

To perform a request for the first page of the paginated list of all IP addresses using the default page size, you can omit the limit and offset query parameters:

Retrieve first page from list of all IP addressesLink to code sample: Retrieve first page from list of all IP addresses
1
const client = require("@sendgrid/client");
2
client.setApiKey(process.env.SENDGRID_API_KEY);
3
4
const queryParams = {
5
limit: 10,
6
};
7
8
const request = {
9
url: `/v3/ips`,
10
method: "GET",
11
qs: queryParams,
12
};
13
14
client
15
.request(request)
16
.then(([response, body]) => {
17
console.log(response.statusCode);
18
console.log(response.body);
19
})
20
.catch((error) => {
21
console.error(error);
22
});

If you want to specify a page size of your choice, you can use the limit query parameter. Assume you want a page size of no more than 5 items per request, to retrieve the first page you can use the limit parameter without specifying an offset:

Retrieve first page from list of all IP addresses with a specified page sizeLink to code sample: Retrieve first page from list of all IP addresses with a specified page size
1
const client = require("@sendgrid/client");
2
client.setApiKey(process.env.SENDGRID_API_KEY);
3
4
const queryParams = {
5
limit: 5,
6
};
7
8
const request = {
9
url: `/v3/ips`,
10
method: "GET",
11
qs: queryParams,
12
};
13
14
client
15
.request(request)
16
.then(([response, body]) => {
17
console.log(response.statusCode);
18
console.log(response.body);
19
})
20
.catch((error) => {
21
console.error(error);
22
});

If you want to retrieve items beyond the first page, you can use the offset parameter as follows. Assume you are still working with a page size of 5 as determined by your limit query parameter and you have more than 15 items. To request the fourth page of items, you can use the offset parameter to skip over the first 15 items, i.e. you start retrieving items starting after the first three pages of 5 items each:

Retrieve a specific page from the list of all IP addressesLink to code sample: Retrieve a specific page from the list of all IP addresses
1
const client = require("@sendgrid/client");
2
client.setApiKey(process.env.SENDGRID_API_KEY);
3
4
const queryParams = {
5
limit: 5,
6
offset: 15,
7
};
8
9
const request = {
10
url: `/v3/ips`,
11
method: "GET",
12
qs: queryParams,
13
};
14
15
client
16
.request(request)
17
.then(([response, body]) => {
18
console.log(response.statusCode);
19
console.log(response.body);
20
})
21
.catch((error) => {
22
console.error(error);
23
});

Need some help?

Terms of service

Copyright © 2025 Twilio Inc.