1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-14 19:24:10 +03:00
one/include/RequestManagerAllocate.h

745 lines
25 KiB
C
Raw Normal View History

2011-05-28 04:03:09 +02:00
/* -------------------------------------------------------------------------- */
2019-01-16 11:27:59 +01:00
/* Copyright 2002-2019, OpenNebula Project, OpenNebula Systems */
2011-05-28 04:03:09 +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 REQUEST_MANAGER_ALLOCATE_H_
#define REQUEST_MANAGER_ALLOCATE_H_
#include "Request.h"
#include "Nebula.h"
#include "VirtualNetworkTemplate.h"
#include "ImageTemplate.h"
#include "VirtualMachineTemplate.h"
#include "DatastoreTemplate.h"
2011-05-28 04:03:09 +02:00
using namespace std;
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class RequestManagerAllocate: public Request
{
protected:
RequestManagerAllocate(const string& method_name,
const string& help,
const string& xml_args,
2013-12-12 19:08:59 +01:00
bool _do_template)
:Request(method_name,xml_args,help), do_template(_do_template)
2011-05-28 04:03:09 +02:00
{
auth_op = AuthRequest::CREATE;
Nebula& nd = Nebula::instance();
clpool = nd.get_clpool();
2011-05-28 04:03:09 +02:00
};
~RequestManagerAllocate(){};
/* -------------------------------------------------------------------- */
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att) override;
2011-05-28 04:03:09 +02:00
virtual bool allocate_authorization(xmlrpc_c::paramList const& _paramList,
Template *obj_template, RequestAttributes& att,
PoolObjectAuth *cluster_perms);
2011-05-28 04:03:09 +02:00
/* -------------------------------------------------------------------- */
virtual Template * get_object_template() { return 0; };
virtual Request::ErrorCode pool_allocate(
xmlrpc_c::paramList const& _paramList,
2011-05-28 04:03:09 +02:00
Template * tmpl,
int& id,
RequestAttributes& att)
{
return Request::INTERNAL;
};
virtual Request::ErrorCode pool_allocate(
xmlrpc_c::paramList const& _paramList,
Template * tmpl,
int& id,
RequestAttributes& att,
int cluster_id,
const string& cluster_name)
{
return pool_allocate(_paramList, tmpl, id, att);
};
virtual int get_cluster_id(xmlrpc_c::paramList const& paramList)
{
return ClusterPool::NONE_CLUSTER_ID;
};
2012-12-17 16:54:17 +01:00
virtual int add_to_cluster(
Cluster* cluster,
int id,
string& error_msg)
{
return -1;
};
2012-12-17 16:54:17 +01:00
virtual Datastore::DatastoreType get_ds_type(int oid)
{
return Datastore::FILE_DS;
};
protected:
ClusterPool * clpool;
int get_cluster_id(xmlrpc_c::paramList const& paramList, int cluster_pos)
{
int cid = xmlrpc_c::value_int(paramList.getInt(cluster_pos));
if (cid == -1)
{
cid = ClusterPool::DEFAULT_CLUSTER_ID;
}
return cid;
};
2011-05-28 04:03:09 +02:00
private:
bool do_template;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class VirtualMachineAllocate: public RequestManagerAllocate
{
public:
VirtualMachineAllocate():
RequestManagerAllocate("one.vm.allocate",
"Allocates a new virtual machine",
"A:ssb",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_vmpool();
auth_object = PoolObjectSQL::VM;
};
~VirtualMachineAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new VirtualMachineTemplate;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
bool allocate_authorization(xmlrpc_c::paramList const& paramList,
Template *obj_template, RequestAttributes& att,
PoolObjectAuth *cluster_perms) override;
};
2011-05-28 04:03:09 +02:00
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class VirtualNetworkAllocate: public RequestManagerAllocate
{
public:
VirtualNetworkAllocate():
RequestManagerAllocate("one.vn.allocate",
2011-05-28 04:03:09 +02:00
"Allocates a new virtual network",
"A:ssi",
2011-05-28 04:03:09 +02:00
true)
{
2011-05-28 04:03:09 +02:00
Nebula& nd = Nebula::instance();
pool = nd.get_vnpool();
auth_object = PoolObjectSQL::NET;
2011-05-28 04:03:09 +02:00
};
~VirtualNetworkAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new VirtualNetworkTemplate;
2011-05-28 04:03:09 +02:00
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& _paramList,
2011-05-28 04:03:09 +02:00
Template * tmpl,
int& id,
RequestAttributes& att,
int cluster_id,
const string& cluster_name) override;
int get_cluster_id(xmlrpc_c::paramList const& paramList) override
{
return RequestManagerAllocate::get_cluster_id(paramList, 2);
};
2012-12-17 16:54:17 +01:00
int add_to_cluster(
Cluster* cluster,
int id,
string& error_msg) override
{
return clpool->add_to_cluster(PoolObjectSQL::NET, cluster, id, error_msg);
};
2011-05-28 04:03:09 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class ImageAllocate: public RequestManagerAllocate
{
public:
ImageAllocate():
RequestManagerAllocate("one.image.allocate",
2011-05-28 04:03:09 +02:00
"Allocates a new image",
"A:ssib",
2011-05-28 04:03:09 +02:00
true)
{
2011-05-28 04:03:09 +02:00
Nebula& nd = Nebula::instance();
pool = nd.get_ipool();
auth_object = PoolObjectSQL::IMAGE;
2011-05-28 04:03:09 +02:00
};
~ImageAllocate(){};
/* --------------------------------------------------------------------- */
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att) override;
2011-05-28 04:03:09 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class TemplateAllocate : public RequestManagerAllocate
{
public:
TemplateAllocate():
RequestManagerAllocate("one.template.allocate",
2011-05-28 04:03:09 +02:00
"Allocates a new virtual machine template",
"A:ss",
true)
{
2011-05-28 04:03:09 +02:00
Nebula& nd = Nebula::instance();
pool = nd.get_tpool();
auth_object = PoolObjectSQL::TEMPLATE;
2011-05-28 04:03:09 +02:00
};
~TemplateAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new VirtualMachineTemplate;
2011-05-28 04:03:09 +02:00
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
bool allocate_authorization(xmlrpc_c::paramList const& paramList,
Template *obj_template, RequestAttributes& att,
PoolObjectAuth *cluster_perms) override;
2011-05-28 04:03:09 +02:00
};
class VirtualNetworkTemplateAllocate : public RequestManagerAllocate
{
public:
VirtualNetworkTemplateAllocate():
RequestManagerAllocate("one.vntemplate.allocate",
"Allocates a new virtual network template",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_vntpool();
auth_object = PoolObjectSQL::VNTEMPLATE;
};
~VirtualNetworkTemplateAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new VirtualMachineTemplate;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
bool allocate_authorization(xmlrpc_c::paramList const& paramList,
Template *obj_template, RequestAttributes& att,
PoolObjectAuth *cluster_perms) override;
};
2011-05-28 04:03:09 +02:00
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class HostAllocate : public RequestManagerAllocate
{
public:
HostAllocate():
RequestManagerAllocate("one.host.allocate",
2011-05-28 04:03:09 +02:00
"Allocates a new host",
"A:ssssi",
false)
{
2011-05-28 04:03:09 +02:00
Nebula& nd = Nebula::instance();
pool = nd.get_hpool();
auth_object = PoolObjectSQL::HOST;
2011-05-28 04:03:09 +02:00
};
~HostAllocate(){};
/* --------------------------------------------------------------------- */
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& _paramList,
Template * tmpl,
int& id,
RequestAttributes& att,
int cluster_id,
const string& cluster_name) override;
int get_cluster_id(xmlrpc_c::paramList const& paramList) override
{
return RequestManagerAllocate::get_cluster_id(paramList, 4);
};
2012-12-17 16:54:17 +01:00
int add_to_cluster(
Cluster* cluster,
int id,
string& error_msg) override
{
return clpool->add_to_cluster(PoolObjectSQL::HOST, cluster, id, error_msg);;
};
2011-05-28 04:03:09 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class UserAllocate: public RequestManagerAllocate
{
public:
UserAllocate():
RequestManagerAllocate("one.user.allocate",
2011-05-28 04:03:09 +02:00
"Returns user information",
"A:ssssA",
2011-05-28 04:03:09 +02:00
false)
{
2011-05-28 04:03:09 +02:00
Nebula& nd = Nebula::instance();
pool = nd.get_upool();
gpool = nd.get_gpool();
auth_object = PoolObjectSQL::USER;
hidden_params.insert(2); // password argument
2011-05-28 04:03:09 +02:00
};
~UserAllocate(){};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
bool allocate_authorization(xmlrpc_c::paramList const& paramList,
Template *obj_template, RequestAttributes& att,
PoolObjectAuth *cluster_perms) override;
private:
GroupPool * gpool;
2011-05-28 04:03:09 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class GroupAllocate: public RequestManagerAllocate
{
public:
GroupAllocate():
RequestManagerAllocate("one.group.allocate",
2011-05-28 04:03:09 +02:00
"Allocates a new group",
"A:ss",
false)
{
2011-05-28 04:03:09 +02:00
Nebula& nd = Nebula::instance();
pool = nd.get_gpool();
auth_object = PoolObjectSQL::GROUP;
vdcpool = nd.get_vdcpool();
2011-05-28 04:03:09 +02:00
};
~GroupAllocate(){};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
private:
VdcPool * vdcpool;
2011-05-28 04:03:09 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class DatastoreAllocate: public RequestManagerAllocate
{
public:
DatastoreAllocate():
RequestManagerAllocate("one.datastore.allocate",
"Allocates a new Datastore",
"A:ssi",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_dspool();
auth_object = PoolObjectSQL::DATASTORE;
};
~DatastoreAllocate(){};
/* -------------------------------------------------------------------- */
Template * get_object_template() override
{
return new DatastoreTemplate;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& _paramList,
Template * tmpl,
int& id,
RequestAttributes& att,
int cluster_id,
const string& cluster_name) override;
int get_cluster_id(xmlrpc_c::paramList const& paramList) override
{
return RequestManagerAllocate::get_cluster_id(paramList, 2);
};
2012-12-17 16:54:17 +01:00
int add_to_cluster(
Cluster* cluster,
int id,
string& error_msg) override
{
return clpool->add_to_cluster(PoolObjectSQL::DATASTORE, cluster, id, error_msg);
};
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class ClusterAllocate: public RequestManagerAllocate
{
public:
ClusterAllocate():
RequestManagerAllocate("one.cluster.allocate",
"Allocates a new cluster",
"A:ss",
false)
{
Nebula& nd = Nebula::instance();
pool = nd.get_clpool();
auth_object = PoolObjectSQL::CLUSTER;
};
~ClusterAllocate(){};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class DocumentAllocate : public RequestManagerAllocate
{
public:
DocumentAllocate():
RequestManagerAllocate("one.document.allocate",
"Allocates a new generic document",
"A:ssi",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_docpool();
auth_object = PoolObjectSQL::DOCUMENT;
};
~DocumentAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new Template;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
};
2013-12-12 19:08:59 +01:00
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class ZoneAllocate: public RequestManagerAllocate
{
public:
ZoneAllocate():
RequestManagerAllocate("one.zone.allocate",
2013-12-12 19:08:59 +01:00
"Allocates a new zone",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_zonepool();
auth_object = PoolObjectSQL::ZONE;
};
~ZoneAllocate(){};
/* --------------------------------------------------------------------- */
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att) override;
Template * get_object_template() override
2013-12-12 19:08:59 +01:00
{
return new Template;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
2013-12-12 19:08:59 +01:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class SecurityGroupAllocate : public RequestManagerAllocate
{
public:
SecurityGroupAllocate():
RequestManagerAllocate("one.secgroup.allocate",
"Allocates a new security group",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_secgrouppool();
auth_object = PoolObjectSQL::SECGROUP;
};
~SecurityGroupAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new Template;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att);
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class VdcAllocate : public RequestManagerAllocate
{
public:
VdcAllocate():
RequestManagerAllocate("one.vdc.allocate",
"Allocates a new VDC",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_vdcpool();
auth_object = PoolObjectSQL::VDC;
};
~VdcAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new Template;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class VirtualRouterAllocate : public RequestManagerAllocate
{
public:
VirtualRouterAllocate():
RequestManagerAllocate("one.vrouter.allocate",
"Allocates a new virtual router",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_vrouterpool();
auth_object = PoolObjectSQL::VROUTER;
};
~VirtualRouterAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new Template;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
bool allocate_authorization(xmlrpc_c::paramList const& paramList,
Template *obj_template, RequestAttributes& att,
PoolObjectAuth *cluster_perms) override;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class MarketPlaceAllocate : public RequestManagerAllocate
{
public:
MarketPlaceAllocate():
RequestManagerAllocate("one.market.allocate",
"Allocates a new marketplace",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_marketpool();
auth_object = PoolObjectSQL::MARKETPLACE;
};
~MarketPlaceAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new MarketPlaceTemplate;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& _paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class MarketPlaceAppAllocate : public RequestManagerAllocate
{
public:
MarketPlaceAppAllocate():
RequestManagerAllocate("one.marketapp.allocate",
"Allocates a new marketplace app",
"A:ssi",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_apppool();
mppool = nd.get_marketpool();
auth_object = PoolObjectSQL::MARKETPLACEAPP;
};
~MarketPlaceAppAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new MarketPlaceAppTemplate;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& _paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
private:
MarketPlacePool * mppool;
};
2011-05-28 04:03:09 +02:00
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
class VMGroupAllocate : public RequestManagerAllocate
{
public:
VMGroupAllocate():
RequestManagerAllocate("one.vmgroup.allocate",
"Allocates a new vm group",
"A:ss",
true)
{
Nebula& nd = Nebula::instance();
pool = nd.get_vmgrouppool();
auth_object = PoolObjectSQL::VMGROUP;
};
~VMGroupAllocate(){};
/* --------------------------------------------------------------------- */
Template * get_object_template() override
{
return new Template;
};
Request::ErrorCode pool_allocate(xmlrpc_c::paramList const& paramList,
Template * tmpl,
int& id,
RequestAttributes& att) override;
};
2011-05-28 04:03:09 +02:00
#endif