2014-05-02 17:04:48 +02:00
/* -------------------------------------------------------------------------- */
2021-02-09 16:07:56 +01:00
/* Copyright 2002-2021, OpenNebula Project, OpenNebula Systems */
2014-05-02 17:04:48 +02:00
/* */
/* 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
class VectorAttribute ;
/**
* The Lease class represents an address lease from a Virtual Network .
*/
class AddressRange
{
public :
virtual ~ AddressRange ( ) { } ;
2014-05-27 17:19:36 +02:00
// *************************************************************************
// Address Range types
2017-02-16 16:26:46 +01:00
/// *************************************************************************
2014-05-27 17:19:36 +02:00
/**
* Type of Addresses defined by this address range
2017-02-16 16:26:46 +01:00
* Constants are encoded as follows :
*
* option bits address family bits
* - - - + - - - - + - - - - +
* . . . * | 0000 | * * * * |
* - - - - + - - - - + | | | | +
* | | | \ ___ AR with Ethernet addresses
* | | \ ____ AR with IPv4 addresses
* | \ _____ AR with IPv6 addresses ( SLAAC )
* \ ______ AR with IPv6 addresses ( static , non - SLAAC )
2014-05-27 17:19:36 +02:00
*/
enum AddressType
{
2017-02-16 16:26:46 +01:00
NONE = 0x00000000 , /** Undefined Address Type */
ETHER = 0x00000001 , /** MAC address type */
IP4 = 0x00000003 , /** MAC + IP4 address */
IP6 = 0x00000005 , /** MAC + IP6 address */
IP6_STATIC = 0x00000009 , /** MAC + IP6 (no-SLAAC) address */
IP4_6 = 0x00000007 , /** MAC + IP4 + IP6 addresses */
IP4_6_STATIC = 0x0000000B , /** MAC + IP4 + IP6 (no-SLAAC) addresses */
2014-05-27 17:19:36 +02:00
} ;
/**
* Return the string representation of an AddressType
* @ param ob the type
* @ return the string
*/
2020-07-02 22:42:10 +02:00
static std : : string type_to_str ( AddressType ob ) ;
2014-05-27 17:19:36 +02:00
/**
* Return the string representation of an AddressType
* @ param ob the type
* @ return the string
*/
2020-07-02 22:42:10 +02:00
static AddressType str_to_type ( std : : string & str_type ) ;
2014-05-27 17:19:36 +02:00
2017-02-16 16:26:46 +01:00
/**
* Return true if the address range includes IPv4 addresses
*/
bool is_ipv4 ( ) const
{
return ( type & 0x00000002 ) ! = 0 ;
}
/**
* Return true if the address range includes IPv6 addresses
*/
bool is_ipv6 ( ) const
{
return ( type & 0x00000004 ) ! = 0 ;
}
/**
* Return true if the address range includes static IPv6 addresses ( host id
* is manually defined )
*/
bool is_ipv6_static ( ) const
{
return ( type & 0x00000008 ) ! = 0 ;
}
2018-10-18 15:20:47 +02:00
bool is_ipam ( ) const
{
return ! attr - > vector_value ( " IPAM_MAD " ) . empty ( ) & & attr - > vector_value ( " IPAM_MAD " ) ! = " internal " ;
}
2014-05-27 17:19:36 +02:00
// *************************************************************************
// 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_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:: " ]
2016-08-17 19:22:53 +02:00
*
* NOTE : This function is part of the AddressRange interface . The AR
* implementation may contact an external IPAM to complete or validate
* the AR allocation request .
2014-05-02 17:04:48 +02:00
*/
2020-07-02 22:42:10 +02:00
virtual int from_vattr ( VectorAttribute * attr , std : : string & error_msg ) = 0 ;
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-09-11 17:00:27 +02:00
* @ param oss stream to write the XML
* @ param vm_ids list of VM the user can access VNET usage info from .
* A vector containing just - 1 means all VMs .
* @ param vnet_ids list of VNET the user can access reservation info from .
* A vector containing just - 1 means all VNETs .
2016-01-07 16:58:54 +01:00
* @ param vrs list of VRouter the user can access VNET usage info from .
* A vector containing just - 1 means all VRouters .
2014-05-08 15:48:16 +02:00
*/
2020-07-02 22:42:10 +02:00
void to_xml ( std : : ostringstream & oss , const std : : vector < int > & vms ,
const std : : vector < int > & vnets , const std : : vector < int > & vrs ) const ;
2014-05-08 15:48:16 +02:00
2016-08-18 21:42:24 +02:00
/**
* Same as above but without the LEASES section
*/
2020-07-02 22:42:10 +02:00
void to_xml ( std : : ostringstream & oss ) const ;
2016-08-18 21:42:24 +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 ,
2020-07-02 22:42:10 +02:00
VectorAttribute * nic , const std : : vector < std : : string > & inherit ) ;
2014-05-02 17:04:48 +02:00
2014-05-05 17:49:57 +02:00
/**
2017-02-21 16:50:45 +01:00
* Returns the specific address by mac / ip if is not allocated . The NIC attr
2014-05-05 17:49:57 +02:00
* 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
*/
2020-07-02 22:42:10 +02:00
int allocate_by_mac ( const std : : string & mac , PoolObjectSQL : : ObjectType ot ,
int obid , VectorAttribute * nic , const std : : vector < std : : string > & inherit ) ;
2014-05-05 17:49:57 +02:00
2020-07-02 22:42:10 +02:00
int allocate_by_ip ( const std : : string & ip , PoolObjectSQL : : ObjectType ot ,
int obid , VectorAttribute * nic , const std : : vector < std : : string > & inherit ) ;
2014-05-05 17:49:57 +02:00
2020-07-02 22:42:10 +02:00
int allocate_by_ip6 ( const std : : string & ip6 , PoolObjectSQL : : ObjectType ot ,
int obid , VectorAttribute * nic , const std : : vector < std : : string > & inherit ) ;
2014-05-19 00:28:27 +02:00
/**
2017-02-21 16:50:45 +01:00
* Sets the given ip / mac on hold , the address is associated to a VM of
* id - 1.
* @ param ip / mac the ip to hold
2014-05-19 00:28:27 +02:00
*/
2020-07-02 22:42:10 +02:00
int hold_by_mac ( const std : : string & mac ) ;
2014-05-19 00:28:27 +02:00
2020-07-02 22:42:10 +02:00
int hold_by_ip ( const std : : string & ip ) ;
2017-02-21 16:50:45 +01:00
2020-07-02 22:42:10 +02:00
int hold_by_ip6 ( const std : : string & ip ) ;
2017-02-21 16:50:45 +01:00
2014-05-02 17:04:48 +02:00
/**
2017-02-21 16:50:45 +01:00
* Frees a previous allocated address , referenced by its MAC / IP 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
2017-02-21 16:50:45 +01:00
* @ param mac / ip the MAC / IP 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
*/
2020-07-02 22:42:10 +02:00
int free_addr ( PoolObjectSQL : : ObjectType ot , int obid , const std : : string & mac ) ;
2014-05-02 17:04:48 +02:00
2020-07-02 22:42:10 +02:00
int free_addr_by_ip ( PoolObjectSQL : : ObjectType ot , int id , const std : : string & ip ) ;
2014-05-19 17:59:06 +02:00
2020-07-02 22:42:10 +02:00
int free_addr_by_ip6 ( PoolObjectSQL : : ObjectType ot , int id , const std : : string & ip ) ;
2017-02-21 16:50:45 +01:00
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 ,
2020-07-02 22:42:10 +02:00
const std : : string & mac , unsigned int rsize ) ;
2014-06-02 19:18:05 +02:00
2014-10-10 16:52:51 +02:00
/**
* Adds the relevant AR definition attributes to the Security Group rule
*
* @ param rule rule to modify
*/
void process_security_rule ( VectorAttribute * rule ) ;
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
2017-02-21 16:50:45 +01:00
* @ param ip / mac the firs ip in the Reservation
2014-05-29 23:55:51 +02:00
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int reserve_addr_by_mac ( int vid , unsigned int rsize , const std : : string & mac ,
2017-02-21 16:50:45 +01:00
AddressRange * rar ) ;
2020-07-02 22:42:10 +02:00
int reserve_addr_by_ip ( int vid , unsigned int rsize , const std : : string & ip ,
2014-05-30 18:59:25 +02:00
AddressRange * rar ) ;
2014-05-27 17:19:36 +02:00
2020-07-02 22:42:10 +02:00
int reserve_addr_by_ip6 ( int vid , unsigned int rsize , const std : : string & ip ,
2014-05-30 18:59:25 +02:00
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
{
2016-08-17 19:22:53 +02:00
return allocated . size ( ) ;
2014-05-10 21:44:39 +02:00
}
2014-05-27 17:19:36 +02:00
/**
* Return the number of free addresses
*/
unsigned int get_free_addr ( ) const
{
2016-08-17 19:22:53 +02:00
return size - allocated . size ( ) ;
2014-05-27 17:19:36 +02:00
}
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
*/
2020-07-02 22:42:10 +02:00
std : : string get_attribute ( const std : : string & name ) const
2014-05-17 01:17:58 +02:00
{
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
*/
2020-07-02 22:42:10 +02:00
int get_attribute ( const std : : string & name , int & value ) const
2014-05-28 10:59:02 +02:00
{
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-09-04 13:38:11 +02:00
int update_attributes (
VectorAttribute * vup ,
bool keep_restricted ,
2020-07-02 22:42:10 +02:00
std : : string & error_msg ) ;
2014-05-23 00:24:14 +02:00
2016-08-17 19:22:53 +02:00
/**
* Helper function to initialize restricte attributes of an AddressRange
*/
2020-07-02 22:42:10 +02:00
static void set_restricted_attributes ( std : : vector < const SingleAttribute * > & ras ) ;
2016-08-17 19:22:53 +02:00
2014-11-11 16:27:46 +01:00
/**
* Get the security groups for this AR .
* @ return a reference to the security group set
*/
2020-07-02 22:42:10 +02:00
const std : : set < int > & get_security_groups ( ) const
2014-11-11 16:27:46 +01:00
{
return security_groups ;
}
2018-04-27 16:31:12 +02:00
/**
* Copy security groups into set
*/
2020-07-05 22:01:32 +02:00
void get_security_groups ( std : : set < int > & sgs ) const
2018-04-27 16:31:12 +02:00
{
2020-07-02 22:42:10 +02:00
for ( auto sg : security_groups )
2018-04-27 16:31:12 +02:00
{
2020-07-02 22:42:10 +02:00
sgs . insert ( sg ) ;
2018-04-27 16:31:12 +02:00
}
}
2019-09-17 15:53:02 +02:00
/*
2019-09-17 17:19:04 +02:00
* Decrypts the address range attributes
2019-09-17 15:53:02 +02:00
*/
2019-09-17 17:19:04 +02:00
void decrypt ( ) ;
2019-09-16 15:51:38 +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 ) ;
2019-09-17 15:53:02 +02:00
/*
* rm_ar from AddressRangePool needs to access the internal representation
* of the AR to remove it from the ARPool template .
*/
2020-07-02 22:42:10 +02:00
friend int AddressRangePool : : rm_ar ( unsigned int ar_id , bool force ,
std : : string & error_msg ) ;
2019-09-17 15:53:02 +02:00
/*
* rm_ars from AddressRangePool needs to access the internal representation
* of the AR to remove it from the ARPool template .
*/
2020-07-02 22:42:10 +02:00
friend int AddressRangePool : : rm_ars ( std : : string & error_msg ) ;
2019-09-17 15:53:02 +02:00
2016-08-17 19:22:53 +02:00
protected :
/**
* Base constructor it cannot be called directly but from the
* AddressRange factory constructor .
*/
AddressRange ( unsigned int _id ) : id ( _id ) { } ;
2016-08-19 13:26:08 +02:00
/* ---------------------------------------------------------------------- */
/* Address/AR helper functions to build/parse driver messages */
/* ---------------------------------------------------------------------- */
2016-08-17 19:22:53 +02:00
/**
* Builds the AddressRange from its vector attribute representation
*/
2020-07-02 22:42:10 +02:00
int from_attr ( VectorAttribute * attr , std : : string & error_msg ) ;
2016-08-17 19:22:53 +02:00
2016-08-18 21:42:24 +02:00
/**
* Builds an address request representation in XML form :
* < ADDRESS >
* < IP >
* < MAC >
* < IP6_ULA >
* < IP6_GLOBAL >
2017-02-21 16:50:45 +01:00
* < IP6 >
2016-08-18 21:42:24 +02:00
* < SIZE >
2016-08-19 13:26:08 +02:00
*
* @ param index for the address
* @ param size number of addresses in this request
* @ param oss string stream to write the request to
2016-08-18 21:42:24 +02:00
*/
void addr_to_xml ( unsigned int index , unsigned int size ,
2020-07-02 22:42:10 +02:00
std : : ostringstream & oss ) const ;
2016-08-18 21:42:24 +02:00
2016-08-19 13:26:08 +02:00
/**
* Check if the given MAC is valid for this address range by verifying :
* - Correct : notation
* - Part of the AR
*
* @ param index of the MAC in the AR
* @ param mac_s string representation of the MAC in : notation
* @ param check_free apart from previous checks
*
* @ return true if the MAC is valid
*/
2020-07-02 22:42:10 +02:00
bool is_valid_mac ( unsigned int & index , const std : : string & mac_s ,
bool check_free ) ;
2016-08-19 13:26:08 +02:00
/**
* Check if the given IP is valid for this address range by verifying :
* - AR is of type IP4 or IP4_6
* - Correct . notation
* - Part of the AR
*
* @ param index of the IP in the AR
* @ param ip_s string representation of the IP in . notation
* @ param check_free apart from previous checks
*
* @ return true if the IP is valid
*/
2020-07-02 22:42:10 +02:00
bool is_valid_ip ( unsigned int & index , const std : : string & ip_s ,
2020-07-05 22:01:32 +02:00
bool check_free ) const ;
2016-08-19 13:26:08 +02:00
2017-02-21 16:50:45 +01:00
/**
* Check if the given IP is valid for this address range by verifying :
* - AR is of type IP6_STATIC or IP4_6_STATIC
* - Correct : notation
* - Part of the AR
*
* @ param index of the IP in the AR
* @ param ip6_s string representation of the IP in : notation
* @ param check_free apart from previous checks
*
* @ return true if the IP is valid
*/
2020-07-02 22:42:10 +02:00
bool is_valid_ip6 ( unsigned int & index , const std : : string & ip_s ,
bool check_free ) ;
2017-02-21 16:50:45 +01:00
2016-08-17 19:22:53 +02:00
/* ---------------------------------------------------------------------- */
/* Implementation specific address management interface */
/* ---------------------------------------------------------------------- */
/**
* Sets the given range of addresses ( by index ) as used
2017-02-16 16:26:46 +01:00
* @ param ix the first address to set as used
2016-08-17 19:22:53 +02:00
* @ param sz number of addresses to set
2017-02-16 16:26:46 +01:00
* @ param mg describing the error if any
2016-08-17 19:22:53 +02:00
*
* @ return 0 if success
*/
2020-07-02 22:42:10 +02:00
virtual int allocate_addr ( unsigned int ix , unsigned int sz ,
std : : string & mg ) = 0 ;
2016-08-17 19:22:53 +02:00
/**
* Gets a range of free addresses
* @ param index the first address in the range
* @ param size number of addresses requested in the range
* @ param msg describing the error if any
*
* @ return 0 if success
*/
2020-07-02 22:42:10 +02:00
virtual int get_addr ( unsigned int & index , unsigned int sz ,
std : : string & msg ) = 0 ;
2016-08-17 19:22:53 +02:00
/**
* Sets the given address ( by index ) as free
* @ param index of the address
* @ param msg describing the error if any
*
* @ return 0 if success
*/
2020-07-02 22:42:10 +02:00
virtual int free_addr ( unsigned int index , std : : string & msg ) = 0 ;
2016-08-17 19:22:53 +02:00
/* ---------------------------------------------------------------------- */
/* Allocated addresses */
/* ---------------------------------------------------------------------- */
/**
* 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 .
*
* + - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - +
* index - - - - > | ObjectType ( 32 bits ) | Object ID ( 32 bits ) |
* + - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - +
*
* Address = First Address + index
*/
2020-07-02 22:42:10 +02:00
std : : map < unsigned int , long long > allocated ;
2014-09-04 13:38:11 +02:00
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
*/
2020-07-02 22:42:10 +02:00
int mac_to_i ( std : : string mac , unsigned int i_mac [ ] ) const ;
2014-05-02 17:04:48 +02:00
2015-02-11 19:00:40 +01:00
/**
* MAC to string
* @ param mac in array form
*/
2020-07-02 22:42:10 +02:00
std : : string mac_to_s ( const unsigned int mac [ ] ) const ;
2015-02-11 19:00:40 +01:00
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
*/
2020-07-02 22:42:10 +02:00
int ip_to_i ( const std : : string & _ip , unsigned int & i_ip ) const ;
2014-05-02 17:04:48 +02:00
2017-02-16 16:26:46 +01:00
/**
* IP version 6 to binary ( 32 bits )
* @ param ip string form 2 a00 : 1 bc0 : b001 : A : : 3
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int ip6_to_i ( const std : : string & _ip , unsigned int i_ip [ ] ) const ;
2017-02-16 16:26:46 +01:00
2015-02-11 19:00:40 +01:00
/**
* IP version 4 to dot notation
*
* @ param i_ip Numeric ( 32 bits ) IP
* @ return dot notation
*/
2020-07-02 22:42:10 +02:00
std : : string ip_to_s ( unsigned int i_ip ) const ;
2015-02-11 19:00:40 +01:00
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
*/
2020-07-02 22:42:10 +02:00
int prefix6_to_i ( const std : : string & prefix , unsigned int ip [ ] ) const ;
2014-05-02 17:04:48 +02:00
2015-02-11 19:00:40 +01:00
/**
* IPv6 to string
* @ param prefix Numeric IPv6 prefix
* @ param mac Numeric ( 48 bits ) mac address
* @ param ip6_s Will contain the resulting IPv6 string
* @ return 0 on success
*/
2016-08-18 21:42:24 +02:00
int ip6_to_s ( const unsigned int prefix [ ] , const unsigned int mac [ ] ,
2020-07-02 22:42:10 +02:00
std : : string & ip6_s ) const ;
2015-02-11 19:00:40 +01:00
2020-07-02 22:42:10 +02:00
int ip6_to_s ( const unsigned int ip6_i [ ] , std : : string & ip6_s ) const ;
2017-02-16 16:26:46 +01:00
2014-05-02 17:04:48 +02:00
/* ---------------------------------------------------------------------- */
/* NIC setup functions */
/* ---------------------------------------------------------------------- */
2016-08-17 19:22:53 +02:00
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
2017-02-16 16:26:46 +01:00
/**
* Writes IPv6 address ( no - slaac ) to the given NIC attribute
* @ param addr_index internal index for the lease
* @ param nic attribute of a VMTemplate
*/
void set_ip6_static ( unsigned int addr_index , VectorAttribute * nic ) const ;
2014-05-08 13:42:28 +02:00
/**
* Writes VNET configuration attributes to the given NIC attribute . It
2016-03-31 16:24:05 +02:00
* includes : BRIDGE , VLAN_ID , PHYDEV and INHERIT_VNET_ATTR in oned . conf
2014-05-08 13:42:28 +02:00
* @ param addr_index internal index for the lease
* @ param nic attribute of a VMTemplate
*/
2020-07-02 22:42:10 +02:00
void set_vnet ( VectorAttribute * nic ,
const std : : vector < std : : 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
*/
2020-07-02 22:42:10 +02:00
int attr_to_allocated ( const std : : 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
*/
2016-08-17 19:22:53 +02:00
void set_allocated_addr ( PoolObjectSQL : : ObjectType ot , int obid ,
2014-05-08 13:42:28 +02:00
unsigned int addr_index ) ;
2014-05-02 17:04:48 +02:00
2016-08-17 19:22:53 +02:00
/**
* Sets the address lease as used and fills a NIC attribute with the
* configuration parameters from the address range .
* @ param index of the lease in the address range
* @ 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
*/
void allocate_by_index ( unsigned int index ,
2020-07-02 22:42:10 +02:00
PoolObjectSQL : : ObjectType ot ,
int obid ,
VectorAttribute * nic ,
const std : : vector < std : : string > & inherit ) ;
2016-08-17 19:22:53 +02:00
2014-05-08 15:48:16 +02:00
/**
* Frees an address from the map . Updates the ALLOCATED attribute
*/
2016-08-17 19:22:53 +02:00
int free_allocated_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
/* ---------------------------------------------------------------------- */
2017-02-16 16:26:46 +01:00
/**
* Function to parse the IPv4 attribute ( " IP " ) for IP4 and IP4_6 ARs
* @ param error_msg if any
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int init_ipv4 ( std : : string & error_msg ) ;
2017-02-16 16:26:46 +01:00
/**
* Function to parse the IPv6 attributes ( " GLOBAL_PREFIX " and " ULA_PREFIX " )
* for IP6 and IP4_6 ARs
* @ param error_msg if any
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int init_ipv6 ( std : : string & error_msg ) ;
2017-02-16 16:26:46 +01:00
/**
* Function to parse the IPv6 attributes no slaac ( " IP6 " ) for IP6_STATIC
* and IP4_6_STATIC ARs
* @ param error_msg if any
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int init_ipv6_static ( std : : string & error_msg ) ;
2017-02-16 16:26:46 +01:00
/**
* Function to parse the MAC attributes ( " MAC " ) for all AR types
* @ param error_msg if any
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int init_mac ( std : : string & error_msg ) ;
2017-02-16 16:26:46 +01:00
/**
* Checks for restricted attributes , returns the first one found
*/
2020-07-02 22:42:10 +02:00
bool check ( std : : string & rs_attr ) const ;
2014-05-02 17:04:48 +02:00
2014-09-04 13:38:11 +02:00
/**
* Deletes all restricted attributes
*/
void remove_restricted ( VectorAttribute * va ) ;
/**
* Deletes all the attributes , except the restricted ones
*/
void remove_all_except_restricted ( VectorAttribute * va ) ;
2014-05-08 13:42:28 +02:00
/* ---------------------------------------------------------------------- */
/* 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
*/
2020-07-02 22:52:05 +02:00
unsigned int mac [ 2 ] = { 0 } ;
2014-05-02 17:04:48 +02:00
/**
* Binary representation of the IPv6 address global unicast prefix
*/
2020-07-02 22:52:05 +02:00
unsigned int global6 [ 2 ] = { 0 } ;
2014-05-02 17:04:48 +02:00
/**
* Binary representation of the IPv6 address site unicast prefix
*/
2020-07-02 22:52:05 +02:00
unsigned int ula6 [ 2 ] = { 0 } ;
2014-05-02 17:04:48 +02:00
2017-02-16 16:26:46 +01:00
/**
* Binary representation of the first IPv6 address in the AR . No SLAAC ARs
*/
2020-07-02 22:52:05 +02:00
unsigned int ip6 [ 4 ] = { 0 } ;
2017-02-16 16:26:46 +01:00
2014-11-11 16:27:46 +01:00
/**
* Security Group IDs for this Address Range
*/
2020-07-02 22:42:10 +02:00
std : : set < int > security_groups ;
2014-11-11 16:27:46 +01:00
2014-05-08 13:42:28 +02:00
/**
2016-08-17 19:22:53 +02:00
* The Address Range attributes as a Template VectorAttribute . This is
* used to generate XML or a template representation of the AR .
2014-05-08 13:42:28 +02:00
*/
2016-08-17 19:22:53 +02:00
VectorAttribute * attr ;
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
*/
2020-07-02 22:42:10 +02:00
static std : : set < std : : string > restricted_attributes ;
2014-10-31 16:57:54 +01:00
/**
* Attributes to be process for Security Group rules
*/
const static char * SG_RULE_ATTRIBUTES [ ] ;
const static int NUM_SG_RULE_ATTRIBUTES ;
2014-05-02 17:04:48 +02:00
} ;
# endif