1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-10 01:17:40 +03:00
one/include/RequestManagerClone.h
Pavel Czerný 3ea67d3645
F #4936: Reduce number of new/delete, use unique_ptr (#212)
* On exit stop RequestManager first

* Use unique_ptr for pointers to Template

* Reduce number of new/delete
2020-09-15 11:16:00 +02:00

265 lines
8.9 KiB
C++

/* -------------------------------------------------------------------------- */
/* Copyright 2002-2020, OpenNebula Project, OpenNebula Systems */
/* */
/* 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_CLONE_H
#define REQUEST_MANAGER_CLONE_H
#include "Request.h"
#include "RequestManagerVMTemplate.h"
#include "Nebula.h"
#include "DocumentPool.h"
#include "SecurityGroupPool.h"
#include "VNTemplatePool.h"
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class RequestManagerClone: public Request
{
protected:
RequestManagerClone(const std::string& method_name, const std::string& help,
const std::string& params = "A:sis"):
Request(method_name,params,help){};
~RequestManagerClone(){};
/* -------------------------------------------------------------------- */
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att) override;
/* -------------------------------------------------------------------- */
/* Especialization Functions for specific Clone actions */
/* -------------------------------------------------------------------- */
/**
* Function to clone the object
*/
virtual ErrorCode clone(int source_id, const std::string &name, int &new_id,
bool recursive, const std::string& s_uattr, RequestAttributes& att);
/**
* Function to clone the base template
*/
virtual std::unique_ptr<Template> clone_template(PoolObjectSQL* obj) = 0;
/**
* Function to merge user/additional attributes in the cloned object
*/
virtual ErrorCode merge(Template * tmpl, const std::string &str_uattrs,
RequestAttributes& att)
{
return SUCCESS;
}
/**
* Function to allocated the new clone object
*/
virtual int pool_allocate(int source_id, std::unique_ptr<Template> tmpl,
int& id, RequestAttributes& att) = 0;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class VMTemplateClone : public RequestManagerClone
{
public:
VMTemplateClone():
RequestManagerClone("one.template.clone",
"Clone a virtual machine template", "A:sisb")
{
Nebula& nd = Nebula::instance();
pool = nd.get_tpool();
auth_object = PoolObjectSQL::TEMPLATE;
auth_op = AuthRequest::USE;
};
~VMTemplateClone(){};
ErrorCode request_execute(int source_id, const std::string &name,
int &new_id, bool recursive,
const std::string& s_uattrs,
RequestAttributes& att)
{
return clone(source_id, name, new_id, recursive, s_uattrs, att);
};
protected:
ErrorCode clone(int source_id, const std::string &name, int &new_id,
bool recursive, const std::string& s_a,
RequestAttributes& att) override;
std::unique_ptr<Template> clone_template(PoolObjectSQL* obj) override
{
return static_cast<VMTemplate*>(obj)->clone_template();
}
int pool_allocate(int sid, std::unique_ptr<Template> tmpl, int& id,
RequestAttributes& att) override
{
VMTemplatePool * tpool = static_cast<VMTemplatePool *>(pool);
std::unique_ptr<VirtualMachineTemplate> t(
static_cast<VirtualMachineTemplate*>(tmpl.release()));
return tpool->allocate(att.uid, att.gid, att.uname, att.gname, att.umask,
std::move(t), &id, att.resp_msg);
}
ErrorCode merge(Template * tmpl, const std::string &s_a,
RequestAttributes& att) override
{
VMTemplateInstantiate vm_instantiate;
return vm_instantiate.merge(tmpl, s_a, att);
};
static const std::vector<const char*> REMOVE_DISK_ATTRS;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class VNTemplateClone : public RequestManagerClone
{
public:
VNTemplateClone():
RequestManagerClone("one.vntemplate.clone",
"Clone a virtual network template", "A:sis")
{
Nebula& nd = Nebula::instance();
pool = nd.get_vntpool();
auth_object = PoolObjectSQL::VNTEMPLATE;
auth_op = AuthRequest::USE;
};
~VNTemplateClone(){};
ErrorCode request_execute(int source_id, const std::string &name,
int &new_id, const std::string& s_uattrs,
RequestAttributes& att)
{
return clone(source_id, name, new_id, false, s_uattrs, att);
};
protected:
std::unique_ptr<Template> clone_template(PoolObjectSQL* obj) override
{
return static_cast<VNTemplate*>(obj)->clone_template();
}
int pool_allocate(int sid, std::unique_ptr<Template> tmpl,
int& id, RequestAttributes& att) override
{
VNTemplatePool * tpool = static_cast<VNTemplatePool *>(pool);
std::unique_ptr<VirtualNetworkTemplate> t(
static_cast<VirtualNetworkTemplate*>(tmpl.release()));
return tpool->allocate(att.uid, att.gid, att.uname, att.gname, att.umask,
std::move(t), &id, att.resp_msg);
}
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class DocumentClone : public RequestManagerClone
{
public:
DocumentClone():
RequestManagerClone("one.document.clone", "Clone existing document")
{
Nebula& nd = Nebula::instance();
pool = nd.get_docpool();
auth_object = PoolObjectSQL::DOCUMENT;
auth_op = AuthRequest::USE;
};
~DocumentClone(){};
protected:
std::unique_ptr<Template> clone_template(PoolObjectSQL* obj) override
{
return static_cast<Document*>(obj)->clone_template();
}
int pool_allocate(int sid, std::unique_ptr<Template> tmpl,
int& id, RequestAttributes& att) override
{
DocumentPool * docpool = static_cast<DocumentPool *>(pool);
auto doc = docpool->get_ro(sid);
if (!doc)
{
return -1;
}
int dtype = doc->get_document_type();
return docpool->allocate(att.uid, att.gid, att.uname, att.gname,
att.umask, dtype, std::move(tmpl), &id, att.resp_msg);
}
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class SecurityGroupClone : public RequestManagerClone
{
public:
SecurityGroupClone():
RequestManagerClone("one.secgroup.clone", "Clone a security group")
{
Nebula& nd = Nebula::instance();
pool = nd.get_secgrouppool();
auth_object = PoolObjectSQL::SECGROUP;
auth_op = AuthRequest::USE;
};
~SecurityGroupClone(){};
protected:
std::unique_ptr<Template> clone_template(PoolObjectSQL* obj) override
{
return static_cast<SecurityGroup*>(obj)->clone_template();
}
int pool_allocate(int sid, std::unique_ptr<Template> tmpl,
int& id, RequestAttributes& att) override
{
SecurityGroupPool * sg = static_cast<SecurityGroupPool *>(pool);
return sg->allocate(att.uid, att.gid, att.uname, att.gname, att.umask,
std::move(tmpl), &id, att.resp_msg);
}
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
#endif