#ifndef __OUC_ENV__
#define __OUC_ENV__
/******************************************************************************/
/* */
/* X r d O u c E n v . h h */
/* */
/* (c) 2003 by the Board of Trustees of the Leland Stanford, Jr., University */
/* All Rights Reserved */
/* Produced by Andrew Hanushevsky for Stanford University under contract */
/* DE-AC02-76-SFO0515 with the Department of Energy */
/* */
/* This file is part of the XRootD software suite. */
/* */
/* XRootD is free software: you can redistribute it and/or modify it under */
/* the terms of the GNU Lesser General Public License as published by the */
/* Free Software Foundation, either version 3 of the License, or (at your */
/* option) any later version. */
/* */
/* XRootD is distributed in the hope that it will be useful, but WITHOUT */
/* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
/* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public */
/* License for more details. */
/* */
/* You should have received a copy of the GNU Lesser General Public License */
/* along with XRootD in a file called COPYING.LESSER (LGPL license) and file */
/* COPYING (GPL license). If not, see . */
/* */
/* The copyright holder's institutional names and contributor's names may not */
/* be used to endorse or promote products derived from this software without */
/* specific prior written permission of the institution or contributor. */
/******************************************************************************/
#include
#ifndef WIN32
#include
#endif
#include "XrdOuc/XrdOucHash.hh"
class XrdSecEntity;
class XrdOucEnv
{
public:
// Env() returns the full environment string and length passed to the
// constructor.
//
inline char *Env(int &envlen) {envlen = global_len; return global_env;}
// EnvTidy() returns the environment string and length with authorization
// information (ie. authz), if any, removed.
//
char *EnvTidy(int &envlen);
// Export() sets an external environmental variable to the desired value
// using dynamically allocated fixed storage.
//
static int Export(const char *Var, const char *Val);
static int Export(const char *Var, int Val);
// Import() gets a variable from the extended environment and stores
// it in this object
static bool Import( const char *var, char *&val );
static bool Import( const char *var, long &val );
// Get() returns the address of the string associated with the variable
// name. If no association exists, zero is returned.
//
char *Get(const char *varname) {return env_Hash.Find(varname);}
// GetInt() returns a long integer value. If the variable varname is not found
// in the hash table, return -999999999.
//
long GetInt(const char *varname);
// GetPtr() returns a pointer as a (void *) value. If the varname is not found
// a nil pointer is returned (i.e. 0).
//
void *GetPtr(const char *varname);
// Put() associates a string value with the a variable name. If one already
// exists, it is replaced. The passed value and variable strings are
// duplicated (value here, variable by env_Hash).
//
void Put(const char *varname, const char *value)
{env_Hash.Rep((char *)varname, strdup(value), 0, Hash_dofree);}
// PutInt() puts a long integer value into the hash. Internally, the value gets
// converted into a char*
//
void PutInt(const char *varname, long value);
// PutPtr() puts a pointer value into the hash. The pointer is accepted as a
// (void *) value. By convention, the variable name should end with
// an asterisk and typically corresponds to it's class name.
//
void PutPtr(const char *varname, void *value);
// Delimit() search for the first occurrence of comma (',') in value and
// replaces it with a null byte. It then returns the address of the
// remaining string. If no comma was found, it returns zero.
//
char *Delimit(char *value);
// secEnv() returns the security environment; which may be a null pointer.
//
inline const XrdSecEntity *secEnv() const {return secEntity;}
// Use the constructor to define the initial variable settings. The passed
// string is duplicated and the copy can be retrieved using Env().
//
XrdOucEnv(const char *vardata=0, int vardlen=0,
const XrdSecEntity *secent=0);
~XrdOucEnv() {if (global_env) free((void *)global_env);}
private:
void EnvBuildTidy();
XrdOucHash env_Hash;
const XrdSecEntity *secEntity;
char *global_env;
int global_len;
};
#endif