DNS
Managed DNS zones and records with domain-ownership verification across Cloudflare / Route53 / AliDNS. (Not domain registration.)
Overview
https://api.infrai.cc/v1/dnsAuthorization: Bearer $INFRAI_API_KEY# Call any /v1/dns capability over raw HTTP — no SDK to install.
# curl:
curl https://api.infrai.cc/v1/dns/... \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json"Methods
dns.domain.add
Bind a custom domain by creating a managed DNS zone at the vendor (Cloudflare / Route53 / AliDNS); returns zone_id + name servers. Not domain registration.
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
domain | string | Required | Apex domain, e.g. example.com. |
vendor | string | Optional | Pin to a DNS vendor (BYOK / explicit). |
account_id | string | Optional | Vendor account id / caller reference. |
metadata | Record<string, unknown> | Optional | Arbitrary key/value metadata. |
Returns
Zone { zone_id, domain, nameservers, status }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X POST https://api.infrai.cc/v1/dns/domain/add \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"domain": "..."}'import os, requests
resp = requests.post(
"https://api.infrai.cc/v1/dns/domain/add",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'domain': '...'},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/add",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/add",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.domain.get
Fetch a bound domain (zone) by zone_id or name, returning its state and name servers.
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
domain | string | Required | Apex domain, e.g. example.com. |
zone_id | string | Optional | Vendor zone id (preferred for get/verify/delete). |
vendor | string | Optional | Pin to a DNS vendor (BYOK / explicit). |
Returns
ZoneExample
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X GET https://api.infrai.cc/v1/dns/domain/get \
-H "Authorization: Bearer $INFRAI_API_KEY"import os, requests
resp = requests.get(
"https://api.infrai.cc/v1/dns/domain/get",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/get",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/get",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.domain.list
List the bound custom domains (managed zones) for the account at the configured DNS vendor.
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
cursor | string | Optional | Opaque pagination cursor. |
limit | number | Optional | Maximum number of items to return. |
Returns
{ items: Zone[], next_cursor?: string }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X GET https://api.infrai.cc/v1/dns/domain/list \
-H "Authorization: Bearer $INFRAI_API_KEY"import os, requests
resp = requests.get(
"https://api.infrai.cc/v1/dns/domain/list",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.domain.verify
Verify a bound domain's activation/delegation against the same vendor zone it was created on (sticky_resource); read-only lookup of zone state.
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
domain | string | Required | Apex domain, e.g. example.com. |
zone_id | string | Optional | Vendor zone id (preferred for get/verify/delete). |
vendor | string | Optional | Pin to a DNS vendor (BYOK / explicit). |
Returns
{ verified: boolean, status }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X POST https://api.infrai.cc/v1/dns/domain/verify \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"domain": "..."}'import os, requests
resp = requests.post(
"https://api.infrai.cc/v1/dns/domain/verify",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'domain': '...'},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/verify",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/verify",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.domain.delete
Delete a bound domain's managed zone at the vendor (requires zone_id).
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
domain | string | Required | Apex domain, e.g. example.com. |
zone_id | string | Optional | Vendor zone id (preferred for get/verify/delete). |
vendor | string | Optional | Pin to a DNS vendor (BYOK / explicit). |
Returns
{ ok: boolean }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X DELETE https://api.infrai.cc/v1/dns/domain/delete \
-H "Authorization: Bearer $INFRAI_API_KEY"import os, requests
resp = requests.delete(
"https://api.infrai.cc/v1/dns/domain/delete",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/delete",
{
method: "DELETE",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/delete",
{
method: "DELETE",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.record.create
Create a DNS record (A/AAAA/CNAME/TXT/MX) in a bound zone with TTL and optional MX priority / Cloudflare proxying.
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
zone_id | string | Required | Vendor zone id (preferred for get/verify/delete). |
record_type | "A" | "AAAA" | "CNAME" | "MX" | "TXT" | "NS" | "SRV" | Required | Record type — A, AAAA, CNAME, MX, TXT, NS, SRV. |
name | string | Required | Record name, e.g. www or www.example.com. |
content | string | Required | IP / target / text value. |
ttl | number | Optional | Record TTL in seconds. |
priority | number | Optional | MX preference (MX only). |
proxied | boolean | Optional | Cloudflare orange-cloud (A/AAAA/CNAME only). |
metadata | Record<string, unknown> | Optional | Arbitrary key/value metadata. |
Returns
Record { record_id, type, name, content, ttl }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X POST https://api.infrai.cc/v1/dns/record/create \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}'import os, requests
resp = requests.post(
"https://api.infrai.cc/v1/dns/record/create",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'zone_id': '...', 'record_type': 'A', 'name': '...', 'content': '...'},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/create",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/create",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.record.list
List DNS records in a bound zone.
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
zone_id | string | Required | Vendor zone id (preferred for get/verify/delete). |
record_type | string | Optional | Record type — A, AAAA, CNAME, MX, TXT, NS, SRV. |
name | string | Optional | Record name, e.g. www or www.example.com. |
Returns
{ items: Record[] }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X GET https://api.infrai.cc/v1/dns/record/list \
-H "Authorization: Bearer $INFRAI_API_KEY"import os, requests
resp = requests.get(
"https://api.infrai.cc/v1/dns/record/list",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.record.update
Update an existing DNS record (by record_id; Route53 uses UPSERT).
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
zone_id | string | Required | Vendor zone id (preferred for get/verify/delete). |
record_id | string | Optional | The record id (for update/delete). |
record_type | string | Required | Record type — A, AAAA, CNAME, MX, TXT, NS, SRV. |
name | string | Required | Record name, e.g. www or www.example.com. |
content | string | Required | IP / target / text value. |
ttl | number | Optional | Record TTL in seconds. |
priority | number | Optional | MX preference (MX only). |
proxied | boolean | Optional | Cloudflare orange-cloud (A/AAAA/CNAME only). |
Returns
RecordExample
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X PATCH https://api.infrai.cc/v1/dns/record/update \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}'import os, requests
resp = requests.patch(
"https://api.infrai.cc/v1/dns/record/update",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'zone_id': '...', 'record_type': 'A', 'name': '...', 'content': '...'},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/update",
{
method: "PATCH",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/update",
{
method: "PATCH",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);dns.record.delete
Delete a DNS record from a bound zone (requires record_id).
Parameters
| Name | Type | Required | Description |
|---|---|---|---|
zone_id | string | Required | Vendor zone id (preferred for get/verify/delete). |
record_id | string | Optional | The record id (for update/delete). |
record_type | string | Optional | Record type — A, AAAA, CNAME, MX, TXT, NS, SRV. |
name | string | Optional | Record name, e.g. www or www.example.com. |
Returns
{ ok: boolean }Example
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."curl -X DELETE https://api.infrai.cc/v1/dns/record/delete \
-H "Authorization: Bearer $INFRAI_API_KEY"import os, requests
resp = requests.delete(
"https://api.infrai.cc/v1/dns/record/delete",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/delete",
{
method: "DELETE",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/delete",
{
method: "DELETE",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);Advanced: pin a vendor
By default infrai routes each call to the best available provider — you do not pick a vendor. As an escape hatch, this capability accepts an optional vendor parameter to pin one specific provider. Every live vendor for this capability is available in real time from the discovery endpoint for the capability id — see the discovery API.
GET /v1/discovery/{capability}dns.domain.add
dns.domain.get
dns.domain.verify
dns.domain.delete
All capabilities
Every routed capability in this module — the complete public REST contract. The methods above are the guided walkthrough; this index is the full reference.
| Capability | Endpoint | Description |
|---|---|---|
dns.domain.add | POST /v1/dns/domain/add | Bind a custom domain by creating a managed DNS zone at the vendor (Cloudflare / Route53 / AliDNS); returns zone_id + name servers. Not domain registration. |
dns.domain.delete | DELETE /v1/dns/domain/delete | Delete a bound domain's managed zone at the vendor (requires zone_id). |
dns.domain.get | GET /v1/dns/domain/get | Fetch a bound domain (zone) by zone_id or name, returning its state and name servers. |
dns.domain.list | GET /v1/dns/domain/list | List the bound custom domains (managed zones) for the account at the configured DNS vendor. |
dns.domain.verify | POST /v1/dns/domain/verify | Verify a bound domain's activation/delegation against the same vendor zone it was created on (sticky_resource); read-only lookup of zone state. |
dns.record.create | POST /v1/dns/record/create | Create a DNS record (A/AAAA/CNAME/TXT/MX) in a bound zone with TTL and optional MX priority / Cloudflare proxying. |
dns.record.delete | DELETE /v1/dns/record/delete | Delete a DNS record from a bound zone (requires record_id). |
dns.record.list | GET /v1/dns/record/list | List DNS records in a bound zone. |
dns.record.update | PATCH /v1/dns/record/update | Update an existing DNS record (by record_id; Route53 uses UPSERT). |
End-to-end example
A production-style walkthrough of this module: configure once, then run the flow. It exercises most of the module's APIs.
A copy-paste-runnable single-file Python program (stdlib only, no SDK): set your INFRAI_API_KEY, run it, and walk this module's core flow with REAL billed calls — later steps reuse real fields returned by earlier ones. The 12-line helper is the entire integration.
#!/usr/bin/env python3
"""Infrai · dns — runnable real-app example (single file, zero deps).
Copy this file, set your key, run it: every step is a REAL call to
api.infrai.cc, billed at the real (tiny) per-call price, printing the
live JSON response. Get a key at https://console.infrai.cc (Google/
GitHub sign-in grants $2 free credit). No SDK — the 12-line helper
below is the entire integration."""
import json
import os
from urllib import error, request
KEY = os.environ.get("INFRAI_API_KEY") or "ifr_pk_proj_..." # <- your key
BASE = "https://api.infrai.cc"
# Same raw HTTPS POST/GET as every per-method example on this page —
# wrapped once for reuse. There is nothing else to it: no SDK.
def infrai(method, path, body=None):
req = request.Request(
BASE + path, method=method,
data=json.dumps(body).encode() if body is not None else None,
headers={"Authorization": f"Bearer {KEY}",
"Content-Type": "application/json"})
try:
with request.urlopen(req, timeout=60) as r:
return json.loads(r.read())
except error.HTTPError as e:
return json.loads(e.read())
def show(label, resp):
print(f"\n== {label} ==")
print(json.dumps(resp, indent=2, ensure_ascii=False))
return resp
# 1) dns.domain.add — POST /v1/dns/domain/add · Bind a custom domain by creating a managed DNS zone at the vendor (Cloudflare / Route53 / AliDNS); returns zone_id + name servers. Not domain registration.
r1 = show("dns.domain.add", infrai("POST", "/v1/dns/domain/add", {"domain":"..."}))
# 2) dns.domain.verify — POST /v1/dns/domain/verify · Verify a bound domain's activation/delegation against the same vendor zone it was created on (sticky_resource); read-only lookup of zone state.
r2 = show("dns.domain.verify", infrai("POST", "/v1/dns/domain/verify", {"domain":"..."}))
# 3) dns.record.create — POST /v1/dns/record/create · Create a DNS record (A/AAAA/CNAME/TXT/MX) in a bound zone with TTL and optional MX priority / Cloudflare proxying.
r3 = show("dns.record.create", infrai("POST", "/v1/dns/record/create", {"zone_id":"...","record_type":"A","name":"...","content":"..."}))
# 4) dns.domain.get — GET /v1/dns/domain/get · Fetch a bound domain (zone) by zone_id or name, returning its state and name servers.
r4 = show("dns.domain.get", infrai("GET", "/v1/dns/domain/get"))
一次性前置(每个范例都假定已完成):
# No SDK to install — every call is a plain HTTPS request.
# Get a project key by signing in at the console: Google/GitHub gives you
# $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..."# 1) Auth: every call is a raw HTTPS request to the Infrai gateway carrying
# only your project key. No SDK, no install.
# Get your key: sign in with Google/GitHub at the console for a project key
# + $2 free credit (email sign-in starts at $0). On 402 INSUFFICIENT_CREDIT,
# POST /v1/account/topup and open the returned checkout_url.
export INFRAI_API_KEY="ifr_pk_proj_..." # from the console
# 2) dns.domain.add
curl -X POST https://api.infrai.cc/v1/dns/domain/add \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"domain": "..."}'
# 3) dns.domain.get
curl -X GET https://api.infrai.cc/v1/dns/domain/get \
-H "Authorization: Bearer $INFRAI_API_KEY"
# 4) dns.domain.list
curl -X GET https://api.infrai.cc/v1/dns/domain/list \
-H "Authorization: Bearer $INFRAI_API_KEY"
# 5) dns.domain.verify
curl -X POST https://api.infrai.cc/v1/dns/domain/verify \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"domain": "..."}'
# 6) dns.domain.delete
curl -X DELETE https://api.infrai.cc/v1/dns/domain/delete \
-H "Authorization: Bearer $INFRAI_API_KEY"
# 7) dns.record.create
curl -X POST https://api.infrai.cc/v1/dns/record/create \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}'
# 8) dns.record.list
curl -X GET https://api.infrai.cc/v1/dns/record/list \
-H "Authorization: Bearer $INFRAI_API_KEY"
# 9) dns.record.update
curl -X PATCH https://api.infrai.cc/v1/dns/record/update \
-H "Authorization: Bearer $INFRAI_API_KEY" \
-H "Content-Type: application/json" \
-d '{"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}'
# 1) Auth: every call is a raw HTTPS request carrying only your project key.
# No SDK to install — just the `requests` library.
import os, requests
BASE = "https://api.infrai.cc"
HEADERS = {
"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}",
"Content-Type": "application/json",
}
# 2) dns.domain.add
import os, requests
resp = requests.post(
"https://api.infrai.cc/v1/dns/domain/add",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'domain': '...'},
)
resp.raise_for_status()
print(resp.json())
# 3) dns.domain.get
import os, requests
resp = requests.get(
"https://api.infrai.cc/v1/dns/domain/get",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())
# 4) dns.domain.list
import os, requests
resp = requests.get(
"https://api.infrai.cc/v1/dns/domain/list",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())
# 5) dns.domain.verify
import os, requests
resp = requests.post(
"https://api.infrai.cc/v1/dns/domain/verify",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'domain': '...'},
)
resp.raise_for_status()
print(resp.json())
# 6) dns.domain.delete
import os, requests
resp = requests.delete(
"https://api.infrai.cc/v1/dns/domain/delete",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())
# 7) dns.record.create
import os, requests
resp = requests.post(
"https://api.infrai.cc/v1/dns/record/create",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'zone_id': '...', 'record_type': 'A', 'name': '...', 'content': '...'},
)
resp.raise_for_status()
print(resp.json())
# 8) dns.record.list
import os, requests
resp = requests.get(
"https://api.infrai.cc/v1/dns/record/list",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
)
resp.raise_for_status()
print(resp.json())
# 9) dns.record.update
import os, requests
resp = requests.patch(
"https://api.infrai.cc/v1/dns/record/update",
headers={"Authorization": f"Bearer {os.environ['INFRAI_API_KEY']}"},
json={'zone_id': '...', 'record_type': 'A', 'name': '...', 'content': '...'},
)
resp.raise_for_status()
print(resp.json())
// 1) Auth: every call is a raw HTTPS request carrying only your project key.
// No SDK to install — just the built-in fetch().
const BASE = "https://api.infrai.cc";
const HEADERS = {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
};
// 2) dns.domain.add
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/add",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
console.log(await resp.json());
// 3) dns.domain.get
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/get",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());
// 4) dns.domain.list
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());
// 5) dns.domain.verify
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/verify",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
console.log(await resp.json());
// 6) dns.domain.delete
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/delete",
{
method: "DELETE",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());
// 7) dns.record.create
const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/create",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
console.log(await resp.json());
// 8) dns.record.list
const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
console.log(await resp.json());
// 9) dns.record.update
const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/update",
{
method: "PATCH",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
console.log(await resp.json());
// 1) Auth: every call is a raw HTTPS request carrying only your project key.
// No SDK to install — just the built-in fetch(), typed.
const BASE = "https://api.infrai.cc";
const HEADERS: Record<string, string> = {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
};
// 2) dns.domain.add
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/add",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 3) dns.domain.get
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/get",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 4) dns.domain.list
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 5) dns.domain.verify
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/verify",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"domain": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 6) dns.domain.delete
const resp = await fetch(
"https://api.infrai.cc/v1/dns/domain/delete",
{
method: "DELETE",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 7) dns.record.create
const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/create",
{
method: "POST",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 8) dns.record.list
const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/list",
{
method: "GET",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
},
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);
// 9) dns.record.update
const resp = await fetch(
"https://api.infrai.cc/v1/dns/record/update",
{
method: "PATCH",
headers: {
"Authorization": `Bearer ${process.env.INFRAI_API_KEY}`,
"Content-Type": "application/json",
},
body: JSON.stringify({"zone_id": "...", "record_type": "A", "name": "...", "content": "..."}),
},
);
if (!resp.ok) throw new Error(`infrai ${resp.status}`);
const data: unknown = await resp.json();
console.log(data);