mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-05 09:17:41 +03:00
feature #2858: First version of VNET reservation. VNET is created, addresses allocated. Needs to set free addr methods upon reservation removal.
This commit is contained in:
parent
88987631d9
commit
d5deaaf9e4
@ -38,6 +38,40 @@ public:
|
|||||||
|
|
||||||
virtual ~AddressRange(){};
|
virtual ~AddressRange(){};
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address Range types
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Type of Addresses defined by this address range
|
||||||
|
*/
|
||||||
|
enum AddressType
|
||||||
|
{
|
||||||
|
NONE = 0x00000000, /** Undefined Address Type */
|
||||||
|
ETHER = 0x00000001, /** MAC address type */
|
||||||
|
IP4 = 0x00000003, /** IP version 4 address */
|
||||||
|
IP6 = 0x00000005, /** IP version 6 address */
|
||||||
|
IP4_6 = 0x00000007 /** IP dual stack version 4 & 6 addresses */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the string representation of an AddressType
|
||||||
|
* @param ob the type
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
static string type_to_str(AddressType ob);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the string representation of an AddressType
|
||||||
|
* @param ob the type
|
||||||
|
* @return the string
|
||||||
|
*/
|
||||||
|
static AddressType str_to_type(string& str_type);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address Range initialization functions
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Init an Address Range based on a vector attribute the following
|
* Init an Address Range based on a vector attribute the following
|
||||||
* attributes will be parsed (* are optional):
|
* attributes will be parsed (* are optional):
|
||||||
@ -84,31 +118,9 @@ public:
|
|||||||
*/
|
*/
|
||||||
void to_xml(ostringstream &oss) const;
|
void to_xml(ostringstream &oss) const;
|
||||||
|
|
||||||
/**
|
// *************************************************************************
|
||||||
* Type of Addresses defined by this address range
|
// Address allocation functions
|
||||||
*/
|
// *************************************************************************
|
||||||
enum AddressType
|
|
||||||
{
|
|
||||||
NONE = 0x00000000, /** Undefined Address Type */
|
|
||||||
ETHER = 0x00000001, /** MAC address type */
|
|
||||||
IP4 = 0x00000003, /** IP version 4 address */
|
|
||||||
IP6 = 0x00000005, /** IP version 6 address */
|
|
||||||
IP4_6 = 0x00000007 /** IP dual stack version 4 & 6 addresses */
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the string representation of an AddressType
|
|
||||||
* @param ob the type
|
|
||||||
* @return the string
|
|
||||||
*/
|
|
||||||
static string type_to_str(AddressType ob);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the string representation of an AddressType
|
|
||||||
* @param ob the type
|
|
||||||
* @return the string
|
|
||||||
*/
|
|
||||||
static AddressType str_to_type(string& str_type);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns an unused address, which becomes used and fills a NIC attribute
|
* Returns an unused address, which becomes used and fills a NIC attribute
|
||||||
@ -177,6 +189,38 @@ public:
|
|||||||
*/
|
*/
|
||||||
int free_addr_by_ip(PoolObjectSQL::ObjectType ot, int id, const string& ip);
|
int free_addr_by_ip(PoolObjectSQL::ObjectType ot, int id, const string& ip);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Frees all previous allocated address to the given object
|
||||||
|
* @param ot the object type of the owner of the address
|
||||||
|
* @param obid the id of the owner of the address
|
||||||
|
* @return the number of addresses freed
|
||||||
|
*/
|
||||||
|
int free_addr_by_owner(PoolObjectSQL::ObjectType ot, int obid);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address Reservation
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reserve a given number of addresses from this address range
|
||||||
|
* @param pvid the id of the parent VNET
|
||||||
|
* @param vid the id of the VNET making the reservation
|
||||||
|
* @param size number of addresses to reserve
|
||||||
|
* @param rar a new address range to place the reservation
|
||||||
|
* @return 0 on success
|
||||||
|
*/
|
||||||
|
int reserve_addr(int pvid, int vid, unsigned int rsize, AddressRange *rar);
|
||||||
|
|
||||||
|
/*
|
||||||
|
void reserve_addr_by_ip();
|
||||||
|
|
||||||
|
void reserve_addr_by_mac();
|
||||||
|
*/
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Helpers
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the id for this address range
|
* Return the id for this address range
|
||||||
*/
|
*/
|
||||||
@ -193,6 +237,14 @@ public:
|
|||||||
return used_addr;
|
return used_addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the number of free addresses
|
||||||
|
*/
|
||||||
|
unsigned int get_free_addr() const
|
||||||
|
{
|
||||||
|
return size - used_addr;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the string value of an Address Range Attribute
|
* Returns the string value of an Address Range Attribute
|
||||||
* @param name of the attribute
|
* @param name of the attribute
|
||||||
|
@ -37,6 +37,10 @@ public:
|
|||||||
|
|
||||||
virtual ~AddressRangePool();
|
virtual ~AddressRangePool();
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Inititalization functions
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds the address range set from an array of VectorAttributes. This
|
* Builds the address range set from an array of VectorAttributes. This
|
||||||
* function is used to create address ranges.
|
* function is used to create address ranges.
|
||||||
@ -54,6 +58,10 @@ public:
|
|||||||
*/
|
*/
|
||||||
int from_xml_node(const xmlNodePtr node);
|
int from_xml_node(const xmlNodePtr node);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address Range management interface
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes an address range from the pool if it does not contain any used
|
* Removes an address range from the pool if it does not contain any used
|
||||||
* leases
|
* leases
|
||||||
@ -70,12 +78,14 @@ public:
|
|||||||
void update_ar(vector<Attribute *> ars);
|
void update_ar(vector<Attribute *> ars);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate a XML representation of the Address Range Pool
|
* Allocates a new address range in the pool.
|
||||||
* @param sstream where the ARPool is written
|
* @return the new address range added to the pool
|
||||||
* @param extended true to include lease information
|
|
||||||
* @return the string with the XML
|
|
||||||
*/
|
*/
|
||||||
string& to_xml(string& sstream, bool extended) const;
|
AddressRange * allocate_ar();
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address allocation interface
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocates an address in a suitable address range from the pool
|
* Allocates an address in a suitable address range from the pool
|
||||||
@ -182,6 +192,33 @@ public:
|
|||||||
*/
|
*/
|
||||||
void free_addr_by_ip(PoolObjectSQL::ObjectType ot, int id, const string& ip);
|
void free_addr_by_ip(PoolObjectSQL::ObjectType ot, int id, const string& ip);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Frees all the addressed owned by the given object
|
||||||
|
* @param ot the type of the object requesting the address (VM or NET)
|
||||||
|
* @param obid the id of the object requesting the address
|
||||||
|
*/
|
||||||
|
void free_addr_by_owner(PoolObjectSQL::ObjectType ot, int obid);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address reservation
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reserve a given number of addresses from the first address range with
|
||||||
|
* enough free addresses to allocate the reservation
|
||||||
|
* @param pvid the id of the parent VNET
|
||||||
|
* @param vid the id of the VNET making the reservation
|
||||||
|
* @param size number of addresses to reserve
|
||||||
|
* @param rar a new address range to place the reservation
|
||||||
|
* @return 0 on success
|
||||||
|
*/
|
||||||
|
int reserve_addr(int pvid, int vid, unsigned int rsize, AddressRange *rar);
|
||||||
|
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Helpers & Formatting
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the number of used addresses
|
* Return the number of used addresses
|
||||||
*/
|
*/
|
||||||
@ -198,6 +235,14 @@ public:
|
|||||||
*/
|
*/
|
||||||
void get_attribute(const char * name, string& value, int ar_id) const;
|
void get_attribute(const char * name, string& value, int ar_id) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a XML representation of the Address Range Pool
|
||||||
|
* @param sstream where the ARPool is written
|
||||||
|
* @param extended true to include lease information
|
||||||
|
* @return the string with the XML
|
||||||
|
*/
|
||||||
|
string& to_xml(string& sstream, bool extended) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/**
|
/**
|
||||||
* Stores the Address Ranges in a template form. This template is used
|
* Stores the Address Ranges in a template form. This template is used
|
||||||
|
@ -49,6 +49,7 @@ protected:
|
|||||||
|
|
||||||
virtual int leases_action(VirtualNetwork * vn,
|
virtual int leases_action(VirtualNetwork * vn,
|
||||||
VirtualNetworkTemplate * tmpl,
|
VirtualNetworkTemplate * tmpl,
|
||||||
|
RequestAttributes& att,
|
||||||
string& error_str) = 0;
|
string& error_str) = 0;
|
||||||
/* -------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------- */
|
||||||
|
|
||||||
@ -68,6 +69,7 @@ public:
|
|||||||
|
|
||||||
int leases_action(VirtualNetwork * vn,
|
int leases_action(VirtualNetwork * vn,
|
||||||
VirtualNetworkTemplate * tmpl,
|
VirtualNetworkTemplate * tmpl,
|
||||||
|
RequestAttributes& att,
|
||||||
string& error_str)
|
string& error_str)
|
||||||
{
|
{
|
||||||
return vn->add_ar(tmpl, error_str);
|
return vn->add_ar(tmpl, error_str);
|
||||||
@ -109,6 +111,7 @@ public:
|
|||||||
|
|
||||||
int leases_action(VirtualNetwork * vn,
|
int leases_action(VirtualNetwork * vn,
|
||||||
VirtualNetworkTemplate * tmpl,
|
VirtualNetworkTemplate * tmpl,
|
||||||
|
RequestAttributes& att,
|
||||||
string& error_str)
|
string& error_str)
|
||||||
{
|
{
|
||||||
error_str.clear();
|
error_str.clear();
|
||||||
@ -132,6 +135,7 @@ public:
|
|||||||
|
|
||||||
int leases_action(VirtualNetwork * vn,
|
int leases_action(VirtualNetwork * vn,
|
||||||
VirtualNetworkTemplate * tmpl,
|
VirtualNetworkTemplate * tmpl,
|
||||||
|
RequestAttributes& att,
|
||||||
string& error_str)
|
string& error_str)
|
||||||
{
|
{
|
||||||
return vn->hold_leases(tmpl, error_str);
|
return vn->hold_leases(tmpl, error_str);
|
||||||
@ -151,12 +155,34 @@ public:
|
|||||||
|
|
||||||
int leases_action(VirtualNetwork * vn,
|
int leases_action(VirtualNetwork * vn,
|
||||||
VirtualNetworkTemplate * tmpl,
|
VirtualNetworkTemplate * tmpl,
|
||||||
|
RequestAttributes& att,
|
||||||
string& error_str)
|
string& error_str)
|
||||||
{
|
{
|
||||||
return vn->free_leases(tmpl, error_str);
|
return vn->free_leases(tmpl, error_str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
class VirtualNetworkReserve: public Request
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
VirtualNetworkReserve():Request("VirtualNetworkReserve", "A:sis",
|
||||||
|
"Reserve network addresses")
|
||||||
|
{
|
||||||
|
Nebula& nd = Nebula::instance();
|
||||||
|
pool = nd.get_vnpool();
|
||||||
|
|
||||||
|
auth_object = PoolObjectSQL::NET;
|
||||||
|
auth_op = AuthRequest::USE;
|
||||||
|
};
|
||||||
|
|
||||||
|
~VirtualNetworkReserve(){};
|
||||||
|
|
||||||
|
void request_execute(xmlrpc_c::paramList const& _paramList,
|
||||||
|
RequestAttributes& att);
|
||||||
|
};
|
||||||
|
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
@ -56,6 +56,10 @@ public:
|
|||||||
return new VirtualNetworkTemplate;
|
return new VirtualNetworkTemplate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address Range management interface
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add an address range to the virtual network
|
* Add an address range to the virtual network
|
||||||
* @param ars_tmpl template in the form AR = [TYPE=...,IP=...,SIZE=...].
|
* @param ars_tmpl template in the form AR = [TYPE=...,IP=...,SIZE=...].
|
||||||
@ -72,6 +76,15 @@ public:
|
|||||||
*/
|
*/
|
||||||
int rm_ar(unsigned int ar_id, string& error_msg);
|
int rm_ar(unsigned int ar_id, string& error_msg);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allocates a new (and empty) address range to the AR pool
|
||||||
|
* @return pointer to the ar added to the AR pool
|
||||||
|
*/
|
||||||
|
AddressRange * allocate_ar()
|
||||||
|
{
|
||||||
|
return ar_pool.allocate_ar();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update an address range to the virtual network
|
* Update an address range to the virtual network
|
||||||
* @param ars_tmpl template in the form AR = [AR_ID=...]. The address range
|
* @param ars_tmpl template in the form AR = [AR_ID=...]. The address range
|
||||||
@ -79,6 +92,10 @@ public:
|
|||||||
*/
|
*/
|
||||||
void update_ar(VirtualNetworkTemplate * ars_tmpl);
|
void update_ar(VirtualNetworkTemplate * ars_tmpl);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address hold/release interface
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds a Lease, marking it as used
|
* Holds a Lease, marking it as used
|
||||||
* @param leases template in the form LEASES = [IP=XX].
|
* @param leases template in the form LEASES = [IP=XX].
|
||||||
@ -98,6 +115,10 @@ public:
|
|||||||
*/
|
*/
|
||||||
int free_leases(VirtualNetworkTemplate* leases, string& error_msg);
|
int free_leases(VirtualNetworkTemplate* leases, string& error_msg);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Address allocation funtions
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a new address lease for a specific VM
|
* Gets a new address lease for a specific VM
|
||||||
* @param vid VM identifier
|
* @param vid VM identifier
|
||||||
@ -144,13 +165,51 @@ public:
|
|||||||
* @param arid of the address range where the address was leased from
|
* @param arid of the address range where the address was leased from
|
||||||
* @param vid the ID of the VM
|
* @param vid the ID of the VM
|
||||||
* @param mac MAC address identifying the lease
|
* @param mac MAC address identifying the lease
|
||||||
* @return 0 if success
|
|
||||||
*/
|
*/
|
||||||
void free_addr(unsigned int arid, int vid, const string& mac)
|
void free_addr(unsigned int arid, int vid, const string& mac)
|
||||||
{
|
{
|
||||||
ar_pool.free_addr(arid, PoolObjectSQL::VM, vid, mac);
|
ar_pool.free_addr(arid, PoolObjectSQL::VM, vid, mac);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Release all previously given address leases to the given object
|
||||||
|
* @param ot the type of the object requesting the address (VM or NET)
|
||||||
|
* @param obid the id of the object requesting the address
|
||||||
|
*/
|
||||||
|
void free_addr_by_owner(PoolObjectSQL::ObjectType ot, int obid)
|
||||||
|
{
|
||||||
|
ar_pool.free_addr_by_owner(ot, obid);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Modifies the given nic attribute adding the following attributes:
|
||||||
|
* * IP: leased from network
|
||||||
|
* * MAC: leased from network
|
||||||
|
* * BRIDGE: for this virtual network
|
||||||
|
* @param nic attribute for the VM template
|
||||||
|
* @param vid of the VM getting the lease
|
||||||
|
* @param inherit_attrs Attributes to be inherited from the vnet template
|
||||||
|
* into the nic
|
||||||
|
* @return 0 on success
|
||||||
|
*/
|
||||||
|
int nic_attribute(
|
||||||
|
VectorAttribute * nic,
|
||||||
|
int vid,
|
||||||
|
const vector<string>& inherit_attrs);
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Network Reservation functions
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
|
int reserve_addr(VirtualNetwork *rvnet, unsigned int rsize, string& error_str);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// *************************************************************************
|
||||||
|
// Formatting & Helper functions
|
||||||
|
// *************************************************************************
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets used leases
|
* Gets used leases
|
||||||
* @return number of network leases in used
|
* @return number of network leases in used
|
||||||
@ -185,22 +244,6 @@ public:
|
|||||||
*/
|
*/
|
||||||
string& to_xml_extended(string& xml) const;
|
string& to_xml_extended(string& xml) const;
|
||||||
|
|
||||||
/**
|
|
||||||
* Modifies the given nic attribute adding the following attributes:
|
|
||||||
* * IP: leased from network
|
|
||||||
* * MAC: leased from network
|
|
||||||
* * BRIDGE: for this virtual network
|
|
||||||
* @param nic attribute for the VM template
|
|
||||||
* @param vid of the VM getting the lease
|
|
||||||
* @param inherit_attrs Attributes to be inherited from the vnet template
|
|
||||||
* into the nic
|
|
||||||
* @return 0 on success
|
|
||||||
*/
|
|
||||||
int nic_attribute(
|
|
||||||
VectorAttribute * nic,
|
|
||||||
int vid,
|
|
||||||
const vector<string>& inherit_attrs);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Replace the template of the virtual network it also updates the BRIDGE,
|
* Replace the template of the virtual network it also updates the BRIDGE,
|
||||||
* PHY_DEV, VLAN_ID and VLAN attributes.
|
* PHY_DEV, VLAN_ID and VLAN attributes.
|
||||||
@ -219,6 +262,15 @@ public:
|
|||||||
*/
|
*/
|
||||||
void get_template_attribute(const char * name, string& value, int ar_id) const;
|
void get_template_attribute(const char * name, string& value, int ar_id) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return A copy of the VNET Template
|
||||||
|
*/
|
||||||
|
VirtualNetworkTemplate * clone_template() const
|
||||||
|
{
|
||||||
|
return new VirtualNetworkTemplate(
|
||||||
|
*(static_cast<VirtualNetworkTemplate *>(obj_template)));
|
||||||
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
|
@ -66,6 +66,22 @@ class OneVNetHelper < OpenNebulaHelper::OneHelper
|
|||||||
:description => "IP6 ula prefix"
|
:description => "IP6 ula prefix"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
R_NAME = {
|
||||||
|
:name => "rname",
|
||||||
|
:short => "-n reservation name",
|
||||||
|
:large => "--name reservation name",
|
||||||
|
:format => String,
|
||||||
|
:description => "Name of the address reservation"
|
||||||
|
}
|
||||||
|
|
||||||
|
R_SIZE = {
|
||||||
|
:name => "rsize",
|
||||||
|
:short => "-s reservation size",
|
||||||
|
:large => "--size reservation size",
|
||||||
|
:format => String,
|
||||||
|
:description => "Number of addresses to reserve"
|
||||||
|
}
|
||||||
|
|
||||||
def self.rname
|
def self.rname
|
||||||
"VNET"
|
"VNET"
|
||||||
end
|
end
|
||||||
@ -240,7 +256,7 @@ class OneVNetHelper < OpenNebulaHelper::OneHelper
|
|||||||
if d['VM']
|
if d['VM']
|
||||||
"VM : #{d['VM']}"
|
"VM : #{d['VM']}"
|
||||||
elsif d['VNET']
|
elsif d['VNET']
|
||||||
"NET: #{d['VM']}"
|
"NET: #{d['VNET']}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -182,6 +182,33 @@ cmd=CommandParser::CmdParser.new(ARGV) do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
reserve_desc = <<-EOT.unindent
|
||||||
|
Reserve addresses from the Virtual Network
|
||||||
|
EOT
|
||||||
|
|
||||||
|
command :reserve, reserve_desc, :vnetid,
|
||||||
|
:options=>STD_OPTIONS + [OneVNetHelper::AR, OneVNetHelper::R_NAME,
|
||||||
|
OneVNetHelper::R_SIZE] do
|
||||||
|
helper.perform_action(args[0],options,"reservation made") do |vn|
|
||||||
|
ar = options[:ar_id] || -1
|
||||||
|
rsize = options[:rsize] || -1
|
||||||
|
rname = options[:rname] || -1
|
||||||
|
|
||||||
|
if rsize == -1
|
||||||
|
STDERR.puts "Specify a size (-s size) for the reservation"
|
||||||
|
exit -1
|
||||||
|
end
|
||||||
|
|
||||||
|
if rname == -1
|
||||||
|
STDERR.puts "Specify a name (-n name) for the reservation"
|
||||||
|
exit -1
|
||||||
|
end
|
||||||
|
|
||||||
|
vn.reserve(rname, rsize)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
chgrp_desc = <<-EOT.unindent
|
chgrp_desc = <<-EOT.unindent
|
||||||
Changes the Virtual Network group
|
Changes the Virtual Network group
|
||||||
EOT
|
EOT
|
||||||
|
@ -35,7 +35,8 @@ module OpenNebula
|
|||||||
:update => "vn.update",
|
:update => "vn.update",
|
||||||
:hold => "vn.hold",
|
:hold => "vn.hold",
|
||||||
:release => "vn.release",
|
:release => "vn.release",
|
||||||
:rename => "vn.rename"
|
:rename => "vn.rename",
|
||||||
|
:reserve => "vn.reserve"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Creates a VirtualNetwork description with just its identifier
|
# Creates a VirtualNetwork description with just its identifier
|
||||||
@ -185,6 +186,21 @@ module OpenNebula
|
|||||||
return rc
|
return rc
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Reserve a set of addresses from this virtual network
|
||||||
|
# @param name [String] of the reservation
|
||||||
|
# @param rsize[String] number of addresses to reserve
|
||||||
|
def reserve(rname, rsize)
|
||||||
|
return Error.new('ID not defined') if !@pe_id
|
||||||
|
|
||||||
|
rtmpl = "NAME = #{rname}\n"
|
||||||
|
rtmpl << "SIZE = #{rsize}\n"
|
||||||
|
|
||||||
|
rc = @client.call(VN_METHODS[:reserve], @pe_id, rtmpl)
|
||||||
|
rc = nil if !OpenNebula.is_error?(rc)
|
||||||
|
|
||||||
|
return rc
|
||||||
|
end
|
||||||
|
|
||||||
# Changes the owner/group
|
# Changes the owner/group
|
||||||
#
|
#
|
||||||
# @param uid [Integer] the new owner id. Set to -1 to leave the current one
|
# @param uid [Integer] the new owner id. Set to -1 to leave the current one
|
||||||
|
@ -281,6 +281,7 @@ void RequestManager::register_xml_methods()
|
|||||||
xmlrpc_c::methodPtr vn_update_ar(new VirtualNetworkUpdateAddressRange());
|
xmlrpc_c::methodPtr vn_update_ar(new VirtualNetworkUpdateAddressRange());
|
||||||
xmlrpc_c::methodPtr vn_hold(new VirtualNetworkHold());
|
xmlrpc_c::methodPtr vn_hold(new VirtualNetworkHold());
|
||||||
xmlrpc_c::methodPtr vn_release(new VirtualNetworkRelease());
|
xmlrpc_c::methodPtr vn_release(new VirtualNetworkRelease());
|
||||||
|
xmlrpc_c::methodPtr vn_reserve(new VirtualNetworkReserve());
|
||||||
|
|
||||||
// Update Template Methods
|
// Update Template Methods
|
||||||
xmlrpc_c::methodPtr image_update(new ImageUpdateTemplate());
|
xmlrpc_c::methodPtr image_update(new ImageUpdateTemplate());
|
||||||
@ -486,6 +487,7 @@ void RequestManager::register_xml_methods()
|
|||||||
RequestManagerRegistry.addMethod("one.groupquota.update", group_set_default_quota);
|
RequestManagerRegistry.addMethod("one.groupquota.update", group_set_default_quota);
|
||||||
|
|
||||||
/* Network related methods*/
|
/* Network related methods*/
|
||||||
|
RequestManagerRegistry.addMethod("one.vn.reserve", vn_reserve);
|
||||||
RequestManagerRegistry.addMethod("one.vn.add_ar", vn_add_ar);
|
RequestManagerRegistry.addMethod("one.vn.add_ar", vn_add_ar);
|
||||||
RequestManagerRegistry.addMethod("one.vn.rm_ar", vn_rm_ar);
|
RequestManagerRegistry.addMethod("one.vn.rm_ar", vn_rm_ar);
|
||||||
RequestManagerRegistry.addMethod("one.vn.update_ar", vn_update_ar);
|
RequestManagerRegistry.addMethod("one.vn.update_ar", vn_update_ar);
|
||||||
|
@ -24,7 +24,7 @@ using namespace std;
|
|||||||
|
|
||||||
string RequestManagerVirtualNetwork::leases_error (const string& error)
|
string RequestManagerVirtualNetwork::leases_error (const string& error)
|
||||||
{
|
{
|
||||||
return request_error("Error modifying network leases",error);
|
return request_error("Error modifying network leases", error);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
@ -64,7 +64,7 @@ void RequestManagerVirtualNetwork::
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = leases_action(vn,&tmpl,error_str);
|
rc = leases_action(vn, &tmpl, att, error_str);
|
||||||
|
|
||||||
if ( rc < 0 )
|
if ( rc < 0 )
|
||||||
{
|
{
|
||||||
@ -127,3 +127,145 @@ void VirtualNetworkRmAddressRange::
|
|||||||
|
|
||||||
success_response(id, att);
|
success_response(id, att);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void VirtualNetworkReserve::request_execute(
|
||||||
|
xmlrpc_c::paramList const& paramList, RequestAttributes& att)
|
||||||
|
{
|
||||||
|
int id = xmlrpc_c::value_int (paramList.getInt(1));
|
||||||
|
string str_tmpl = xmlrpc_c::value_string (paramList.getString(2));
|
||||||
|
|
||||||
|
VirtualNetworkTemplate tmpl;
|
||||||
|
VirtualNetwork * vn;
|
||||||
|
|
||||||
|
string error_str;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
if ( basic_authorization(id, att) == false )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------- Process the Reservation Template -------------------
|
||||||
|
|
||||||
|
rc = tmpl.parse_str_or_xml(str_tmpl, error_str);
|
||||||
|
|
||||||
|
if ( rc != 0 )
|
||||||
|
{
|
||||||
|
failure_response(ACTION,
|
||||||
|
request_error("Error in reservation request", error_str), att);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int size;
|
||||||
|
|
||||||
|
if ( !tmpl.get("SIZE", size) || size <= 0 )
|
||||||
|
{
|
||||||
|
failure_response(ACTION, request_error("Error in reservation request",
|
||||||
|
"Reservation SIZE must be a greater than 0"), att);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
string name;
|
||||||
|
|
||||||
|
tmpl.get("NAME", name);
|
||||||
|
|
||||||
|
if (name.empty())
|
||||||
|
{
|
||||||
|
failure_response(ACTION, request_error("Error in reservation request",
|
||||||
|
"NAME for reservation has to be set"), att);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// --------------- Create a new VNET to place the reservation -------------
|
||||||
|
|
||||||
|
vn = static_cast<VirtualNetwork *>(pool->get(id,true));
|
||||||
|
|
||||||
|
if ( vn == 0 )
|
||||||
|
{
|
||||||
|
failure_response(NO_EXISTS, get_error(object_name(auth_object),id),att);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
VirtualNetworkTemplate * vtmpl = vn->clone_template();
|
||||||
|
|
||||||
|
vtmpl->replace("NAME", name);
|
||||||
|
|
||||||
|
int rid;
|
||||||
|
int cluster_id = vn->get_cluster_id();
|
||||||
|
|
||||||
|
rc = (static_cast<VirtualNetworkPool *>(pool))->allocate(att.uid, att.gid,
|
||||||
|
att.uname, att.gname, att.umask, vtmpl, &rid, cluster_id,
|
||||||
|
vn->get_cluster_name(), error_str);
|
||||||
|
|
||||||
|
if (rc < 0)
|
||||||
|
{
|
||||||
|
failure_response(INTERNAL,
|
||||||
|
request_error("Cannot allocate reservation VNET", error_str), att);
|
||||||
|
|
||||||
|
vn->unlock();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
VirtualNetwork * rvn = static_cast<VirtualNetwork *>(pool->get(rid,true));
|
||||||
|
|
||||||
|
if (rvn == 0)
|
||||||
|
{
|
||||||
|
failure_response(INTERNAL,
|
||||||
|
request_error("Cannot allocate reservation VNET",""), att);
|
||||||
|
|
||||||
|
vn->unlock();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// -------------- Make address reservation and set it ----------------------
|
||||||
|
|
||||||
|
if (vn->reserve_addr(rvn, size, error_str) != 0 )
|
||||||
|
{
|
||||||
|
failure_response(ACTION, request_error(error_str,""), att);
|
||||||
|
|
||||||
|
pool->drop(rvn, error_str);
|
||||||
|
|
||||||
|
rvn->unlock();
|
||||||
|
|
||||||
|
vn->unlock();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
pool->update(rvn);
|
||||||
|
|
||||||
|
pool->update(vn);
|
||||||
|
|
||||||
|
rvn->unlock();
|
||||||
|
|
||||||
|
vn->unlock();
|
||||||
|
|
||||||
|
// -------------- Add the reservation to the cluster ----------------------
|
||||||
|
|
||||||
|
if ( cluster_id != ClusterPool::NONE_CLUSTER_ID )
|
||||||
|
{
|
||||||
|
Nebula& nd = Nebula::instance();
|
||||||
|
|
||||||
|
ClusterPool * clpool = nd.get_clpool();
|
||||||
|
Cluster * cluster = clpool->get(cluster_id, true);
|
||||||
|
|
||||||
|
if ( cluster != 0 )
|
||||||
|
{
|
||||||
|
cluster->add_vnet(rid, error_str);
|
||||||
|
|
||||||
|
clpool->update(cluster);
|
||||||
|
|
||||||
|
cluster->unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
success_response(rid, att);
|
||||||
|
}
|
||||||
|
@ -178,6 +178,16 @@ int AddressRange::from_vattr(VectorAttribute *vattr, string& error_msg)
|
|||||||
|
|
||||||
vattr->replace("AR_ID", id);
|
vattr->replace("AR_ID", id);
|
||||||
|
|
||||||
|
vattr->remove("ALLOCATED");
|
||||||
|
|
||||||
|
vattr->remove("USED_LEASES");
|
||||||
|
|
||||||
|
vattr->remove("LEASES");
|
||||||
|
|
||||||
|
vattr->remove("PARENT_NETWORK_AR_ID");
|
||||||
|
|
||||||
|
vattr->remove("PARENT_NETWORK");
|
||||||
|
|
||||||
if (do_mac) //Need to add MAC to the attribute
|
if (do_mac) //Need to add MAC to the attribute
|
||||||
{
|
{
|
||||||
set_mac(0, attr);
|
set_mac(0, attr);
|
||||||
@ -214,6 +224,10 @@ void AddressRange::update_attributes(VectorAttribute *vup)
|
|||||||
|
|
||||||
vup->remove("LEASES");
|
vup->remove("LEASES");
|
||||||
|
|
||||||
|
vup->remove("PARENT_NETWORK_AR_ID");
|
||||||
|
|
||||||
|
vup->remove("PARENT_NETWORK");
|
||||||
|
|
||||||
/* ----------------- update known attributes ----------------- */
|
/* ----------------- update known attributes ----------------- */
|
||||||
|
|
||||||
unsigned int new_size;
|
unsigned int new_size;
|
||||||
@ -905,6 +919,38 @@ int AddressRange::free_addr_by_ip(PoolObjectSQL::ObjectType ot, int obid,
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
int AddressRange::free_addr_by_owner(PoolObjectSQL::ObjectType ot, int obid)
|
||||||
|
{
|
||||||
|
map<unsigned int, long long>::iterator it = allocated.begin();
|
||||||
|
|
||||||
|
long long obj_pack = ot | (obid & 0x00000000FFFFFFFFLL);
|
||||||
|
|
||||||
|
int freed = 0;
|
||||||
|
|
||||||
|
while (it != allocated.end())
|
||||||
|
{
|
||||||
|
if (it->second == obj_pack)
|
||||||
|
{
|
||||||
|
map<unsigned int, long long>::iterator prev_it = it++;
|
||||||
|
|
||||||
|
allocated.erase(prev_it);
|
||||||
|
|
||||||
|
used_addr--;
|
||||||
|
|
||||||
|
freed++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
it++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return freed;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
int AddressRange::hold_by_ip(const string& ip_s)
|
int AddressRange::hold_by_ip(const string& ip_s)
|
||||||
{
|
{
|
||||||
if (!(type & 0x00000002))//Not of type IP4 or IP4_6
|
if (!(type & 0x00000002))//Not of type IP4 or IP4_6
|
||||||
@ -965,6 +1011,63 @@ int AddressRange::hold_by_mac(const string& mac_s)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
int AddressRange::reserve_addr(int pvid, int vid, unsigned int rsize,
|
||||||
|
AddressRange *rar)
|
||||||
|
{
|
||||||
|
bool isset = false;
|
||||||
|
unsigned int first_index;
|
||||||
|
int pnet;
|
||||||
|
|
||||||
|
if (rsize > (size - used_addr))
|
||||||
|
{
|
||||||
|
return -1; //reservation dosen't fit
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((attr->vector_value("PARENT_NETWORK_ID", pnet) == 0 ) && (pnet > -1))
|
||||||
|
{
|
||||||
|
return -1; //This address range is already a reservation
|
||||||
|
}
|
||||||
|
|
||||||
|
for ( unsigned int i=0; i<rsize; next = (next+1)%size )
|
||||||
|
{
|
||||||
|
if ( allocated.count(next) == 0 )
|
||||||
|
{
|
||||||
|
allocate_addr(PoolObjectSQL::NET, vid, next);
|
||||||
|
|
||||||
|
if (!isset)
|
||||||
|
{
|
||||||
|
first_index = next;
|
||||||
|
isset = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
VectorAttribute * new_ar = attr->clone();
|
||||||
|
string errmsg;
|
||||||
|
|
||||||
|
set_mac(first_index, new_ar);
|
||||||
|
|
||||||
|
if (type & 0x00000002 )
|
||||||
|
{
|
||||||
|
set_ip(first_index, new_ar);
|
||||||
|
}
|
||||||
|
|
||||||
|
new_ar->replace("SIZE",rsize);
|
||||||
|
|
||||||
|
rar->from_vattr(new_ar, errmsg);
|
||||||
|
|
||||||
|
new_ar->replace("PARENT_NETWORK_ID", pvid);
|
||||||
|
|
||||||
|
new_ar->replace("PARENT_NETWORK_AR_ID",id);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
@ -74,6 +74,18 @@ int AddressRangePool::from_vattr(vector<Attribute *> ars, string& error_msg)
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
AddressRange * AddressRangePool::allocate_ar()
|
||||||
|
{
|
||||||
|
AddressRange * ar = new AddressRange(next_ar);
|
||||||
|
|
||||||
|
ar_pool.insert(make_pair(next_ar++, ar));
|
||||||
|
|
||||||
|
return ar;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
void AddressRangePool::update_ar(vector<Attribute *> ars)
|
void AddressRangePool::update_ar(vector<Attribute *> ars)
|
||||||
{
|
{
|
||||||
vector<Attribute *>::iterator it;
|
vector<Attribute *>::iterator it;
|
||||||
@ -175,6 +187,7 @@ int AddressRangePool::rm_ar(unsigned int ar_id, string& error_msg)
|
|||||||
|
|
||||||
vector<Attribute*> ars;
|
vector<Attribute*> ars;
|
||||||
vector<Attribute*>::iterator it_ar;
|
vector<Attribute*>::iterator it_ar;
|
||||||
|
|
||||||
Attribute * the_ar = 0;
|
Attribute * the_ar = 0;
|
||||||
|
|
||||||
unsigned int ar_id_templ;
|
unsigned int ar_id_templ;
|
||||||
@ -369,6 +382,19 @@ void AddressRangePool::free_addr_by_ip(PoolObjectSQL::ObjectType ot, int obid,
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void AddressRangePool::free_addr_by_owner(PoolObjectSQL::ObjectType ot, int oid)
|
||||||
|
{
|
||||||
|
map<unsigned int, AddressRange *>::iterator it;
|
||||||
|
|
||||||
|
for (it=ar_pool.begin(); it!=ar_pool.end(); it++)
|
||||||
|
{
|
||||||
|
used_addr = used_addr - it->second->free_addr_by_owner(ot, oid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
void AddressRangePool::get_attribute(const char * name, string& value,
|
void AddressRangePool::get_attribute(const char * name, string& value,
|
||||||
int ar_id) const
|
int ar_id) const
|
||||||
{
|
{
|
||||||
@ -471,3 +497,23 @@ int AddressRangePool::hold_by_mac(const string& mac_s)
|
|||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
int AddressRangePool::reserve_addr(int pvid, int vid, unsigned int rsize,
|
||||||
|
AddressRange *rar)
|
||||||
|
{
|
||||||
|
map<unsigned int, AddressRange *>::iterator it;
|
||||||
|
|
||||||
|
for (it=ar_pool.begin(); it!=ar_pool.end(); it++)
|
||||||
|
{
|
||||||
|
if ((it->second->get_free_addr() >= rsize) &&
|
||||||
|
(it->second->reserve_addr(pvid, vid, rsize, rar) == 0))
|
||||||
|
{
|
||||||
|
used_addr += rsize;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
@ -766,3 +766,21 @@ void VirtualNetwork::get_template_attribute(const char * name, string& value, in
|
|||||||
PoolObjectSQL::get_template_attribute(name, value);
|
PoolObjectSQL::get_template_attribute(name, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
int VirtualNetwork::reserve_addr(VirtualNetwork *rvnet,
|
||||||
|
unsigned int rsize, string& error_str)
|
||||||
|
{
|
||||||
|
AddressRange *rar = rvnet->allocate_ar();
|
||||||
|
|
||||||
|
if (ar_pool.reserve_addr(oid, rvnet->get_oid(), rsize, rar) != 0)
|
||||||
|
{
|
||||||
|
error_str = "Not enough free addresses in an address range";
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user