2012-06-08 13:45:15 +02:00
/* -------------------------------------------------------------------------- */
2023-01-09 12:23:19 +01:00
/* Copyright 2002-2023, OpenNebula Project, OpenNebula Systems */
2012-06-08 13:45:15 +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 QUOTAS_H_
# define QUOTAS_H_
# include "QuotaDatastore.h"
# include "QuotaNetwork.h"
# include "QuotaVirtualMachine.h"
# include "QuotaImage.h"
2012-06-15 12:28:20 +02:00
class ObjectXML ;
2014-01-21 23:21:18 +01:00
class Quotas
2012-06-08 13:45:15 +02:00
{
public :
2012-06-15 23:33:50 +02:00
/**
* Different quota types
*/
2024-06-03 11:40:24 +02:00
enum QuotaType
{
2012-06-15 23:33:50 +02:00
DATASTORE , /**< Checks Datastore usage */
VM , /**< Checks VM usage (MEMORY, CPU and VMS) */
NETWORK , /**< Checks Network usage (leases) */
IMAGE , /**< Checks Image usage (RVMs using it) */
2016-02-01 17:07:04 +01:00
VIRTUALMACHINE , /**< Checks all VM associated resources VM, NETWORK, IMAGE */
VIRTUALROUTER /**< Checks the Virtual Router NETWORK usage (leases) */
2012-06-15 23:33:50 +02:00
} ;
2012-06-08 13:45:15 +02:00
/**
* Set the quotas
* @ param tmpl contains the user quota limits
* @ param error describes error when setting the quotas
*
* @ return 0 on success , - 1 otherwise
*/
2020-07-02 22:42:10 +02:00
int set ( Template * tmpl , std : : string & error ) ;
2012-06-08 13:45:15 +02:00
/**
* Delete usage from quota counters .
2023-12-12 16:19:20 +01:00
* @ param tmpl Template with the quota usage
2012-06-08 13:45:15 +02:00
*/
2024-06-03 11:40:24 +02:00
void ds_del ( Template * tmpl )
{
2012-06-15 23:33:50 +02:00
datastore_quota . del ( tmpl ) ;
2024-06-03 11:40:24 +02:00
}
/**
* Gets a Datastore quota identified by its ID .
*
* @ param id of the quota
* @ param va The quota , if it is found
*
* @ return 0 on success , - 1 if not found
*/
int ds_get ( const std : : string & id , VectorAttribute * * va )
{
return datastore_quota . get_quota ( id , va ) ;
}
/**
* Add VM quota usage , without checking limits
* @ param tmpl Template with the quota usage
*/
void vm_add ( Template * tmpl )
{
vm_quota . add ( tmpl ) ;
}
/**
* Gets a VM quota identified by its ID .
*
* @ param id of the quota
* @ param va The quota , if it is found
*
* @ return 0 on success , - 1 if not found
*/
int vm_get ( const std : : string & id , VectorAttribute * * va )
{
return vm_quota . get_quota ( id , va ) ;
}
/**
* Gets a Network quota identified by its ID .
*
* @ param id of the quota
* @ param va The quota , if it is found
*
* @ return 0 on success , - 1 if not found
*/
int network_get ( const std : : string & id , VectorAttribute * * va )
{
return network_quota . get_quota ( id , va ) ;
}
/**
* Gets an Image quota identified by its ID .
*
* @ param id of the quota
* @ param va The quota , if it is found
*
* @ return 0 on success , - 1 if not found
*/
int image_get ( const std : : string & id , VectorAttribute * * va )
{
return image_quota . get_quota ( id , va ) ;
}
2012-11-19 15:19:09 +01:00
2012-06-15 23:33:50 +02:00
/**
* Check quota , it updates usage counters if quotas are not exceeded .
* @ param type the quota to work with
* @ param tmpl template for the VirtualMachine
2012-11-19 16:38:39 +01:00
* @ param default_quotas Quotas that contain the default limits
2012-06-15 23:33:50 +02:00
* @ param error_str string describing the error
2013-02-23 19:49:06 +01:00
* @ return true if resource can be allocated , false otherwise
2012-06-15 23:33:50 +02:00
*/
2024-06-03 11:40:24 +02:00
bool quota_check ( QuotaType type ,
2012-11-19 16:38:39 +01:00
Template * tmpl ,
Quotas & default_quotas ,
2020-07-02 22:42:10 +02:00
std : : string & error_str ) ;
2012-06-15 23:33:50 +02:00
2013-07-22 22:08:01 +02:00
/**
* Update usage of an existing quota ( e . g . size of an image ) , it updates
* the usage counters if quotas are not exceeded .
* @ param type the quota to work with
* @ param tmpl template for the VirtualMachine
* @ param default_quotas Quotas that contain the default limits
* @ param error_str string describing the error
* @ return true if resource can be updated , false otherwise
*/
2024-06-03 11:40:24 +02:00
bool quota_update ( QuotaType type ,
Template * tmpl ,
Quotas & default_quotas ,
std : : string & error_str ) ;
2013-07-22 22:08:01 +02:00
2012-06-15 23:33:50 +02:00
/**
* Delete usage from the given quota counters .
* @ param type the quota to work with
* @ param tmpl template for the image , with usage
*/
void quota_del ( QuotaType type , Template * tmpl ) ;
2012-06-08 13:45:15 +02:00
/**
* Generates a string representation of the quotas in XML format
* @ param xml the string to store the XML
* @ return the same xml string to use it in < < compounds
*/
2020-07-02 22:42:10 +02:00
std : : string & to_xml ( std : : string & xml ) const ;
2012-06-08 13:45:15 +02:00
/**
* Builds quota object from an ObjectXML
2012-11-29 23:53:34 +01:00
* @ param object_xml pointer to the ObjectXML
2012-06-08 13:45:15 +02:00
* @ return 0 if success
*/
2012-06-15 12:28:20 +02:00
int from_xml ( ObjectXML * object_xml ) ;
2012-06-08 13:45:15 +02:00
2023-12-12 16:19:20 +01:00
/**
* Add VM quota usage , without checking the limits
* @ param uid of the user
* @ param gid of the group
* @ param tmpl template with quota usage
* @ note Use carefully as this method may exceed quota limits
*/
static void vm_add ( int uid , int gid , Template * tmpl ) ;
2012-06-15 12:28:20 +02:00
/**
* Delete VM related usage ( network , image and compute ) from quota counters .
* for the given user and group
* @ param uid of the user
* @ param gid of the group
2018-09-05 15:14:39 +02:00
* @ param tmpl template for the vm with usage
2012-06-15 12:28:20 +02:00
*/
2012-06-15 23:33:50 +02:00
static void vm_del ( int uid , int gid , Template * tmpl )
{
quota_del ( VIRTUALMACHINE , uid , gid , tmpl ) ;
}
2012-06-08 13:45:15 +02:00
2018-09-05 15:14:39 +02:00
/**
* Check VM related usage ( network , image and compute ) from quota counters
* for the given user and group . Quotas are updated if not exceeded .
* @ param uid of the user
* @ param gid of the group
* @ param tmpl template for the vm with usage
* @ param error string
*/
2020-07-02 22:42:10 +02:00
static void vm_check ( int uid , int gid , Template * tmpl , std : : string & error )
2018-09-05 15:14:39 +02:00
{
quota_check ( VIRTUALMACHINE , uid , gid , tmpl , error ) ;
}
2012-06-15 12:28:20 +02:00
/**
* Delete Datastore related usage from quota counters .
* for the given user and group
* @ param uid of the user
* @ param gid of the group
* @ param tmpl template for the image , with usage
*/
2012-06-15 23:33:50 +02:00
static void ds_del ( int uid , int gid , Template * tmpl )
{
quota_del ( DATASTORE , uid , gid , tmpl ) ;
}
2022-12-07 09:39:03 +01:00
/**
* Delete Datastore related usage from quota counters .
* for the given user and group
* @ param uid of the user
* @ param gid of the group
* @ param ds_id datastore ID
* @ param size size of the image
* @ param images number of images
*/
static void ds_del ( int uid , int gid , int ds_id , long long size , int images = 1 )
{
Template img_usage ;
img_usage . add ( " DATASTORE " , ds_id ) ;
img_usage . add ( " SIZE " , size ) ;
img_usage . add ( " IMAGES " , images ) ;
Quotas : : ds_del ( uid , gid , & img_usage ) ;
}
2017-03-30 18:54:58 +02:00
/**
* Delete Datastore related usage from quota counters .
* for the given user and group
* @ param uid of the user
* @ param gid of the group
* @ param tmpl template for the image , with usage
*/
2020-07-02 22:42:10 +02:00
static void ds_del ( int uid , int gid , std : : vector < Template * > tmpls )
2017-03-30 18:54:58 +02:00
{
2020-07-02 22:42:10 +02:00
for ( auto it = tmpls . begin ( ) ; it ! = tmpls . end ( ) ; + + it )
2017-03-30 18:54:58 +02:00
{
quota_del ( DATASTORE , uid , gid , * it ) ;
delete * it ;
}
}
2024-06-03 11:40:24 +02:00
/**
* Delete a set of Datastore usage attributes from quota counters . Each
* quota datastore is associate to a given image . NOTE : The templates
* * ARE FREED * by this function
* @ param ds_quotas a map with image_id and a tmpl with usage attributes
*/
2020-07-02 22:42:10 +02:00
static void ds_del_recreate ( int uid , int gid , std : : vector < Template * > & ds_quotas ) ;
2015-11-12 13:23:58 +01:00
2012-06-15 23:33:50 +02:00
/**
2018-09-05 15:14:39 +02:00
* Delete usage from the given quota counters for the given user and group
2012-06-15 23:33:50 +02:00
* @ param type the quota to work with
* @ param uid of the user
* @ param gid of the group
2023-12-12 16:19:20 +01:00
* @ param tmpl template with quota usage
2012-06-15 23:33:50 +02:00
*/
static void quota_del ( QuotaType type , int uid , int gid , Template * tmpl ) ;
2012-06-08 13:45:15 +02:00
2018-09-05 15:14:39 +02:00
/**
* Delete usage from the given quota counters for the given user and group
* @ param type the quota to work with
* @ param uid of the user
* @ param gid of the group
* @ param tmpl template for the image , with usage
*/
static void quota_check ( QuotaType type , int uid , int gid , Template * tmpl ,
2024-06-03 11:40:24 +02:00
std : : string & error ) ;
2018-09-05 15:14:39 +02:00
2012-11-26 12:48:10 +01:00
protected :
2012-11-30 00:16:52 +01:00
/**
* This is an specialized constructor only for derived Quotas classes .
* It allows to set the defaultness attribute
*/
Quotas ( const char * _ds_xpath ,
const char * _net_xpath ,
const char * _img_xpath ,
const char * _vm_xpath ,
bool is_deafult ) :
2024-06-03 11:40:24 +02:00
datastore_quota ( is_deafult ) ,
network_quota ( is_deafult ) ,
image_quota ( is_deafult ) ,
vm_quota ( is_deafult ) ,
ds_xpath ( _ds_xpath ) ,
net_xpath ( _net_xpath ) ,
img_xpath ( _img_xpath ) ,
vm_xpath ( _vm_xpath ) { } ;
2014-01-15 16:27:50 +01:00
2024-06-03 11:40:24 +02:00
virtual ~ Quotas ( ) { } ;
2014-01-15 16:27:50 +01:00
2012-11-30 00:16:52 +01:00
private :
2012-06-08 13:45:15 +02:00
//--------------------------------------------------------------------------
2012-11-29 23:53:34 +01:00
// Usage Counters and Quotas
2012-06-08 13:45:15 +02:00
//--------------------------------------------------------------------------
/**
2012-11-29 23:53:34 +01:00
* Datastore Quotas
*/
2024-06-03 11:40:24 +02:00
QuotaDatastore datastore_quota ;
2012-06-08 13:45:15 +02:00
/**
2012-11-29 23:53:34 +01:00
* Network Quotas
2012-06-08 13:45:15 +02:00
*/
2024-06-03 11:40:24 +02:00
QuotaNetwork network_quota ;
2012-06-08 13:45:15 +02:00
/**
2012-11-29 23:53:34 +01:00
* Image Quotas
*/
2024-06-03 11:40:24 +02:00
QuotaImage image_quota ;
2012-06-08 13:45:15 +02:00
/**
2012-11-29 23:53:34 +01:00
* Virtual Machine Quotas
*/
2024-06-03 11:40:24 +02:00
QuotaVirtualMachine vm_quota ;
2012-06-08 13:45:15 +02:00
//--------------------------------------------------------------------------
// XPaths
//--------------------------------------------------------------------------
/**
* Path for the datastore quota object
*/
const char * ds_xpath ;
/**
* Path for the network quota object
*/
const char * net_xpath ;
/**
* Path for the image quota object
*/
const char * img_xpath ;
/**
* Path for the vm quota object
*/
const char * vm_xpath ;
} ;
# endif /*QUOTABLE_H_*/