1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-11 05:17:41 +03:00
one/include/RequestManagerUser.h
Carlos Martín cf45afe0a7 Feature #1108: Add more verbosity to Request Manager log messages:
* Each request message includes a unique (ish) ID, and user doing the request
 * Success results are also logged
 * All arguments are included in the request message (except session)
 * Password arguments are shown as ***
2012-10-02 16:25:57 +02:00

136 lines
4.8 KiB
C++

/* -------------------------------------------------------------------------- */
/* Copyright 2002-2012, OpenNebula Project Leads (OpenNebula.org) */
/* */
/* 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_USER_H
#define REQUEST_MANAGER_USER_H
#include "Request.h"
#include "Nebula.h"
using namespace std;
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class RequestManagerUser: public Request
{
protected:
RequestManagerUser(const string& method_name,
const string& help,
const string& params)
:Request(method_name,params,help)
{
Nebula& nd = Nebula::instance();
pool = nd.get_upool();
auth_object = PoolObjectSQL::USER;
};
~RequestManagerUser(){};
/* -------------------------------------------------------------------- */
void request_execute(xmlrpc_c::paramList const& _paramList,
RequestAttributes& att);
virtual int user_action(int user_id,
xmlrpc_c::paramList const& _paramList,
string& error_str ) = 0;
/* -------------------------------------------------------------------- */
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class UserChangePassword : public RequestManagerUser
{
public:
UserChangePassword():
RequestManagerUser("UserChangePassword",
"Changes user's password",
"A:sis")
{
auth_op = AuthRequest::MANAGE;
};
~UserChangePassword(){};
int user_action(int user_id,
xmlrpc_c::paramList const& _paramList,
string& err);
void log_xmlrpc_param(
const xmlrpc_c::value& v,
ostringstream& oss,
const int& index);
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class UserChangeAuth: public RequestManagerUser
{
public:
UserChangeAuth():
RequestManagerUser("UserChangeAuth",
"Changes user's authentication driver",
"A:siss")
{
auth_op = AuthRequest::ADMIN;
};
~UserChangeAuth(){};
int user_action(int user_id,
xmlrpc_c::paramList const& _paramList,
string& err);
void log_xmlrpc_param(
const xmlrpc_c::value& v,
ostringstream& oss,
const int& index);
};
/* ------------------------------------------------------------------------- */
/* ------------------------------------------------------------------------- */
class UserSetQuota : public RequestManagerUser
{
public:
UserSetQuota():
RequestManagerUser("UserSetQuota",
"Sets user quota limits",
"A:sis")
{
auth_op = AuthRequest::ADMIN;
};
~UserSetQuota(){};
int user_action(int user_id,
xmlrpc_c::paramList const& _paramList,
string& err);
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
#endif