VPS.org API

REST API დოკუმენტაცია

დომენები

დომენის რეგისტრაციის, განახლების და კონფიგურაციის პროგრამულად მართვა.

საბოლოო წერტილები 6 endpoints
ბაზისური გზა /api/v1/domains
მიიღეთ /api/v1/domains/

ყველა დომენის სია

თქვენი ანგარიშის ქვეშ რეგისტრირებული ყველა დომენის სიის მიღება.

მოთხოვნის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
status string ნვ, ნვ ჟყმ. Filter by status: active, pending, expired, locked
search string ნვ, ნვ ჟყმ. დომენების ძებნა სახელის მიხედვით

მაგალითის მოთხოვნა

cURL
Python
JavaScript
curl -X GET "https://admin.vps.org/api/v1/domains/" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json"
import requests

url = "https://admin.vps.org/api/v1/domains/"
headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Content-Type": "application/json"
}

response = requests.get(url, headers=headers)
print(response.json())
const response = await fetch('https://admin.vps.org/api/v1/domains/', {
  method: 'GET',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Content-Type': 'application/json'
  }
});

const domains = await response.json();
console.log(domains);

მაგალითის პასუხი

{
  "count": 3,
  "results": [
    {
      "id": 101,
      "domain_name": "example.com",
      "status": "active",
      "registration_date": "2023-01-15T10:30:00Z",
      "expiration_date": "2026-01-15T10:30:00Z",
      "auto_renew": true,
      "locked": true,
      "nameservers": [
        "ns1.vps.org",
        "ns2.vps.org"
      ],
      "privacy_protection": true,
      "dns_managed_by": "vps.org"
    },
    {
      "id": 102,
      "domain_name": "myapp.io",
      "status": "active",
      "registration_date": "2024-06-20T14:15:00Z",
      "expiration_date": "2025-06-20T14:15:00Z",
      "auto_renew": false,
      "locked": false,
      "nameservers": [
        "ns1.cloudflare.com",
        "ns2.cloudflare.com"
      ],
      "privacy_protection": false,
      "dns_managed_by": "external"
    }
  ]
}

პასუხის სტატუსის კოდები

200 დომენების სია წარმატებით მოიძებნა
401 არაავტორიზებული - არასწორი ან დაკარგული ავტორიზაციის ტოკენი
წერილის გაგზავნა /api/v1/domains/

ახალი დომენის რეგისტრაცია

ახალი დომენის სახელის რეგისტრაცია. რეგისტრაციის წინ უნდა შემოწმდეს დომენის ხელმისაწვდომობა.

მოთხოვნის სხეულის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
domain_name string დიახ Domain name to register (e.g., "example.com")
years integer ნვ, ნვ ჟყმ. Registration period in years (1-10, default: 1)
auto_renew boolean ნვ, ნვ ჟყმ. Enable automatic renewal (default: true)
privacy_protection boolean ნვ, ნვ ჟყმ. Enable WHOIS privacy protection (default: true)
nameservers array ნვ, ნვ ჟყმ. Custom nameservers (default: VPS.org nameservers)

მაგალითის მოთხოვნა

cURL
Python
JavaScript
PHP
curl -X POST "https://admin.vps.org/api/v1/domains/" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json" \
  -d '{
    "domain_name": "mynewdomain.com",
    "years": 2,
    "auto_renew": true,
    "privacy_protection": true
  }'
import requests

url = "https://admin.vps.org/api/v1/domains/"
headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Content-Type": "application/json"
}
data = {
    "domain_name": "mynewdomain.com",
    "years": 2,
    "auto_renew": True,
    "privacy_protection": True
}

response = requests.post(url, headers=headers, json=data)
print(response.json())
const response = await fetch('https://admin.vps.org/api/v1/domains/', {
  method: 'POST',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    domain_name: 'mynewdomain.com',
    years: 2,
    auto_renew: true,
    privacy_protection: true
  })
});

const domain = await response.json();
console.log(domain);
$data = [
    'domain_name' => 'mynewdomain.com',
    'years' => 2,
    'auto_renew' => true,
    'privacy_protection' => true
];

$ch = curl_init('https://admin.vps.org/api/v1/domains/');
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
curl_setopt($ch, CURLOPT_HTTPHEADER, [
    'Authorization: Bearer YOUR_API_TOKEN',
    'Content-Type: application/json'
]);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$response = curl_exec($ch);
$domain = json_decode($response, true);
curl_close($ch);

მაგალითის პასუხი

{
  "id": 103,
  "domain_name": "mynewdomain.com",
  "status": "pending",
  "registration_date": "2026-01-16T16:00:00Z",
  "expiration_date": "2028-01-16T16:00:00Z",
  "auto_renew": true,
  "locked": true,
  "nameservers": [
    "ns1.vps.org",
    "ns2.vps.org"
  ],
  "privacy_protection": true,
  "dns_managed_by": "vps.org",
  "total_cost": 24.98,
  "message": "Domain registration initiated. Processing may take 5-10 minutes."
}

პასუხის სტატუსის კოდები

201 Domain registration initiated successfully
400 Bad Request - Invalid domain name or domain already registered
401 არაავტორიზებული - არასწორი ან დაკარგული ავტორიზაციის ტოკენი
402 Payment Required - Insufficient account balance
შენიშვნა: Domain registration is not instant. Status will change from pending to active within 5-10 minutes. You'll receive an email confirmation when registration completes.
მიიღეთ /api/v1/domains/{domain_id}/

დომენის დეტალების მიღება

დეტალური ინფორმაცია კონკრეტული დომენის შესახებ. Name

გზის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
domain_id integer დიახ Unique domain ID

მაგალითის მოთხოვნა

cURL
Python
JavaScript
curl -X GET "https://admin.vps.org/api/v1/domains/101/" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json"
import requests

domain_id = 101
url = f"https://admin.vps.org/api/v1/domains/{domain_id}/"
headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Content-Type": "application/json"
}

response = requests.get(url, headers=headers)
print(response.json())
const domainId = 101;
const response = await fetch(`https://admin.vps.org/api/v1/domains/${domainId}/`, {
  method: 'GET',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Content-Type': 'application/json'
  }
});

const domain = await response.json();
console.log(domain);

მაგალითის პასუხი

{
  "id": 101,
  "domain_name": "example.com",
  "status": "active",
  "registration_date": "2023-01-15T10:30:00Z",
  "expiration_date": "2026-01-15T10:30:00Z",
  "auto_renew": true,
  "locked": true,
  "nameservers": [
    "ns1.vps.org",
    "ns2.vps.org"
  ],
  "privacy_protection": true,
  "dns_managed_by": "vps.org",
  "registrar": "VPS.org",
  "days_until_expiration": 730,
  "whois_info": {
    "registrant": "Privacy Protected",
    "admin_contact": "Privacy Protected",
    "tech_contact": "Privacy Protected",
    "created_date": "2023-01-15",
    "updated_date": "2025-12-20"
  },
  "dns_records_count": 12
}

პასუხის სტატუსის კოდები

200 Successfully retrieved domain details
401 არაავტორიზებული - არასწორი ან დაკარგული ავტორიზაციის ტოკენი
404 ვერ მოიძებნა - დომენი არ არსებობს
დადეთ /api/v1/domains/{domain_id}/

დომენის პარამეტრების განახლება

დომენის კონფიგურაციის განახლება, როგორიცაა ავტოგანახლების, სახელის სერვერების და პირადი პარამეტრების პარამეტრები. Name

გზის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
domain_id integer დიახ Unique domain ID

მოთხოვნის სხეულის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
auto_renew boolean ნვ, ნვ ჟყმ. Enable or disable automatic renewal
privacy_protection boolean ნვ, ნვ ჟყმ. Enable or disable WHOIS privacy
nameservers array ნვ, ნვ ჟყმ. Update nameservers (2-4 nameservers required)
locked boolean ნვ, ნვ ჟყმ. Lock or unlock domain to prevent transfers

მაგალითის მოთხოვნა

cURL
Python
JavaScript
curl -X PUT "https://admin.vps.org/api/v1/domains/101/" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json" \
  -d '{
    "auto_renew": false,
    "nameservers": [
      "ns1.cloudflare.com",
      "ns2.cloudflare.com"
    ]
  }'
import requests

domain_id = 101
url = f"https://admin.vps.org/api/v1/domains/{domain_id}/"
headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Content-Type": "application/json"
}
data = {
    "auto_renew": False,
    "nameservers": [
        "ns1.cloudflare.com",
        "ns2.cloudflare.com"
    ]
}

response = requests.put(url, headers=headers, json=data)
print(response.json())
const domainId = 101;
const response = await fetch(`https://admin.vps.org/api/v1/domains/${domainId}/`, {
  method: 'PUT',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    auto_renew: false,
    nameservers: [
      'ns1.cloudflare.com',
      'ns2.cloudflare.com'
    ]
  })
});

const domain = await response.json();
console.log(domain);

მაგალითის პასუხი

{
  "id": 101,
  "domain_name": "example.com",
  "status": "active",
  "auto_renew": false,
  "nameservers": [
    "ns1.cloudflare.com",
    "ns2.cloudflare.com"
  ],
  "privacy_protection": true,
  "locked": true,
  "message": "Domain settings updated successfully. Nameserver changes may take up to 24 hours to propagate."
}

პასუხის სტატუსის კოდები

200 Domain updated successfully
400 Bad Request - Invalid parameters
401 არაავტორიზებული - არასწორი ან დაკარგული ავტორიზაციის ტოკენი
404 ვერ მოიძებნა - დომენი არ არსებობს
წაშლა /api/v1/domains/{domain_id}/

დომენის წაშლა

დომენის წაშლა თქვენი ანგარიშიდან. ეს არ წყვეტს დომენის რეგისტრაციას - ის მხოლოდ VPS.org ანგარიშის მართვაში ამოიჭრება.

გზის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
domain_id integer დიახ Unique domain ID

მაგალითის მოთხოვნა

cURL
Python
JavaScript
curl -X DELETE "https://admin.vps.org/api/v1/domains/101/" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json"
import requests

domain_id = 101
url = f"https://admin.vps.org/api/v1/domains/{domain_id}/"
headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Content-Type": "application/json"
}

response = requests.delete(url, headers=headers)
print(response.status_code)
const domainId = 101;
const response = await fetch(`https://admin.vps.org/api/v1/domains/${domainId}/`, {
  method: 'DELETE',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Content-Type': 'application/json'
  }
});

console.log(response.status);

პასუხის სტატუსის კოდები

204 Domain removed from account successfully
401 არაავტორიზებული - არასწორი ან დაკარგული ავტორიზაციის ტოკენი
404 ვერ მოიძებნა - დომენი არ არსებობს
Important: Deleting a domain from your VPS.org account does NOT cancel the registration. The domain will continue to be registered and will auto-renew if enabled. To cancel a domain registration, disable auto-renewal and let it expire.
წერილის გაგზავნა /api/v1/domains/{domain_id}/transfer/

დომენის გადატანა

VPS.org-ზე დომენის გადატანა სხვა რეგისტრატორისაგან.

გზის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
domain_id integer დიახ Unique domain ID

მოთხოვნის სხეულის პარამეტრები

პარამეტრები ტიპი სავალდებულო აღწერა
auth_code string დიახ EPP/Authorization code from current registrar
auto_renew boolean ნვ, ნვ ჟყმ. Enable auto-renewal after transfer (default: true)

მაგალითის მოთხოვნა

cURL
Python
JavaScript
curl -X POST "https://admin.vps.org/api/v1/domains/101/transfer/" \
  -H "Authorization: Bearer YOUR_API_TOKEN" \
  -H "Content-Type: application/json" \
  -d '{
    "auth_code": "Xy9Kl2Mn#4pQ",
    "auto_renew": true
  }'
import requests

domain_id = 101
url = f"https://admin.vps.org/api/v1/domains/{domain_id}/transfer/"
headers = {
    "Authorization": "Bearer YOUR_API_TOKEN",
    "Content-Type": "application/json"
}
data = {
    "auth_code": "Xy9Kl2Mn#4pQ",
    "auto_renew": True
}

response = requests.post(url, headers=headers, json=data)
print(response.json())
const domainId = 101;
const response = await fetch(`https://admin.vps.org/api/v1/domains/${domainId}/transfer/`, {
  method: 'POST',
  headers: {
    'Authorization': 'Bearer YOUR_API_TOKEN',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    auth_code: 'Xy9Kl2Mn#4pQ',
    auto_renew: true
  })
});

const transfer = await response.json();
console.log(transfer);

მაგალითის პასუხი

{
  "id": 101,
  "domain_name": "example.com",
  "transfer_status": "pending",
  "transfer_initiated_at": "2026-01-16T16:30:00Z",
  "estimated_completion": "2026-01-23T16:30:00Z",
  "message": "Domain transfer initiated. You should receive a confirmation email from your current registrar. Transfer typically completes within 5-7 days.",
  "next_steps": [
    "Check email for transfer authorization request",
    "Approve transfer with current registrar",
    "Wait for transfer to complete (5-7 days)",
    "Domain will be automatically renewed for 1 year upon completion"
  ]
}

პასუხის სტატუსის კოდები

200 Transfer initiated successfully
400 Bad Request - Invalid auth code or domain not eligible for transfer
401 არაავტორიზებული - არასწორი ან დაკარგული ავტორიზაციის ტოკენი
404 ვერ მოიძებნა - დომენი არ არსებობს
402 Payment Required - Insufficient account balance for transfer fee
გადაცემის მოთხოვნები:
  • დომენი უნდა იყოს გააქტივებული მიმდინარე რეგისტრატორის მიერ
  • დომენი უნდა იყოს 60 დღის ასაკზე ნაკლები
  • საჭიროა სწორი EPP/Auth კოდი
  • WHOIS ელფოსტა უნდა იყოს ხელმისაწვდომი დამოწმებისთვის
  • გადაცემა მოიცავს 1 წლის განახლების (ფასიანი)

დომენის ფასი

პოპულარული TLD- ები

TLD რეგისტრაცია (1 წელი) განახლება გადაცემა
.com $12.99 $12.99 $12.99
.net $14.99 $14.99 $14.99
.org $13.99 $13.99 $13.99
.io $39.99 $39.99 $39.99
.dev $14.99 $14.99 $14.99
.app $14.99 $14.99 $14.99
.co $24.99 $24.99 $24.99

შედის ფუნქციები

  • ✓ თავისუფალი WHOIS კონფიდენციალურობის დაცვა
  • ✓ DNS მართვაName
  • ✓ ელფოსტის გადაგზავნა
  • ✓ დომენის გადაგზავნა
  • ✓ დომენის დაბლოკვა
  • ✓ 24/7 მხარდაჭერა
  • ✓ დომენის ადვილი მართვაName
  • ✓ ავტომატური განახლების პარამეტრები

დომენის მართვაName

უსაფრთხოება

კონფიგურაცია

გადაცემები