2014-05-02 17:04:48 +02:00
/* -------------------------------------------------------------------------- */
/* Copyright 2002-2014, OpenNebula Project (OpenNebula.org), C12G Labs */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
# ifndef ADDRESS_RANGE_H_
# define ADDRESS_RANGE_H_
# include <string>
# include <set>
# include <vector>
2014-05-08 13:42:28 +02:00
# include "PoolObjectSQL.h"
2014-05-29 12:44:41 +02:00
# include "AddressRangePool.h"
2014-05-08 13:42:28 +02:00
2014-05-02 17:04:48 +02:00
using namespace std ;
class VectorAttribute ;
/**
* The Lease class represents an address lease from a Virtual Network .
*/
class AddressRange
{
public :
2014-05-10 21:44:39 +02:00
AddressRange ( unsigned int _id ) : id ( _id ) , next ( 0 ) , used_addr ( 0 ) { } ;
2014-05-02 17:04:48 +02:00
virtual ~ AddressRange ( ) { } ;
2014-05-27 17:19:36 +02:00
// *************************************************************************
// 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
// *************************************************************************
2014-05-02 17:04:48 +02:00
/**
* Init an Address Range based on a vector attribute the following
* attributes will be parsed ( * are optional ) :
* - TYPE = ETHER | IP4 | IP6 | IP4_6
* - SIZE
2014-05-08 13:42:28 +02:00
* - MAC
* - IP
2014-05-02 17:04:48 +02:00
* - ULA_PREFIX
* - GLOBAL_PREFIX
*
* The following can be defined to override VNET values :
* - BRIDGE
* - VLAN
* - VLAN_ID
* - PHYDEV
*
* Any value defined in the INHERIT_VNET_ATTR can be defined as well .
*
* Any value for context can be included in the AR .
*
* Example :
2014-05-08 13:42:28 +02:00
* - AR = [ TYPE = " ETHER " , SIZE = 128 , MAC = " 00:02:01:02:03:04 " ]
2014-05-02 17:04:48 +02:00
* - AR = [ TYPE = " ETHER " , SIZE = 128 ]
2014-05-08 13:42:28 +02:00
* - AR = [ TYPE = IP4 ,
* SIZE = 256 ,
* IP = 10.0 .0 .0 ,
* DNS = 10.0 .0 .5 ]
2014-05-02 17:04:48 +02:00
* - AR = [ TYPE = " IP6 " ,
* SIZE = 1024 ,
* ULA_PREFIX = " fd00:0:0:1:: " ,
* GLOBAL_PREFIX = " 2001:: " ]
*/
2014-05-08 13:42:28 +02:00
int from_vattr ( VectorAttribute * attr , string & error_msg ) ;
2014-05-02 17:04:48 +02:00
2014-05-08 15:48:16 +02:00
/**
* Builds an Address Range from a vector attribute stored in the DB
* @ param vattr the VectorAttribute stored in a ADDRESS_RANGE template
*/
int from_vattr_db ( VectorAttribute * vattr ) ;
/**
2014-05-10 19:46:27 +02:00
* Builds an extended XML representation of the AR to send it back to
* clients
2014-05-08 15:48:16 +02:00
*/
2014-05-10 01:22:02 +02:00
void to_xml ( ostringstream & oss ) const ;
2014-05-08 15:48:16 +02:00
2014-05-27 17:19:36 +02:00
// *************************************************************************
// Address allocation functions
// *************************************************************************
2014-05-08 13:42:28 +02:00
2014-05-02 17:04:48 +02:00
/**
* Returns an unused address , which becomes used and fills a NIC attribute
* with the configuration parameters from the address range .
2014-05-19 00:28:27 +02:00
* @ param ot the type of the object allocating the address
* @ param obid the id of the object
* @ param nic the VM NIC attribute
* @ param inherit attributes to be added to the NIC attribute
* @ return 0 if success
2014-05-02 17:04:48 +02:00
*/
2014-05-08 13:42:28 +02:00
int allocate_addr ( PoolObjectSQL : : ObjectType ot , int obid ,
VectorAttribute * nic , const vector < string > & inherit ) ;
2014-05-02 17:04:48 +02:00
2014-05-05 17:49:57 +02:00
/**
* Returns the specific address by mac if is not allocated . The NIC attr
* is filled with the configuration parameters from the address range .
2014-05-19 00:28:27 +02:00
* @ param mac the mac address
* @ param ot the type of the object allocating the address
* @ param obid the id of the object
* @ param nic the VM NIC attribute
* @ param inherit attributes to be added to the NIC attribute
* @ return 0 if success
2014-05-05 17:49:57 +02:00
*/
2014-05-08 13:42:28 +02:00
int allocate_by_mac ( const string & mac , PoolObjectSQL : : ObjectType ot ,
int obid , VectorAttribute * nic , const vector < string > & inherit ) ;
2014-05-05 17:49:57 +02:00
/**
* Returns the specific address by ip if is not allocated . The NIC attr
* is filled with the configuration parameters from the address range .
2014-05-19 00:28:27 +02:00
* @ param ot the type of the object allocating the address
* @ param obid the id of the object
* @ param nic the VM NIC attribute
* @ param inherit attributes to be added to the NIC attribute
* @ return 0 if success
2014-05-05 17:49:57 +02:00
*/
2014-05-08 13:42:28 +02:00
int allocate_by_ip ( const string & ip , PoolObjectSQL : : ObjectType ot ,
int obid , VectorAttribute * nic , const vector < string > & inherit ) ;
2014-05-05 17:49:57 +02:00
2014-05-19 00:28:27 +02:00
/**
* Sets the given ip on hold , the address is associated to a VM of id - 1.
* @ param ip the ip to hold
*/
int hold_by_ip ( const string & ip ) ;
/**
* Sets the given mac on hold , the address is associated to a VM of id - 1.
* @ param mac the mac to hold
*/
int hold_by_mac ( const string & mac ) ;
2014-05-02 17:04:48 +02:00
/**
* Frees a previous allocated address , referenced by its MAC address
2014-05-10 19:46:27 +02:00
* @ param ot the object type of the owner of the address
* @ param obid the id of the owner of the address
2014-05-02 17:04:48 +02:00
* @ param mac the MAC address in string form
2014-05-10 21:44:39 +02:00
* @ return 0 if the address was freed
2014-05-02 17:04:48 +02:00
*/
2014-05-10 21:44:39 +02:00
int free_addr ( PoolObjectSQL : : ObjectType ot , int obid , const string & mac ) ;
2014-05-02 17:04:48 +02:00
2014-05-19 17:59:06 +02:00
/**
* Frees a previous allocated address , referenced by its IP address
* @ param ot the object type of the owner of the address
* @ param obid the id of the owner of the address
* @ param ip the IP address in string form
* @ return 0 if the address was freed
*/
int free_addr_by_ip ( PoolObjectSQL : : ObjectType ot , int id , const string & ip ) ;
2014-05-27 17:19:36 +02:00
/**
* 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 ) ;
2014-06-02 19:18:05 +02:00
/**
* Frees a previous allocated address range , referenced by its MAC address
* and size
* @ param ot the object type of the owner of the address
* @ param obid the id of the owner of the address
* @ param mac the first MAC address in string form
* @ param rsize the size of the range
* @ return the number of addresses freed
*/
int free_addr_by_range ( PoolObjectSQL : : ObjectType ot , int obid ,
const string & mac , unsigned int rsize ) ;
2014-05-27 17:19:36 +02:00
// *************************************************************************
// Address Reservation
// *************************************************************************
/**
* Reserve a given number of addresses from this address range
* @ 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
*/
2014-05-30 18:59:25 +02:00
int reserve_addr ( int vid , unsigned int rsize , AddressRange * rar ) ;
2014-05-27 17:19:36 +02:00
2014-05-29 23:55:51 +02:00
/**
* Reserve a given number of addresses from this address range
* @ 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
* @ param ip the firs ip in the Reservation
* @ return 0 on success
*/
2014-05-30 18:59:25 +02:00
int reserve_addr_by_ip ( int vid , unsigned int rsize , const string & ip ,
AddressRange * rar ) ;
2014-05-27 17:19:36 +02:00
2014-05-29 23:55:51 +02:00
/**
* Reserve a given number of addresses from this address range
* @ 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
* @ param mac the firs mac in the Reservation
* @ return 0 on success
*/
2014-05-30 18:59:25 +02:00
int reserve_addr_by_mac ( int vid , unsigned int rsize , const string & mac ,
AddressRange * rar ) ;
2014-05-27 17:19:36 +02:00
// *************************************************************************
// Helpers
// *************************************************************************
2014-05-09 21:20:09 +02:00
/**
* Return the id for this address range
*/
2014-05-10 21:44:39 +02:00
unsigned int ar_id ( ) const
2014-05-09 21:20:09 +02:00
{
return id ;
}
2014-05-10 21:44:39 +02:00
/**
* Return the number of used addresses
*/
unsigned int get_used_addr ( ) const
{
return used_addr ;
}
2014-05-27 17:19:36 +02:00
/**
* Return the number of free addresses
*/
unsigned int get_free_addr ( ) const
{
return size - used_addr ;
}
2014-06-03 16:09:26 +02:00
/**
* Return the total number of addresses
*/
unsigned int get_size ( ) const
{
return size ;
}
2014-05-17 01:17:58 +02:00
/**
* Returns the string value of an Address Range Attribute
* @ param name of the attribute
* @ return the value of the attribute if found , empty otherwise
*/
string get_attribute ( const char * name ) const
{
return attr - > vector_value ( name ) ;
}
2014-05-23 00:24:14 +02:00
/**
2014-05-28 10:59:02 +02:00
* Returns the int value of an Address Range Attribute
* @ param name of the attribute
2014-06-02 19:18:05 +02:00
* @ param value of the attribute
* @ return 0 on success
2014-05-28 10:59:02 +02:00
*/
int get_attribute ( const char * name , int & value ) const
{
return attr - > vector_value ( name , value ) ;
}
/**
2014-05-23 00:24:14 +02:00
* Updates the Address Range with the attributes provided . The following
* CANNOT be updated : TYPE , SIZE , IP , MAC ( plus the internal AR_ID and
* ALLOCATED )
* @ param vup the new vector attributes for the address range
2014-06-16 17:56:50 +02:00
* @ param error_msg If the action fails , this message contains
* the reason .
* @ return 0 on success
2014-05-23 00:24:14 +02:00
*/
2014-06-16 17:56:50 +02:00
int update_attributes ( VectorAttribute * vup , string & error_msg ) ;
2014-05-23 00:24:14 +02:00
2014-05-29 12:44:41 +02:00
/*
* add_ar from AddressRangePool needs to access the internal representation
* of the AR to include it in the ARPool template .
*/
friend int AddressRangePool : : add_ar ( AddressRange * ar ) ;
2014-05-02 17:04:48 +02:00
private :
/* ---------------------------------------------------------------------- */
/* String to binary conversion functions for different address types */
/* ---------------------------------------------------------------------- */
/**
* MAC to binary ( 48 bits )
* @ param mac in string form 00 : 02 : 01 : 02 : 03 : 04
* @ return 0 on success
*/
2014-05-10 01:22:02 +02:00
int mac_to_i ( string mac , unsigned int i_mac [ ] ) const ;
2014-05-02 17:04:48 +02:00
/**
* IP version 4 to binary ( 32 bits )
* @ param ip in string form 192.168 .0 .2
* @ return 0 on success
*/
2014-05-10 01:22:02 +02:00
int ip_to_i ( const string & _ip , unsigned int & i_ip ) const ;
2014-05-02 17:04:48 +02:00
/**
* IPv6 64 bits prefix conversion
* @ param prefix in string form 2 a00 : 1 bc0 : b001 : A : :
* @ return 0 on success
*/
2014-05-10 01:22:02 +02:00
int prefix6_to_i ( const string & prefix , unsigned int ip [ ] ) const ;
2014-05-02 17:04:48 +02:00
/* ---------------------------------------------------------------------- */
/* NIC setup functions */
/* ---------------------------------------------------------------------- */
2014-05-08 13:42:28 +02:00
/**
* Writes MAC address to the given NIC attribute
* @ param addr_index internal index for the lease
* @ param nic attribute of a VMTemplate
*/
2014-05-10 01:22:02 +02:00
void set_mac ( unsigned int addr_index , VectorAttribute * nic ) const ;
2014-05-02 17:04:48 +02:00
2014-05-08 13:42:28 +02:00
/**
* Writes IP address to the given NIC attribute
* @ param addr_index internal index for the lease
* @ param nic attribute of a VMTemplate
*/
2014-05-10 01:22:02 +02:00
void set_ip ( unsigned int addr_index , VectorAttribute * nic ) const ;
2014-05-02 17:04:48 +02:00
2014-05-08 13:42:28 +02:00
/**
* Writes IPv6 address to the given NIC attribute
* @ param addr_index internal index for the lease
* @ param nic attribute of a VMTemplate
*/
2014-05-10 01:22:02 +02:00
void set_ip6 ( unsigned int addr_index , VectorAttribute * nic ) const ;
2014-05-02 17:04:48 +02:00
2014-05-08 13:42:28 +02:00
/**
* Writes VNET configuration attributes to the given NIC attribute . It
* includes : BRIDGE , VLAN , VLAN_ID , PHYDEV and INHERIT_VNET_ATTR in oned . conf
* @ param addr_index internal index for the lease
* @ param nic attribute of a VMTemplate
*/
2014-05-10 01:22:02 +02:00
void set_vnet ( VectorAttribute * nic , const vector < string > & inherit ) const ;
2014-05-02 17:04:48 +02:00
/* ---------------------------------------------------------------------- */
2014-05-08 13:42:28 +02:00
/* Address index map helper functions */
2014-05-02 17:04:48 +02:00
/* ---------------------------------------------------------------------- */
2014-05-08 15:48:16 +02:00
/**
* This function generates a string representation of the in - memory allocated
* addresses . It ' ll be stored along side the AR vector attribute in the
* ADDRESS_RANGE template .
*/
2014-05-02 17:04:48 +02:00
void allocated_to_attr ( ) ;
2014-05-08 15:48:16 +02:00
/**
* Generates a memory map for the addresses .
* @ param allocated_s the string representation of the allocated addresses
* generated by allocated_to_attr ( )
* @ return 0 on success
*/
2014-05-08 13:42:28 +02:00
int attr_to_allocated ( const string & allocated_s ) ;
2014-05-02 17:04:48 +02:00
2014-05-08 15:48:16 +02:00
/**
* Adds a new allocated address to the map . Updates the ALLOCATED attribute
*/
2014-05-08 13:42:28 +02:00
void allocate_addr ( PoolObjectSQL : : ObjectType ot , int obid ,
unsigned int addr_index ) ;
2014-05-02 17:04:48 +02:00
2014-05-08 15:48:16 +02:00
/**
* Frees an address from the map . Updates the ALLOCATED attribute
*/
2014-05-10 21:44:39 +02:00
int free_addr ( PoolObjectSQL : : ObjectType ot , int obid ,
2014-05-10 19:46:27 +02:00
unsigned int addr_index ) ;
2014-05-02 17:04:48 +02:00
2014-05-29 23:55:51 +02:00
/**
* Reserve a set of addresses from an starting one
* @ param vid the id of the VNET making the reservation
* @ param rsize number of addresses to reserve
* @ param sindex the first index to start the reservation
* @ param rar a new address range to place the reservation
* @ return 0 on success
*/
2014-05-30 18:59:25 +02:00
int reserve_addr_by_index ( int vid , unsigned int rsize , unsigned int sindex ,
AddressRange * rar ) ;
2014-05-29 23:55:51 +02:00
2014-05-02 17:04:48 +02:00
/* ---------------------------------------------------------------------- */
2014-05-08 13:42:28 +02:00
/* Restricted Attributes functions */
2014-05-02 17:04:48 +02:00
/* ---------------------------------------------------------------------- */
2014-05-10 01:22:02 +02:00
bool check ( string & rs_attr ) const ;
2014-05-02 17:04:48 +02:00
2014-05-08 13:42:28 +02:00
static void set_restricted_attributes ( vector < const Attribute * > & rattrs ) ;
/* ---------------------------------------------------------------------- */
/* Address Range data */
/* ---------------------------------------------------------------------- */
2014-05-02 17:04:48 +02:00
/**
* The type of addresses defined in the range
*/
AddressType type ;
/**
* ID for this range , unique within the Virtual Network
*/
unsigned int id ;
/**
* Number of addresses in the range
*/
unsigned int size ;
/**
* First IP4 in the range
*/
2014-05-08 13:42:28 +02:00
unsigned int ip ;
2014-05-02 17:04:48 +02:00
/**
* First MAC in the range
*/
2014-05-08 13:42:28 +02:00
unsigned int mac [ 2 ] ;
2014-05-02 17:04:48 +02:00
/**
* Binary representation of the IPv6 address global unicast prefix
*/
unsigned int global6 [ 2 ] ;
/**
* Binary representation of the IPv6 address site unicast prefix
*/
unsigned int ula6 [ 2 ] ;
/**
2014-05-08 13:42:28 +02:00
* The Address Range attributes as a Template VectorAttribute . This is
* used to generate XML or a template representation of the AR .
*/
VectorAttribute * attr ;
/* ---------------------------------------------------------------------- */
/* Allocated address & control */
/* ---------------------------------------------------------------------- */
/**
* Map to store the allocated address indexed by the address index relative
* to the mac / ip values . It contains also the type and id of the object
* owning the address ObjectType ( 32 bits ) | Object ID ( 32 )
*/
map < unsigned int , long long > allocated ;
2014-05-10 21:44:39 +02:00
unsigned int next ;
unsigned int used_addr ;
2014-05-08 13:42:28 +02:00
/* ---------------------------------------------------------------------- */
/* Restricted Attributes */
/* ---------------------------------------------------------------------- */
/**
* TRUE if restricted attributes have been defined for Address Ranges
2014-05-02 17:04:48 +02:00
*/
2014-05-08 13:42:28 +02:00
static bool restricted_set ;
2014-05-02 17:04:48 +02:00
/**
2014-05-08 13:42:28 +02:00
* The restricted attributes from oned . conf
2014-05-02 17:04:48 +02:00
*/
2014-05-08 13:42:28 +02:00
static set < string > restricted_attributes ;
2014-05-02 17:04:48 +02:00
} ;
# endif