2011-05-24 14:32:39 +02:00
/* -------------------------------------------------------------------------- */
2021-02-09 16:07:56 +01:00
/* Copyright 2002-2021, OpenNebula Project, OpenNebula Systems */
2011-05-24 14:32:39 +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_H_
# define REQUEST_H_
# include <xmlrpc-c/base.hpp>
# include <xmlrpc-c/registry.hpp>
# include "RequestManager.h"
2012-05-31 16:51:07 +02:00
# include "AuthRequest.h"
2012-01-03 02:58:23 +01:00
# include "PoolObjectSQL.h"
2012-06-15 23:33:50 +02:00
# include "Quotas.h"
2019-12-10 11:45:15 +01:00
# include "UserPool.h"
2011-05-24 14:32:39 +02:00
2016-01-30 13:55:13 +01:00
/**
* This class represents the dynamic attributes : specific for a request of the
* same method .
*/
struct RequestAttributes
{
public :
int uid ; /**< id of the user */
int gid ; /**< id of the user's group */
2020-07-02 22:42:10 +02:00
std : : string uname ; /**< name of the user */
std : : string gname ; /**< name of the user's group */
2016-01-30 13:55:13 +01:00
2020-07-02 22:42:10 +02:00
std : : string password ; /**< password of the user */
2016-01-30 13:55:13 +01:00
2020-07-02 22:42:10 +02:00
std : : set < int > group_ids ; /**< set of user's group ids */
2016-01-30 13:55:13 +01:00
2020-07-02 22:42:10 +02:00
std : : string session ; /**< Session from ONE XML-RPC API */
2016-01-30 13:55:13 +01:00
int req_id ; /**< Request ID for log messages */
int umask ; /**< User umask for new objects */
xmlrpc_c : : value * retval ; /**< Return value from libxmlrpc-c */
2020-07-02 22:42:10 +02:00
std : : string retval_xml ; /**< Return value in XML format */
std : : string extra_xml ; /**< Extra information returned for API Hooks */
2016-01-30 13:55:13 +01:00
PoolObjectSQL : : ObjectType resp_obj ; /**< object type */
int resp_id ; /**< Id of the object */
2020-07-02 22:42:10 +02:00
std : : string resp_msg ; /**< Additional response message */
2016-01-30 13:55:13 +01:00
2019-04-08 17:43:12 +02:00
uint64_t replication_idx ;
2019-09-09 13:13:52 +02:00
AuthRequest : : Operation auth_op ; /**< Auth operation for the request */
2019-09-09 14:43:51 +02:00
bool success ; /**< True if the call was successfull false otherwise */
2019-09-09 13:13:52 +02:00
RequestAttributes ( AuthRequest : : Operation api_auth_op )
2016-02-08 12:32:27 +01:00
{
2019-04-08 17:43:12 +02:00
resp_obj = PoolObjectSQL : : NONE ;
resp_id = - 1 ;
resp_msg = " " ;
replication_idx = UINT64_MAX ;
2019-09-09 13:13:52 +02:00
auth_op = api_auth_op ;
2016-02-08 12:32:27 +01:00
} ;
2016-01-30 13:55:13 +01:00
RequestAttributes ( const RequestAttributes & ra )
{
uid = ra . uid ;
gid = ra . gid ;
uname = ra . uname ;
gname = ra . gname ;
password = ra . password ;
2016-04-21 10:48:14 +02:00
group_ids = ra . group_ids ;
2016-01-30 13:55:13 +01:00
session = ra . session ;
2016-04-21 10:48:14 +02:00
req_id = ra . req_id ;
2016-01-30 13:55:13 +01:00
2016-04-21 10:48:14 +02:00
umask = ra . umask ;
2019-09-09 14:43:51 +02:00
retval = ra . retval ;
retval_xml = ra . retval_xml ;
2016-01-30 13:55:13 +01:00
resp_obj = ra . resp_obj ;
resp_id = ra . resp_id ;
resp_msg = ra . resp_msg ;
2019-04-08 17:43:12 +02:00
replication_idx = ra . replication_idx ;
2019-09-09 13:13:52 +02:00
auth_op = ra . auth_op ;
2016-01-30 13:55:13 +01:00
} ;
RequestAttributes ( int _uid , int _gid , const RequestAttributes & ra )
{
uid = _uid ;
gid = _gid ;
password = " " ;
2016-04-21 10:48:14 +02:00
group_ids = ra . group_ids ;
2016-01-30 13:55:13 +01:00
uname = " " ;
gname = " " ;
umask = 0 ;
session = ra . session ;
2016-04-21 10:48:14 +02:00
req_id = ra . req_id ;
umask = ra . umask ;
2019-09-09 14:43:51 +02:00
retval = ra . retval ;
retval_xml = ra . retval_xml ;
2016-01-30 13:55:13 +01:00
resp_obj = PoolObjectSQL : : NONE ;
resp_id = - 1 ;
resp_msg = " " ;
2019-04-08 17:43:12 +02:00
replication_idx = UINT64_MAX ;
2019-09-09 13:13:52 +02:00
auth_op = ra . auth_op ;
2016-01-30 13:55:13 +01:00
} ;
2018-05-23 14:42:57 +02:00
2018-05-23 14:50:15 +02:00
bool is_admin ( ) const
2018-05-23 14:42:57 +02:00
{
return uid = = UserPool : : ONEADMIN_ID | |
group_ids . count ( GroupPool : : ONEADMIN_ID ) = = 1 ;
}
2018-05-23 14:50:15 +02:00
bool is_oneadmin ( ) const
2018-05-23 14:42:57 +02:00
{
return uid = = UserPool : : ONEADMIN_ID ;
}
2018-05-23 14:50:15 +02:00
bool is_oneadmin_group ( ) const
2018-05-23 14:42:57 +02:00
{
return gid = = GroupPool : : ONEADMIN_ID ;
}
2019-09-09 13:13:52 +02:00
/**
* Set the operation level ( admin , manage or use ) associated to this
* request . Precedence is : user > group > system .
*
* @ param action perfomed on the VM object
*/
void set_auth_op ( VMActions : : Action action ) ;
2016-01-30 13:55:13 +01:00
} ;
2019-09-09 14:43:51 +02:00
class ParamList
{
public :
2020-07-02 22:42:10 +02:00
ParamList ( const xmlrpc_c : : paramList * paramList ,
const std : : set < int > & hidden ) :
2019-09-10 18:17:12 +02:00
_paramList ( paramList ) , _hidden ( hidden ) { } ;
2019-09-09 14:43:51 +02:00
2020-07-02 22:42:10 +02:00
std : : string & to_string ( std : : string & str ) const
2019-09-09 14:43:51 +02:00
{
2020-07-02 22:42:10 +02:00
std : : ostringstream oss ;
2019-09-09 14:43:51 +02:00
oss < < get_value_as_string ( 0 ) ;
for ( unsigned int i = 1 ; i < _paramList - > size ( ) ; i + + )
{
oss < < " " < < get_value_as_string ( i ) ;
}
str = oss . str ( ) ;
return str ;
} ;
2020-07-02 22:42:10 +02:00
std : : string get_value_as_string ( int index ) const
2019-09-09 14:43:51 +02:00
{
2019-09-10 18:17:12 +02:00
if ( index = = 0 | | _hidden . count ( index ) = = 1 )
{
return " **** " ;
}
2020-07-02 22:42:10 +02:00
std : : ostringstream oss ;
2019-09-09 14:43:51 +02:00
xmlrpc_c : : value : : type_t type ( ( * _paramList ) [ index ] . type ( ) ) ;
if ( type = = xmlrpc_c : : value : : TYPE_INT )
{
oss < < _paramList - > getInt ( index ) ;
return oss . str ( ) ;
}
else if ( type = = xmlrpc_c : : value : : TYPE_I8 )
{
oss < < _paramList - > getI8 ( index ) ;
return oss . str ( ) ;
}
else if ( type = = xmlrpc_c : : value : : TYPE_BOOLEAN )
{
oss < < _paramList - > getBoolean ( index ) ;
return oss . str ( ) ;
}
else if ( type = = xmlrpc_c : : value : : TYPE_STRING )
{
oss < < _paramList - > getString ( index ) ;
return oss . str ( ) ;
}
else if ( type = = xmlrpc_c : : value : : TYPE_DOUBLE )
{
oss < < _paramList - > getDouble ( index ) ;
return oss . str ( ) ;
}
return oss . str ( ) ;
} ;
int size ( ) const
{
return _paramList - > size ( ) ;
} ;
private :
const xmlrpc_c : : paramList * _paramList ;
2019-09-10 18:17:12 +02:00
2020-07-02 22:42:10 +02:00
const std : : set < int > & _hidden ;
2019-09-09 14:43:51 +02:00
} ;
2011-05-24 15:23:07 +02:00
/**
* The Request Class represents the basic abstraction for the OpenNebula
* XML - RPC API . This interface must be implemented by any XML - RPC API call
*/
2018-07-31 10:51:16 +02:00
class Request : public xmlrpc_c : : method2
2011-05-24 14:32:39 +02:00
{
public :
2011-05-24 15:23:07 +02:00
/**
* Error codes for the XML - RPC API
*/
enum ErrorCode {
2019-04-08 17:43:12 +02:00
SUCCESS = 0x00000 ,
AUTHENTICATION = 0x00100 ,
AUTHORIZATION = 0x00200 ,
NO_EXISTS = 0x00400 ,
ACTION = 0x00800 ,
XML_RPC_API = 0x01000 ,
INTERNAL = 0x02000 ,
ALLOCATE = 0x04000 ,
LOCKED = 0x08000 ,
REPLICATION = 0x10000
2011-05-24 15:23:07 +02:00
} ;
2016-01-30 13:55:13 +01:00
/**
* Gets a string representation for the Auth object in the
* request .
* @ param ob object for the auth operation
* @ return string equivalent of the object
*/
2020-07-02 22:42:10 +02:00
static std : : string object_name ( PoolObjectSQL : : ObjectType ob ) ;
2016-01-30 13:55:13 +01:00
2014-10-28 18:52:48 +01:00
/**
* Sets the format string to log xml - rpc method calls . The format string
* interprets the following sequences :
* % i - - request id
* % m - - method name
* % u - - user id
* % U - - user name
* % l - - param list
* % p - - user password
* % g - - group id
* % G - - group name
* % a - - auth token
2018-07-31 10:51:16 +02:00
* % A - - client IP address ( only IPv4 )
* % a - - client port ( only IPv4 )
2014-10-28 18:52:48 +01:00
* % % - - %
*/
2020-07-02 22:42:10 +02:00
static void set_call_log_format ( const std : : string & log_format )
2014-10-28 18:52:48 +01:00
{
format_str = log_format ;
}
2011-05-24 14:32:39 +02:00
protected :
2016-01-30 13:55:13 +01:00
/* ---------------------------------------------------------------------- */
2019-09-09 13:13:52 +02:00
/* Global configuration attributes por API calls */
2016-01-30 13:55:13 +01:00
/* ---------------------------------------------------------------------- */
2020-07-02 22:42:10 +02:00
static std : : string format_str ;
2019-09-09 13:13:52 +02:00
static const long long xmlrpc_timeout ; //Timeout (ms) for request forwarding
2011-05-26 00:59:50 +02:00
2019-09-09 13:13:52 +02:00
/* ---------------------------------------------------------------------- */
/* Static Request Attributes: shared among request of the same method */
/* ---------------------------------------------------------------------- */
2020-07-02 22:42:10 +02:00
PoolSQL * pool ;
std : : string method_name ;
2014-10-28 16:23:09 +01:00
2019-09-09 13:13:52 +02:00
// Configuration for authentication level of the API call
2020-07-02 22:52:05 +02:00
PoolObjectSQL : : ObjectType auth_object = PoolObjectSQL : : ObjectType : : NONE ;
2019-09-09 13:13:52 +02:00
AuthRequest : : Operation auth_op ;
2014-10-28 18:52:48 +01:00
2019-09-09 13:13:52 +02:00
VMActions : : Action vm_action ;
2017-05-07 21:52:34 +02:00
2019-09-09 13:13:52 +02:00
// Logging configuration fot the API call
2020-07-02 22:42:10 +02:00
std : : set < int > hidden_params ;
bool log_method_call ;
2017-05-08 10:47:42 +02:00
2021-04-20 13:40:44 +02:00
// Method can be only execute by leaders or solo servers
2019-09-09 13:13:52 +02:00
bool leader_only ;
2017-05-08 19:48:41 +02:00
2021-04-20 13:40:44 +02:00
// Method can be executed in disabled state
bool zone_disabled ;
2016-01-30 13:55:13 +01:00
/* ---------------------------------------------------------------------- */
/* Class Constructors */
/* ---------------------------------------------------------------------- */
2020-07-02 22:42:10 +02:00
Request ( const std : : string & mn ,
const std : : string & signature ,
const std : : string & help )
2011-05-24 14:32:39 +02:00
{
2019-09-09 13:13:52 +02:00
pool = nullptr ;
method_name = mn ;
2011-05-24 14:32:39 +02:00
_signature = signature ;
_help = help ;
2014-10-28 16:23:09 +01:00
hidden_params . clear ( ) ;
2017-05-07 21:52:34 +02:00
log_method_call = true ;
2017-05-08 10:47:42 +02:00
leader_only = true ;
2021-04-20 13:40:44 +02:00
zone_disabled = false ;
2019-09-09 13:13:52 +02:00
vm_action = VMActions : : NONE_ACTION ;
2011-05-24 14:32:39 +02:00
} ;
2019-09-03 16:31:51 +02:00
virtual ~ Request ( ) = default ;
2011-05-24 14:32:39 +02:00
2016-01-30 13:55:13 +01:00
/* ---------------------------------------------------------------------- */
/* Methods to execute the request when received at the server */
/* ---------------------------------------------------------------------- */
/**
* Wraps the actual execution function by authorizing the user
* and calling the request_execute virtual function
* @ param _paramlist list of XML parameters
* @ param _retval value to be returned to the client
*/
2019-07-05 17:23:21 +02:00
void execute ( xmlrpc_c : : paramList const & _paramList ,
const xmlrpc_c : : callInfo * _callInfoP , xmlrpc_c : : value * const _retval ) override ;
2011-05-26 00:59:50 +02:00
/**
2016-01-27 13:29:30 +01:00
* Actual Execution method for the request . Must be implemented by the
* XML - RPC requests
* @ param _paramlist of the XML - RPC call ( complete list )
2011-07-07 12:45:13 +02:00
* @ param att the specific request attributes
2011-05-26 00:59:50 +02:00
*/
2016-01-27 13:29:30 +01:00
virtual void request_execute ( xmlrpc_c : : paramList const & _paramList ,
RequestAttributes & att ) = 0 ;
2011-07-01 17:33:37 +02:00
/**
2016-01-27 13:29:30 +01:00
* Locks the requested object , gets information , and unlocks it
2011-07-01 17:33:37 +02:00
*
2016-01-27 13:29:30 +01:00
* @ param pool object pool
* @ param id of the object
* @ param type of the object
* @ param att the specific request attributes
2012-06-28 13:21:19 +02:00
*
2016-01-27 13:29:30 +01:00
* @ param perms returns the object ' s permissions
* @ param name returns the object ' s name
* @ param throw_error send error response to client if object not found
2012-05-30 02:20:16 +02:00
*
2016-01-27 13:29:30 +01:00
* @ return 0 on success , - 1 otherwise
2012-05-30 02:20:16 +02:00
*/
2016-01-30 13:55:13 +01:00
int get_info ( PoolSQL * pool ,
int id ,
PoolObjectSQL : : ObjectType type ,
RequestAttributes & att ,
PoolObjectAuth & perms ,
2020-07-02 22:42:10 +02:00
std : : string & name ,
2016-01-30 13:55:13 +01:00
bool throw_error ) ;
/* ---------------------------------------------------------------------- */
/* Methods to send response to xml-rpc client */
/* ---------------------------------------------------------------------- */
2011-05-24 14:32:39 +02:00
/**
* Builds an XML - RPC response updating retval . After calling this function
* the xml - rpc excute method should return
* @ param val to be returned to the client
2011-07-07 12:45:13 +02:00
* @ param att the specific request attributes
2011-05-24 14:32:39 +02:00
*/
2011-07-07 12:45:13 +02:00
void success_response ( int val , RequestAttributes & att ) ;
2011-05-24 14:32:39 +02:00
/**
* Builds an XML - RPC response updating retval . After calling this function
* the xml - rpc excute method should return
* @ param val string to be returned to the client
2011-07-07 12:45:13 +02:00
* @ param att the specific request attributes
2011-05-24 14:32:39 +02:00
*/
2020-07-02 22:42:10 +02:00
void success_response ( const std : : string & val , RequestAttributes & att ) ;
2011-05-24 14:32:39 +02:00
2015-05-12 12:48:59 +02:00
/**
* Builds an XML - RPC response updating retval . After calling this function
* the xml - rpc execute method should return
* @ param val to be returned to the client
* @ param att the specific request attributes
*/
void success_response ( bool val , RequestAttributes & att ) ;
2019-04-08 17:43:12 +02:00
/**
* Builds an XML - RPC response updating retval . After calling this function
* the xml - rpc excute method should return
* @ param val to be returned to the client
* @ param att the specific request attributes
*/
void success_response ( uint64_t val , RequestAttributes & att ) ;
2011-05-24 14:32:39 +02:00
/**
* Builds an XML - RPC response updating retval . After calling this function
2016-01-30 13:55:13 +01:00
* the xml - rpc excute method should return . A descriptive error message
* is constructed using att . resp_obj , att . resp_id and / or att . resp_msg and
* the ErrorCode
2011-05-24 14:32:39 +02:00
* @ param ec error code for this call
2016-01-30 13:55:13 +01:00
* @ param ra the specific request attributes
2011-05-24 14:32:39 +02:00
*/
2016-01-30 13:55:13 +01:00
void failure_response ( ErrorCode ec , RequestAttributes & ra ) ;
2016-01-27 13:29:30 +01:00
2016-02-08 16:40:38 +01:00
/**
* Builds an error response . A descriptive error message
* is constructed using att . resp_obj , att . resp_id and / or att . resp_msg and
* the ErrorCode
* @ param ec error code for this call
* @ param att the specific request attributes
*/
2020-07-02 22:42:10 +02:00
std : : string failure_message ( ErrorCode ec , RequestAttributes & att ) ;
2016-02-08 16:40:38 +01:00
2016-01-30 13:55:13 +01:00
/* ---------------------------------------------------------------------- */
/* Authorization methods for requests */
/* ---------------------------------------------------------------------- */
2012-02-28 17:59:03 +01:00
/**
2016-01-27 13:29:30 +01:00
* Performs a basic authorization for this request using the uid / gid
* from the request . The function gets the object from the pool to get
* the public attribute and its owner . The authorization is based on
* object and type of operation for the request .
* @ param oid of the object , can be - 1 for objects to be created , or
* pools .
* @ param att the specific request attributes
2012-02-28 17:59:03 +01:00
*
2016-01-27 13:29:30 +01:00
* @ return true if the user is authorized .
2012-02-28 17:59:03 +01:00
*/
2019-09-09 13:13:52 +02:00
bool basic_authorization ( int oid , RequestAttributes & att ) ;
2012-10-02 16:25:57 +02:00
2016-04-11 12:25:02 +02:00
/**
* Performs a basic authorization for this request using the uid / gid
* from the request . The function gets the object from the pool to get
* the public attribute and its owner . The authorization is based on
* object and type of operation for the request .
* @ param pool object pool
* @ param oid of the object , can be - 1 for objects to be created , or
* pools .
* @ param att the specific request attributes
*
* @ return SUCCESS if the user is authorized .
*/
static ErrorCode basic_authorization (
PoolSQL * pool ,
int oid ,
PoolObjectSQL : : ObjectType auth_object ,
RequestAttributes & att ) ;
2012-10-02 16:25:57 +02:00
/**
2016-01-27 13:29:30 +01:00
* Performs a basic quota check for this request using the uid / gid
* from the request . Usage counters are updated for the user / group .
* On case of error , the failure_response return values are set
2012-10-02 16:25:57 +02:00
*
2016-01-27 13:29:30 +01:00
* @ param tmpl describing the object
* @ param object type of the object
* @ param att the specific request attributes
*
* @ return true if the user is authorized .
2012-10-02 16:25:57 +02:00
*/
2016-01-30 13:55:13 +01:00
bool quota_authorization ( Template * tmpl , Quotas : : QuotaType qtype ,
RequestAttributes & att ) ;
2012-06-08 22:14:40 +02:00
2014-10-28 17:40:30 +01:00
/**
2016-01-27 13:29:30 +01:00
* Performs a basic quota check for this request using the uid / gid
* from the request . Usage counters are updated for the user / group .
* On case of error , the failure_response return values is not set , instead
* the error reason is returned in error_str
2014-10-28 17:40:30 +01:00
*
2016-01-27 13:29:30 +01:00
* @ param tmpl describing the object
* @ param object type of the object
* @ param att the specific request attributes
*
* @ param error_str Error reason , if any
* @ return true if the user is authorized .
2014-10-28 17:40:30 +01:00
*/
2016-01-30 13:55:13 +01:00
static bool quota_authorization ( Template * tmpl , Quotas : : QuotaType qtype ,
2020-07-02 22:42:10 +02:00
RequestAttributes & att , std : : string & error_str ) ;
2012-06-08 22:14:40 +02:00
2016-01-27 13:29:30 +01:00
/**
* Performs rollback on usage counters for a previous quota check operation
* for the request .
* @ param tmpl describing the object
* @ param att the specific request attributes
*/
2016-01-30 13:55:13 +01:00
static void quota_rollback ( Template * tmpl , Quotas : : QuotaType qtype ,
RequestAttributes & att ) ;
2018-04-04 14:49:44 +02:00
/**
* @ param tmpl describing the object
* @ param att the specific request attributes
*/
ErrorCode as_uid_gid ( Template * tmpl , RequestAttributes & att ) ;
2016-01-30 13:55:13 +01:00
private :
/* ---------------------------------------------------------------------- */
/* Functions to manage user and group quotas */
/* ---------------------------------------------------------------------- */
static bool user_quota_authorization ( Template * tmpl , Quotas : : QuotaType qtype ,
2020-07-02 22:42:10 +02:00
RequestAttributes & att , std : : string & error_str ) ;
2016-01-30 13:55:13 +01:00
static bool group_quota_authorization ( Template * tmpl , Quotas : : QuotaType qtype ,
2020-07-02 22:42:10 +02:00
RequestAttributes & att , std : : string & error_str ) ;
2016-01-30 13:55:13 +01:00
static void user_quota_rollback ( Template * tmpl , Quotas : : QuotaType qtype ,
RequestAttributes & att ) ;
2012-06-08 22:14:40 +02:00
2016-01-30 13:55:13 +01:00
static void group_quota_rollback ( Template * tmpl , Quotas : : QuotaType qtype ,
RequestAttributes & att ) ;
/**
* Builds an XML - RPC response updating retval . After calling this function
* the xml - rpc excute method should return
* @ param ec error code for this call
* @ param va string representation of the error
* @ param ra the specific request attributes
*/
2020-07-05 22:01:32 +02:00
void failure_response ( ErrorCode ec , const std : : string & va , RequestAttributes & ra ) const ;
2016-01-30 13:55:13 +01:00
/**
* Logs the method invocation , including the arguments
* @ param att the specific request attributes
* @ param paramList list of XML parameters
* @ param format_str for the log
* @ param hidden_params params not to be shown
2018-07-31 10:51:16 +02:00
* @ param callInfoP information of client
2016-01-30 13:55:13 +01:00
*/
static void log_method_invoked ( const RequestAttributes & att ,
2020-07-02 22:42:10 +02:00
const xmlrpc_c : : paramList & paramList , const std : : string & format_str ,
2018-07-31 10:51:16 +02:00
const std : : string & method_name , const std : : set < int > & hidden_params ,
const xmlrpc_c : : callInfo * callInfoP ) ;
2016-01-30 13:55:13 +01:00
/**
* Logs the method result , including the output data or error message
*
* @ param att the specific request attributes
* @ param method_name that produced the error
*/
static void log_result ( const RequestAttributes & att ,
const std : : string & method_name ) ;
/**
* Formats and adds a xmlrpc_c : : value to oss .
*
* @ param v value to format
* @ param oss stream to write v
2018-07-31 10:51:16 +02:00
* @ param limit of characters to wirte
2016-01-30 13:55:13 +01:00
*/
2018-07-31 10:51:16 +02:00
static void log_xmlrpc_value ( const xmlrpc_c : : value & v ,
std : : ostringstream & oss , const int limit ) ;
2018-03-23 10:23:16 +01:00
// Default number of character to show in the log. Option %l<number>
const static int DEFAULT_LOG_LIMIT = 20 ;
2011-05-24 14:32:39 +02:00
} ;
2011-05-26 00:59:50 +02:00
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
2011-05-24 14:32:39 +02:00
# endif //REQUEST_H_