1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-22 22:03:39 +03:00
one/include/RequestManagerAcl.h

115 lines
4.0 KiB
C
Raw Normal View History

2011-06-22 19:22:52 +02:00
/* -------------------------------------------------------------------------- */
2018-01-02 18:27:37 +01:00
/* Copyright 2002-2018, OpenNebula Project, OpenNebula Systems */
2011-06-22 19:22:52 +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_ACL_H
#define REQUEST_MANAGER_ACL_H
#include "Request.h"
#include "Nebula.h"
using namespace std;
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class RequestManagerAcl: public Request
{
protected:
RequestManagerAcl( const string& method_name,
const string& help,
const string& params)
:Request(method_name,params,help)
{
auth_object = PoolObjectSQL::ACL;
auth_op = AuthRequest::MANAGE;
Nebula& nd = Nebula::instance();
aclm = nd.get_aclm();
2011-06-22 19:22:52 +02:00
};
~RequestManagerAcl(){};
/* -------------------------------------------------------------------- */
virtual void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att) = 0;
2011-06-22 19:22:52 +02:00
/* -------------------------------------------------------------------- */
AclManager * aclm;
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class AclAddRule : public RequestManagerAcl
{
public:
AclAddRule():
RequestManagerAcl("one.acl.addrule",
"Adds a new ACL rule",
"A:ssss")
{};
2011-06-22 19:22:52 +02:00
~AclAddRule(){};
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att);
2011-06-22 19:22:52 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class AclDelRule : public RequestManagerAcl
{
public:
AclDelRule():
RequestManagerAcl("one.acl.delrule",
"Deletes an existing ACL rule",
"A:si")
{};
2011-06-22 19:22:52 +02:00
~AclDelRule(){};
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att);
2011-06-22 19:22:52 +02:00
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class AclInfo: public RequestManagerAcl
{
public:
AclInfo():
RequestManagerAcl("one.acl.info",
"Returns the ACL rule set",
"A:s")
{};
2011-06-22 19:22:52 +02:00
~AclInfo(){};
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att);
2011-06-22 19:22:52 +02:00
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
#endif