#include <xtd/net/sockets/socket>
#include <xtd/net/dns>
#include <xtd/net/ip_address>
#include <xtd/console>
#include <xtd/startup>
#include <regex>
using namespace std;
class test_ip_address {
public:
static auto main(const vector<ustring>& args) {
auto server = ustring::empty_string;
auto rex = regex {R"(^[a-zA-Z]\w{1,39}$)"};
if (args.size() < 1) {
server = dns::get_host_name();
console::write_line("Using current host: {}", server);
} else {
server = args[0];
if (!regex_match(server, rex)) {
console::write_line("Input string format not allowed.");
return;
}
}
ip_addresses(server);
ip_address_additional_info();
}
private:
static void ip_addresses(
const ustring& server) {
try {
auto heserver = dns::get_host_entry(server);
for (auto cur_add : heserver.address_list()) {
console::write_line("address_family: {}", cur_add.address_family());
if (cur_add.address_family() == address_family::inter_network_v6)
console::write_line("scope id: {}", cur_add.scope_id());
console::write_line("address: {}", cur_add);
console::write("address_bytes: ");
auto bytes = cur_add.get_address_bytes();
for (
size_t i = 0;
i < bytes.size();
i++)
console::write(bytes[
i]);
console::write_line("\r\n");
}
console::write_line("[do_resolve] exception: {}", e);
}
}
static void ip_address_additional_info() {
try {
console::write_line("\r\nos_supports_ip_v4: {}", socket::os_supports_ip_v4());
console::write_line("os_supports_ip_v6: {}", socket::os_supports_ip_v6());
if (socket::os_supports_ip_v6()) {
console::write_line("\r\nip_v6_any: {}", ip_address::ip_v6_any);
console::write_line("ip_v6_loopback: {}", ip_address::ip_v6_loopback);
console::write_line("ip_v6_none: {}", ip_address::ip_v6_none);
console::write_line("is_loopback(ip_v6_loopback): {}", ip_address::is_loopback(ip_address::ip_v6_loopback));
}
console::write_line("is_loopback(loopback):{}", ip_address::is_loopback(ip_address::loopback));
console::write_line("[ip_addresses] exception: {}", e);
}
}
};