-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathexample.php
executable file
·88 lines (68 loc) · 3.35 KB
/
example.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#!/usr/bin/env php
<?php
// Load dependencies
require __DIR__ . '/vendor/autoload.php';
// Set up credentials. Set you username and password for United Domains account.
$username = 'username';
$password = 'password';
// Prepare a client. We gonna use traceable client to have a good debug output.
$client = new \HadesArchitect\UnitedDomains\TraceableClient($username, $password);
// Optional step. Set up a logger to see what's going on "under the hood".
$client->setLogger(
new \Monolog\Logger(
'ud_api',
[new \Monolog\Handler\StreamHandler('php://stdout', \Monolog\Logger::DEBUG)],
[new \Monolog\Processor\PsrLogMessageProcessor()]
)
);
// Turn on debug mode for http requests. Optional step.
//$client->enableDebug();
// Check domain direct call, existing domain
//$response = $client->call('CheckDomain', ['domain' => 'ololo.com']); echo $response, PHP_EOL;
// Check domain direct call, existing domain with umlauts (UTF-8 check)
//$response = $client->call('CheckDomain', ['domain' => 'möbelhaus.de']); echo $response, PHP_EOL;
// Check domain direct call, non-existing domain
//$response = $client->call('CheckDomain', ['domain' => 'ololo345678765434567.com', 'suggest' => 2]); echo $response, PHP_EOL;
// Create a DNS Resource Record
//$response = $client->call('UpdateDNSZone', ['dnszone' => 'example.de', 'addrr0' => 'test-100500.example.de. 3600 IN A 10.10.0.2']); //echo $response, PHP_EOL;
// Create a DNS Resource Record
//$response = $client->call('UpdateDNSZone', ['dnszone' => 'example.de', 'delrr0' => 'test-100500.example.de. IN A 10.10.0.2']); //echo $response, PHP_EOL;
// Get records for a DNS zone
//$response = $client->call('QueryDNSZoneRRList', ['dnszone' => 'example.de']); //echo $response, PHP_EOL;
//var_dump($response->getProperty('rr'));
// Instead of manually sending complex queries, you can use facades whose simplify API usage. Set your credentials!
$facadeClient = new \HadesArchitect\UnitedDomains\ClientFacade($username, $password);
$facadeClient->setLogger(
new \Monolog\Logger(
'ud_api',
[new \Monolog\Handler\StreamHandler('php://stdout', \Monolog\Logger::DEBUG)],
[new \Monolog\Processor\PsrLogMessageProcessor()]
)
);
// Get records in DNS zone
//var_dump($facadeClient->getRecords('example.de'));
// Get A-type records in DNS zone
//var_dump($facadeClient->findRecordsByType('example.de', 'A'));
// Check domain availability
//if ($facadeClient->isDomainFree('example.com'))
// echo 'Domain example.com is free, lolwut?', PHP_EOL;
//else
// echo 'Domain example.com is registered already.', PHP_EOL;
//if ($facadeClient->isDomainFree('1234567834567654376543.com'))
// echo 'Domain 1234567834567654376543.com is free', PHP_EOL;
//else
// echo 'Domain 1234567834567654376543.com is registered already.', PHP_EOL;
// Create DNS Zone
//$facadeClient->CreateDNSZone('test999999999.de');
// Delete DNS Zone
//$facadeClient->DeleteDNSZone('test999999999.de');
// Add multiply records
//$facadeClient->addRecords(
// 'example.de',
// [
// ['name' => 'test1.example.de', 'type' => 'A', 'data' => '8.8.8.8'],
// ['name' => 'test2.example.de', 'type' => 'A', 'data' => '87.87.87.87']
// ]
//);
// Delete record by name and type only, without specifying data
//$facadeClient->deleteRecord('example.de', 'test3.example.de.', 'A');