—package
VM::HetznerCloud::API::Networks;
# ABSTRACT: Networks
# ---
# This class is auto-generated by bin/get_hetzner_info.pl
# ---
use
v5.24;
use
Moo;
use
Mojo::Base -strict, -signatures;
our
$VERSION
=
'0.0.1'
;
# VERSION
has
endpoint
=> (
is
=>
'ro'
,
isa
=> Str,
default
=>
sub
{
'networks'
} );
sub
list (
$self
,
%params
) {
my
$request_params
= {
'label_selector'
=> {
'in'
=>
'query'
,
'required'
=> 0,
'validate'
=>
'string'
,
},
'name'
=> {
'in'
=>
'query'
,
'required'
=> 0,
'validate'
=>
'string'
,
},
};
;
return
$self
->_request(
''
, \
%params
,
$request_params
, {
type
=>
'get'
} );
}
sub
create (
$self
,
%params
) {
my
$request_params
= {};
return
$self
->_request(
''
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
delete
(
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id'
, \
%params
,
$request_params
, {
type
=>
'delete'
} );
}
sub
get (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id'
, \
%params
,
$request_params
, {
type
=>
'get'
} );
}
sub
put (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id'
, \
%params
,
$request_params
, {
type
=>
'put'
} );
}
sub
list_actions (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
'sort'
=> {
'in'
=>
'query'
,
'required'
=> 0,
'validate'
=>
'string'
,
},
'status'
=> {
'in'
=>
'query'
,
'required'
=> 0,
'validate'
=>
'string'
,
},
};
;
return
$self
->_request(
'/:id/actions'
, \
%params
,
$request_params
, {
type
=>
'get'
} );
}
sub
create_actions_add_route (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/add_route'
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
create_actions_add_subnet (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/add_subnet'
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
create_actions_change_ip_range (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/change_ip_range'
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
create_actions_change_protection (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/change_protection'
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
create_actions_delete_route (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/delete_route'
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
create_actions_delete_subnet (
$self
,
%params
) {
my
$request_params
= {
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/delete_subnet'
, \
%params
,
$request_params
, {
type
=>
'post'
} );
}
sub
get_actions (
$self
,
%params
) {
my
$request_params
= {
'action_id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
'id'
=> {
'in'
=>
'path'
,
'required'
=> 1,
'validate'
=>
'int64'
,
},
};
;
return
$self
->_request(
'/:id/actions/:action_id'
, \
%params
,
$request_params
, {
type
=>
'get'
} );
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
VM::HetznerCloud::API::Networks - Networks
=head1 VERSION
version 0.0.1
=head1 SYNOPSIS
use VM::HetznerCloud;
my $api_key = '1234abc';
my $cloud = VM::HetznerCloud->new(
token => $api_key,
);
$cloud->records->create(
);
=head1 ATTRIBUTES
=over 4
=item * endpoint
=back
=head1 METHODS
=head2 list
Gets all existing networks that you have available.
$cloud->networks->list(
label_selector => 'test',
name => 'test',
);
=head2 create
Creates a network with the specified `ip_range`.
You may specify one or more `subnets`. You can also add more Subnets later by using the [add subnet action](https://docs.hetzner.cloud/#network-actions-add-a-subnet-to-a-network). If you do not specify an `ip_range` in the subnet we will automatically pick the first available /24 range for you.
You may specify one or more routes in `routes`. You can also add more routes later by using the [add route action](https://docs.hetzner.cloud/#network-actions-add-a-route-to-a-network).
$cloud->networks->create();
=head2 delete
Deletes a network. If there are Servers attached they will be detached in the background.
Note: if the network object changes during the request, the response will be a “conflict” error.
$cloud->networks->delete(
id => 'test',
);
=head2 get
Gets a specific network object.
$cloud->networks->get(
id => 'test',
);
=head2 put
Updates the network properties.
Note that when updating labels, the network’s current set of labels will be replaced with the labels provided in the request body. So, for example, if you want to add a new label, you have to provide all existing labels plus the new label in the request body.
Note: if the network object changes during the request, the response will be a “conflict” error.
$cloud->networks->put(
id => 'test',
);
=head2 list_actions
Returns all Action objects for a Network. You can sort the results by using the `sort` URI parameter, and filter them with the `status` parameter.
$cloud->networks->list_actions(
id => 'test',
sort => 'test',
status => 'test',
);
=head2 create_actions_add_route
Adds a route entry to a Network.
Note: if the Network object changes during the request, the response will be a “conflict” error.
$cloud->networks->create_actions_add_route(
id => 'test',
);
=head2 create_actions_add_subnet
Adds a new subnet object to the Network. If you do not specify an `ip_range` for the subnet we will automatically pick the first available /24 range for you if possible.
Note: if the parent Network object changes during the request, the response will be a “conflict” error.
$cloud->networks->create_actions_add_subnet(
id => 'test',
);
=head2 create_actions_change_ip_range
Changes the IP range of a Network. IP ranges can only be extended and never shrunk. You can only add IPs at the end of an existing IP range. This means that the IP part of your existing range must stay the same and you can only change its netmask.
For example if you have a range `10.0.0.0/16` you want to extend then your new range must also start with the IP `10.0.0.0`. Your CIDR netmask `/16` may change to a number that is smaller than `16` thereby increasing the IP range. So valid entries would be `10.0.0.0/15`, `10.0.0.0/14`, `10.0.0.0/13` and so on.
After changing the IP range you will have to adjust the routes on your connected Servers by either rebooting them or manually changing the routes to your private Network interface.
Note: if the Network object changes during the request, the response will be a “conflict” error.
$cloud->networks->create_actions_change_ip_range(
id => 'test',
);
=head2 create_actions_change_protection
Changes the protection configuration of a Network.
Note: if the Network object changes during the request, the response will be a “conflict” error.
$cloud->networks->create_actions_change_protection(
id => 'test',
);
=head2 create_actions_delete_route
Delete a route entry from a Network.
Note: if the Network object changes during the request, the response will be a “conflict” error.
$cloud->networks->create_actions_delete_route(
id => 'test',
);
=head2 create_actions_delete_subnet
Deletes a single subnet entry from a Network. You cannot delete subnets which still have Servers attached. If you have Servers attached you first need to detach all Servers that use IPs from this subnet before you can delete the subnet.
Note: if the Network object changes during the request, the response will be a “conflict” error.
$cloud->networks->create_actions_delete_subnet(
id => 'test',
);
=head2 get_actions
Returns a specific Action for a Network.
$cloud->networks->get_actions(
action_id => 'test',
id => 'test',
);
=head1 AUTHOR
Renee Baecker <reneeb@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is Copyright (c) 2018 by Renee Baecker.
This is free software, licensed under:
The Artistic License 2.0 (GPL Compatible)
=cut