version 1.123, 2006/08/09 21:12:42
|
version 1.124, 2009/01/30 18:18:33
|
|
|
//%2006//////////////////////////////////////////////////////////////////////// |
//%LICENSE//////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// Licensed to The Open Group (TOG) under one or more contributor license |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
// agreements. Refer to the OpenPegasusNOTICE.txt file distributed with |
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; |
// this work for additional information regarding copyright ownership. |
// IBM Corp.; EMC Corporation, The Open Group. |
// Each contributor licenses this file to you under the OpenPegasus Open |
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; |
// Source License; you may not use this file except in compliance with the |
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
// License. |
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
// |
// EMC Corporation; VERITAS Software Corporation; The Open Group. |
// Permission is hereby granted, free of charge, to any person obtaining a |
// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
// copy of this software and associated documentation files (the "Software"), |
// EMC Corporation; Symantec Corporation; The Open Group. |
// to deal in the Software without restriction, including without limitation |
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense, |
|
// and/or sell copies of the Software, and to permit persons to whom the |
|
// Software is furnished to do so, subject to the following conditions: |
|
// |
|
// The above copyright notice and this permission notice shall be included |
|
// in all copies or substantial portions of the Software. |
|
// |
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
|
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
|
// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
|
// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
|
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy |
////////////////////////////////////////////////////////////////////////// |
// of this software and associated documentation files (the "Software"), to |
|
// deal in the Software without restriction, including without limitation the |
|
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
|
// sell copies of the Software, and to permit persons to whom the Software is |
|
// furnished to do so, subject to the following conditions: |
|
// |
|
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
|
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
|
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
|
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
|
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
|
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
|
// |
|
//============================================================================== |
|
// |
|
// Author: Mike Brasher (mbrasher@bmc.com) |
|
// |
|
// Modified By: Ben Heilbronn (ben_heilbronn@hp.com) |
|
// Sushma Fernandes (sushma_fernandes@hp.com) |
|
// Nag Boranna (nagaraja_boranna@hp.com) |
|
// Bapu Patil (bapu_patil@hp.com) |
|
// Dave Rosckes (rosckes@us.ibm.com) |
|
// Amit K Arora (amita@in.ibm.com) for PEP101 |
|
// David Dillard, VERITAS Software Corp. |
|
// (david.dillard@veritas.com) |
|
// Yi Zhou (yi.zhou@hp.com) |
|
// Josephine Eskaline Joyce, IBM (jojustin@in.ibm.com) for Bug#3194 |
|
// Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) |
|
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
#ifdef PEGASUS_OS_HPUX |
#if !defined(PEGASUS_OS_ZOS) && \ |
# include <dl.h> |
!defined(PEGASUS_OS_DARWIN) |
|
|
#if defined(PEGASUS_HPUX_USE_DLOPEN) |
|
# include <dlfcn.h> |
|
#endif |
|
|
|
#elif defined(PEGASUS_PLATFORM_ZOS_ZSERIES_IBM) |
|
#define _UNIX03_SOURCE |
|
# include <dlfcn.h> |
|
|
|
#elif defined(PEGASUS_PLATFORM_OS400_ISERIES_IBM) |
|
# include <fcntl.h> |
|
# include <qycmutilu2.H> |
|
# include <unistd.cleinc> |
|
# include "qycmmsgclsMessage.H" // ycmMessage class |
|
# include "OS400SystemState.h" // OS400LoadDynamicLibrary, etc |
|
# include "OS400ConvertChar.h" |
|
#else |
|
# include <dlfcn.h> |
|
#endif |
|
|
|
#include <unistd.h> |
|
#include <dirent.h> |
|
#include <pwd.h> |
|
#include <grp.h> |
|
|
|
#include <errno.h> |
|
#if defined(PEGASUS_OS_SOLARIS) |
|
# include <string.h> |
|
#endif |
|
|
|
#if !defined(PEGASUS_PLATFORM_ZOS_ZSERIES_IBM) && !defined(PEGASUS_PLATFORM_OS400_ISERIES_IBM) && !defined(PEGASUS_PLATFORM_DARWIN_PPC_GNU) |
|
#include <crypt.h> | #include <crypt.h> |
#endif | #endif |
| |
#include "Network.h" |
|
|
|
#ifdef PEGASUS_PLATFORM_ZOS_ZSERIES_IBM |
|
# define _OPEN_SYS_EXT |
|
# include <sys/ps.h> |
|
#endif |
|
|
|
#if defined(PEGASUS_USE_SYSLOGS) |
|
#include <syslog.h> |
|
#endif |
|
|
|
#include <sys/stat.h> |
|
#include <sys/types.h> |
|
#include <cstdio> |
|
#include <time.h> |
|
#include <sys/time.h> |
|
#include "System.h" |
|
#include <Pegasus/Common/Tracer.h> |
|
#include <Pegasus/Common/InternalException.h> |
|
#include <Pegasus/Common/IPC.h> |
|
#ifdef PEGASUS_ZOS_SECURITY |
|
#include "DynamicLibraryzOS_inline.h" |
|
#endif |
|
|
|
#if defined(PEGASUS_OS_LSB) |
|
#include <termios.h> |
|
#include <stdio.h> |
|
#include <stdlib.h> |
|
#endif |
|
|
|
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
#ifdef PEGASUS_OS_OS400 |
String System::getPassword(const char* prompt) |
typedef struct os400_pnstruct |
|
{ |
|
Qlg_Path_Name_T qlg_struct; |
|
char * pn; |
|
} OS400_PNSTRUCT; |
|
#endif |
|
|
|
inline void sleep_wrapper(Uint32 seconds) |
|
{ |
|
sleep(seconds); |
|
} |
|
|
|
void System::getCurrentTime(Uint32& seconds, Uint32& milliseconds) |
|
{ |
|
timeval tv; |
|
gettimeofday(&tv, 0); |
|
seconds = Uint32(tv.tv_sec); |
|
milliseconds = Uint32(tv.tv_usec) / 1000; |
|
} |
|
|
|
void System::getCurrentTimeUsec(Uint32& seconds, Uint32& microseconds) |
|
{ |
|
timeval tv; |
|
gettimeofday(&tv, 0); |
|
seconds = Uint32(tv.tv_sec); |
|
microseconds = Uint32(tv.tv_usec); |
|
} |
|
|
|
String System::getCurrentASCIITime() |
|
{ |
|
char str[50]; |
|
time_t rawTime; |
|
struct tm tmBuffer; |
|
|
|
time(&rawTime); |
|
strftime(str, 40,"%m/%d/%Y-%T", localtime_r(&rawTime, &tmBuffer)); |
|
return String(str); |
|
} |
|
|
|
void System::sleep(Uint32 seconds) |
|
{ |
|
sleep_wrapper(seconds); |
|
} |
|
|
|
Boolean System::exists(const char* path) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgAccess((Qlg_Path_Name_T *)&pathname, F_OK) == 0; |
|
#elif defined(PEGASUS_PLATFORM_ZOS_ZSERIES_IBM) |
|
struct stat info; |
|
errno = 0; |
|
return lstat(path, &info) == 0; |
|
#else |
|
return access(path, F_OK) == 0; |
|
#endif |
|
} |
|
|
|
Boolean System::canRead(const char* path) |
|
{ |
|
|
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgAccess((Qlg_Path_Name_T *)&pathname, R_OK) == 0; |
|
#else |
|
return access(path, R_OK) == 0; |
|
#endif |
|
} |
|
|
|
Boolean System::canWrite(const char* path) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgAccess((Qlg_Path_Name_T *)&pathname, W_OK) == 0; |
|
#else |
|
return access(path, W_OK) == 0; |
|
#endif |
|
} |
|
|
|
Boolean System::getCurrentDirectory(char* path, Uint32 size) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgGetcwd((Qlg_Path_Name_T *)&pathname, size) == 0; |
|
#else |
|
return getcwd(path, size) != NULL; |
|
#endif |
|
} |
|
|
|
Boolean System::isDirectory(const char* path) |
|
{ |
|
struct stat st; |
|
|
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
if (QlgStat((Qlg_Path_Name_T *)&pathname, &st) != 0) |
|
return false; |
|
#else |
|
if (stat(path, &st) != 0) |
|
return false; |
|
#endif |
|
return S_ISDIR(st.st_mode); |
|
} |
|
|
|
Boolean System::changeDirectory(const char* path) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgChdir((Qlg_Path_Name_T *)&pathname) == 0; |
|
#else |
|
return chdir(path) == 0; |
|
#endif |
|
} |
|
|
|
Boolean System::makeDirectory(const char* path) |
|
{ |
|
|
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgMkdir((Qlg_Path_Name_T *)&pathname, 0777) == 0; |
|
#else |
|
return mkdir(path, 0777) == 0; |
|
#endif |
|
|
|
} |
|
|
|
Boolean System::getFileSize(const char* path, Uint32& size) |
|
{ |
|
struct stat st; |
|
|
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
if (QlgStat((Qlg_Path_Name_T *)&pathname, &st) != 0) |
|
return false; |
|
#else |
|
if (stat(path, &st) != 0) |
|
return false; |
|
#endif |
|
|
|
size = st.st_size; |
|
return true; |
|
} |
|
|
|
Boolean System::removeDirectory(const char* path) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgRmdir((Qlg_Path_Name_T *)&pathname) == 0; |
|
#else |
|
return rmdir(path) == 0; |
|
#endif |
|
} |
|
|
|
Boolean System::removeFile(const char* path) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
return QlgUnlink((Qlg_Path_Name_T *)&pathname) == 0; |
|
#else |
|
return unlink(path) == 0; |
|
#endif |
|
} |
|
|
|
Boolean System::renameFile(const char* oldPath, const char* newPath) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT oldpathname; |
|
memset((void*)&oldpathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
oldpathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(oldpathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(oldpathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
oldpathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
oldpathname.qlg_struct.Path_Length = strlen(oldPath); |
|
oldpathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
oldpathname.pn = (char *)oldPath; |
|
|
|
OS400_PNSTRUCT newpathname; |
|
memset((void*)&newpathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
newpathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(newpathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(newpathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
newpathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
newpathname.qlg_struct.Path_Length = strlen(newPath); |
|
newpathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
newpathname.pn = (char *)newPath; |
|
|
|
if (QlgLink((Qlg_Path_Name_T *)&oldpathname, |
|
(Qlg_Path_Name_T *)&newpathname) != 0) |
|
{ |
|
return false; |
|
} |
|
|
|
return QlgUnlink((Qlg_Path_Name_T *)&oldpathname) == 0; |
|
#else |
|
|
|
if (link(oldPath, newPath) != 0) |
|
return false; |
|
|
|
return unlink(oldPath) == 0; |
|
#endif |
|
} |
|
|
|
DynamicLibraryHandle System::loadDynamicLibrary(const char* fileName) |
|
{ |
|
PEG_METHOD_ENTER(TRC_OS_ABSTRACTION, "System::loadDynamicLibrary()"); |
|
|
|
Tracer::trace(TRC_OS_ABSTRACTION, Tracer::LEVEL2, |
|
"Attempting to load library %s", fileName); |
|
|
|
#if defined(PEGASUS_OS_HPUX) && !defined(PEGASUS_HPUX_USE_DLOPEN) |
|
void* handle; |
|
if (bindVerbose) |
|
{ |
|
handle = shl_load(fileName, |
|
BIND_IMMEDIATE | DYNAMIC_PATH | BIND_VERBOSE, 0L); |
|
} |
|
else |
|
{ |
|
handle = shl_load(fileName, BIND_IMMEDIATE | DYNAMIC_PATH, 0L); |
|
} |
|
Tracer::trace(TRC_OS_ABSTRACTION, Tracer::LEVEL2, |
|
"After loading lib %s, error code is %d", fileName, |
|
(handle == (void *)0)?errno:0); |
|
|
|
PEG_METHOD_EXIT(); |
|
return DynamicLibraryHandle(handle); |
|
#elif defined(PEGASUS_OS_TRU64) |
|
PEG_METHOD_EXIT(); |
|
return DynamicLibraryHandle(dlopen(fileName, RTLD_NOW)); |
|
#elif defined(PEGASUS_OS_ZOS) |
|
# if defined(PEGASUS_ZOS_SECURITY) |
|
if (!hasProgramControl(fileName)) |
|
{ |
|
PEG_METHOD_EXIT(); |
|
return 0; |
|
} |
|
# endif |
|
PEG_METHOD_EXIT(); |
|
return DynamicLibraryHandle(dlopen(fileName, RTLD_LAZY)); |
|
#elif defined(PEGASUS_OS_OS400) |
|
PEG_METHOD_EXIT(); |
|
return DynamicLibraryHandle(OS400_LoadDynamicLibrary(fileName)); |
|
#else |
|
PEG_METHOD_EXIT(); |
|
return DynamicLibraryHandle(dlopen(fileName, RTLD_GLOBAL|RTLD_NOW)); |
|
#endif |
|
|
|
} |
|
|
|
void System::unloadDynamicLibrary(DynamicLibraryHandle libraryHandle) |
|
{ |
|
|
|
#if defined(PEGASUS_OS_HPUX) && !defined(PEGASUS_HPUX_USE_DLOPEN) |
|
// Note: shl_unload will unload the library even if it has been loaded |
|
// multiple times. No reference count is kept. |
|
int ignored = shl_unload(reinterpret_cast<shl_t>(libraryHandle)); |
|
// ATTN: Should this method indicate success/failure? |
|
#elif defined(PEGASUS_OS_OS400) |
|
OS400_UnloadDynamicLibrary((int)libraryHandle); |
|
#else |
|
dlclose(libraryHandle); |
|
#endif |
|
} |
|
|
|
String System::dynamicLoadError() { |
|
// ATTN: Is this safe in a multi-threaded process? Should this string |
|
// be returned from loadDynamicLibrary? |
|
#if defined(PEGASUS_OS_HPUX) && !defined(PEGASUS_HPUX_USE_DLOPEN) |
|
// If shl_load() returns NULL, errno is set to indicate the error |
|
return strerror(errno); |
|
#elif defined(PEGASUS_OS_ZOS) |
|
return String(); |
|
#elif defined(PEGASUS_OS_OS400) |
|
return String(OS400_DynamicLoadError()); |
|
#else |
|
String dlerr = dlerror(); |
|
return dlerr; |
|
#endif |
|
} |
|
|
|
|
|
DynamicSymbolHandle System::loadDynamicSymbol( |
|
DynamicLibraryHandle libraryHandle, |
|
const char* symbolName) |
|
{ |
|
#if defined(PEGASUS_OS_HPUX) && !defined(PEGASUS_HPUX_USE_DLOPEN) |
|
char* p = (char*)symbolName; |
|
void* proc = 0; |
|
|
|
if (shl_findsym((shl_t*)&libraryHandle, symbolName, TYPE_UNDEFINED, |
|
&proc) == 0) |
|
{ |
|
return DynamicSymbolHandle(proc); |
|
} |
|
|
|
if (shl_findsym((shl_t*)libraryHandle, |
|
(String("_") + symbolName).getCString(), |
|
TYPE_UNDEFINED, |
|
&proc) == 0) |
|
{ |
|
return DynamicSymbolHandle(proc); |
|
} |
|
|
|
return 0; |
|
|
|
#elif defined(PEGASUS_OS_OS400) |
|
return DynamicSymbolHandle(OS400_LoadDynamicSymbol((int)libraryHandle, |
|
symbolName)); |
|
#else |
|
|
|
return DynamicSymbolHandle(dlsym(libraryHandle,(char *) symbolName)); |
|
|
|
#endif |
|
} |
|
|
|
String System::getHostName() |
|
{ |
|
static char hostname[PEGASUS_MAXHOSTNAMELEN + 1]; |
|
|
|
if (!*hostname) |
|
{ |
|
gethostname(hostname, sizeof(hostname)); |
|
hostname[sizeof(hostname)-1] = 0; |
|
#if defined(PEGASUS_OS_OS400) |
|
EtoA(hostname); |
|
#endif |
|
} |
|
|
|
return hostname; |
|
} |
|
|
|
String System::getFullyQualifiedHostName () |
|
{ |
|
#if defined(PEGASUS_OS_ZOS) |
|
char hostName[PEGASUS_MAXHOSTNAMELEN + 1]; |
|
String fqName; |
|
struct addrinfo *resolv; |
|
struct addrinfo hint; |
|
struct hostent *he; |
|
// receive short name of the local host |
|
if (gethostname(hostName, PEGASUS_MAXHOSTNAMELEN) != 0) |
|
{ |
|
return String::EMPTY; |
|
} |
|
resolv = new struct addrinfo; |
|
hint.ai_flags = AI_CANONNAME; |
|
hint.ai_family = AF_UNSPEC; // any family |
|
hint.ai_socktype = 0; // any socket type |
|
hint.ai_protocol = 0; // any protocol |
|
int success = getaddrinfo(hostName, |
|
NULL, |
|
&hint, |
|
&resolv); |
|
if (success==0) |
|
{ |
|
// assign fully qualified hostname |
|
fqName.assign(resolv->ai_canonname); |
|
} else |
|
{ |
|
if ((he = gethostbyname(hostName))) |
|
{ | { |
strcpy (hostName, he->h_name); |
#if defined(PEGASUS_OS_PASE) |
} |
|
// assign hostName |
|
// if gethostbyname was successful assign that result |
|
// else assign unqualified hostname |
|
fqName.assign(hostName); |
|
} |
|
freeaddrinfo(resolv); |
|
delete resolv; |
|
|
|
return fqName; |
|
#else |
|
char hostName[PEGASUS_MAXHOSTNAMELEN + 1]; |
|
| |
if (gethostname(hostName, sizeof(hostName)) != 0) |
char* umepass = umeGetPass(); |
|
if(NULL == umepass) |
{ | { |
return String::EMPTY; | return String::EMPTY; |
} | } |
hostName[sizeof(hostName)-1] = 0; |
|
|
|
struct hostent *hostEntry; |
|
|
|
# if defined(PEGASUS_OS_LINUX) |
|
char hostEntryBuffer[8192]; |
|
struct hostent hostEntryStruct; |
|
int hostEntryErrno; |
|
|
|
gethostbyname_r( |
|
hostName, |
|
&hostEntryStruct, |
|
hostEntryBuffer, |
|
sizeof(hostEntryBuffer), |
|
&hostEntry, |
|
&hostEntryErrno); |
|
# elif defined(PEGASUS_OS_SOLARIS) |
|
char hostEntryBuffer[8192]; |
|
struct hostent hostEntryStruct; |
|
int hostEntryErrno; |
|
|
|
hostEntry = gethostbyname_r( |
|
hostName, |
|
&hostEntryStruct, |
|
hostEntryBuffer, |
|
sizeof(hostEntryBuffer), |
|
&hostEntryErrno); |
|
# else |
|
hostEntry = gethostbyname(hostName); |
|
# endif |
|
|
|
if (hostEntry) |
|
{ |
|
strncpy(hostName, hostEntry->h_name, sizeof(hostName)-1); |
|
} |
|
|
|
# if defined(PEGASUS_OS_OS400) |
|
EtoA(hostName); |
|
# endif |
|
|
|
return String(hostName); |
|
#endif |
|
} |
|
|
|
String System::getSystemCreationClassName () |
|
{ |
|
// |
|
// The value returned should match the value of the CreationClassName key |
|
// property used in the instrumentation of the CIM_ComputerSystem class |
|
// as determined by the provider for the CIM_ComputerSystem class |
|
// |
|
return "CIM_ComputerSystem"; |
|
} |
|
|
|
Uint32 System::lookupPort( |
|
const char * serviceName, |
|
Uint32 defaultPort) |
|
{ |
|
Uint32 localPort; |
|
|
|
struct servent *serv; |
|
|
|
// |
|
// Get wbem-local port from /etc/services |
|
// |
|
|
|
#ifdef PEGASUS_OS_SOLARIS |
|
#define SERV_BUFF_SIZE 1024 |
|
struct servent serv_result; |
|
char buf[SERV_BUFF_SIZE]; |
|
|
|
if ( (serv = getservbyname_r(serviceName, TCP, &serv_result, |
|
buf, SERV_BUFF_SIZE)) != NULL ) |
|
#elif defined(PEGASUS_OS_OS400) |
|
struct servent serv_result; |
|
serv = &serv_result; |
|
struct servent_data buf; |
|
memset(&buf, 0x00, sizeof(struct servent_data)); |
|
|
|
char srvnameEbcdic[256]; |
|
strcpy(srvnameEbcdic, serviceName); |
|
AtoE(srvnameEbcdic); |
|
|
|
char tcpEbcdic[64]; |
|
strcpy(tcpEbcdic, TCP); |
|
AtoE(tcpEbcdic); |
|
|
|
if ( (getservbyname_r(srvnameEbcdic, tcpEbcdic, &serv_result, |
|
&buf)) == 0 ) |
|
#else // PEGASUS_OS_SOLARIS |
|
if ( (serv = getservbyname(serviceName, TCP)) != NULL ) |
|
#endif // PEGASUS_OS_SOLARIS |
|
{ |
|
localPort = htons((uint16_t)serv->s_port); |
|
} |
|
else | else |
{ | { |
localPort = defaultPort; |
return String(umepass); |
} |
|
|
|
return localPort; |
|
} |
|
#if defined(PEGASUS_OS_LSB) |
|
/* |
|
getpass equivalent. |
|
Adapted from example implementation described in GLIBC documentation |
|
(http://www.dusek.ch/manual/glibc/libc_32.html) and |
|
"Advanced Programming in the UNIX Environment" by Richard Stevens, |
|
pg. 350. |
|
|
|
*/ |
|
#define MAX_PASS_LEN 1024 |
|
char *getpassword(const char *prompt) |
|
{ |
|
static char buf[MAX_PASS_LEN]; |
|
struct termios old, new_val; |
|
char *ptr; |
|
int c; |
|
|
|
buf[0] = 0; |
|
|
|
/* Turn echoing off and fail if we can't. */ |
|
if (tcgetattr (fileno (stdin), &old) != 0) |
|
return buf; |
|
new_val = old; |
|
new_val.c_lflag &= ~(ECHO | ECHOE | ECHOK | ECHONL); |
|
if (tcsetattr (fileno (stdin), TCSAFLUSH, &new_val) != 0) |
|
return buf; |
|
|
|
/* Read the password. */ |
|
fputs (prompt, stdin); |
|
ptr = buf; |
|
while ( (c = getc(stdin)) != EOF && c != '\n') { |
|
if (ptr < &buf[MAX_PASS_LEN]) |
|
*ptr++ = c; |
|
} |
|
*ptr = 0; |
|
putc('\n', stdin); |
|
|
|
/* Restore terminal. */ |
|
(void) tcsetattr (fileno (stdin), TCSAFLUSH, &old); |
|
fclose(stdin); |
|
return buf; |
|
} |
|
#endif |
|
|
|
String System::getPassword(const char* prompt) |
|
{ |
|
|
|
String password; |
|
|
|
#if !defined(PEGASUS_OS_OS400) |
|
// Not supported on OS/400, and we don't need it. |
|
// 'getpass' is DEPRECATED |
|
# if !defined(PEGASUS_OS_LSB) |
|
password = String(getpass( prompt )); |
|
# else |
|
password = String(getpassword( prompt )); |
|
# endif |
|
|
|
#endif |
|
|
|
return password; |
|
} | } |
| |
String System::getEffectiveUserName() |
#else /* default */ |
{ |
|
String userName = String::EMPTY; |
|
struct passwd* pwd = NULL; |
|
| |
#if defined(PEGASUS_OS_SOLARIS) || \ |
return String(getpass(prompt)); |
defined(PEGASUS_OS_HPUX) || \ |
|
defined(PEGASUS_OS_LINUX) || \ |
|
defined(PEGASUS_OS_OS400) |
|
| |
const unsigned int PWD_BUFF_SIZE = 1024; |
#endif /* default */ |
struct passwd local_pwd; |
|
char buf[PWD_BUFF_SIZE]; |
|
| |
if(getpwuid_r(geteuid(), &local_pwd, buf, PWD_BUFF_SIZE, &pwd) != 0) |
|
{ |
|
String errorMsg = String("getpwuid_r failure : ") + |
|
String(strerror(errno)); |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
|
// L10N TODO - This message needs to be added. |
|
//Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
|
// errorMsg); |
|
} |
|
#elif defined(PEGASUS_OS_ZOS) |
|
char effective_username[9]; |
|
__getuserid(effective_username, 9); |
|
__etoa_l(effective_username,9); |
|
userName.assign(effective_username); |
|
return userName; |
|
#else |
|
// |
|
// get the currently logged in user's UID. |
|
// |
|
pwd = getpwuid(geteuid()); |
|
#endif |
|
if ( pwd == NULL ) |
|
{ |
|
// L10N TODO - This message needs to be added. |
|
//Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
|
// "getpwuid_r failure, user may have been removed just after login"); |
|
Tracer::trace (TRC_OS_ABSTRACTION, Tracer::LEVEL4, |
|
"getpwuid_r failure, user may have been removed just after login"); |
|
} |
|
else |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
EtoA(pwd->pw_name); |
|
#endif |
|
// |
|
// get the user name |
|
// |
|
userName.assign(pwd->pw_name); |
|
} |
|
|
|
return(userName); |
|
} | } |
| |
String System::encryptPassword(const char* password, const char* salt) | String System::encryptPassword(const char* password, const char* salt) |
{ | { |
#if !defined(PEGASUS_OS_OS400) |
return String(crypt(password, salt)); |
return ( String(crypt( password,salt)) ); |
|
#else |
|
// Not supported on OS400, and we don't need it. |
|
return ( String(password) ); |
|
#endif |
|
} | } |
| |
Boolean System::isSystemUser(const char* userName) |
Boolean System::isPrivilegedUser(const String& userName) |
{ | { |
#if defined(PEGASUS_OS_OS400) |
#if defined(PEGASUS_OS_PASE) |
AtoE((char *)userName); |
CString user = userName.getCString(); |
#endif |
// this function only can be found in PASE environment |
|
return umeIsPrivilegedUser((const char *)user); |
#if defined(PEGASUS_OS_SOLARIS) || \ |
|
defined(PEGASUS_OS_HPUX) || \ |
|
defined(PEGASUS_OS_LINUX) || \ |
|
defined(PEGASUS_OS_OS400) |
|
|
|
const unsigned int PWD_BUFF_SIZE = 1024; |
|
struct passwd pwd; |
|
struct passwd *result; |
|
char pwdBuffer[PWD_BUFF_SIZE]; |
|
| |
if (getpwnam_r(userName, &pwd, pwdBuffer, PWD_BUFF_SIZE, &result) != 0) |
|
{ |
|
String errorMsg = String("getpwnam_r failure : ") + |
|
String(strerror(errno)); |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
|
// L10N TODO - This message needs to be added. |
|
//Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
|
// errorMsg); |
|
} |
|
if (result == NULL) |
|
{ |
|
return false; |
|
} |
|
#else | #else |
// |
|
// get the password entry for the user |
|
// |
|
if ( getpwnam(userName) == NULL ) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
EtoA((char *)userName); |
|
#endif |
|
return false; |
|
} |
|
#endif |
|
#if defined(PEGASUS_OS_OS400) |
|
EtoA((char *)userName); |
|
#endif |
|
|
|
return true; |
|
} |
|
|
|
Boolean System::isPrivilegedUser(const String& userName) |
|
{ |
|
// |
|
// Check if the given user is a privileged user |
|
// |
|
#if !defined(PEGASUS_OS_OS400) |
|
struct passwd pwd; | struct passwd pwd; |
struct passwd *result; | struct passwd *result; |
const unsigned int PWD_BUFF_SIZE = 1024; | const unsigned int PWD_BUFF_SIZE = 1024; |
|
|
if (getpwnam_r( | if (getpwnam_r( |
userName.getCString(), &pwd, pwdBuffer, PWD_BUFF_SIZE, &result) != 0) | userName.getCString(), &pwd, pwdBuffer, PWD_BUFF_SIZE, &result) != 0) |
{ | { |
String errorMsg = String("getpwnam_r failure : ") + |
PEG_TRACE(( |
String(strerror(errno)); |
TRC_OS_ABSTRACTION, |
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
Tracer::LEVEL1, |
// L10N TODO - This message needs to be added. |
"getpwnam_r failure : %s", |
//Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
strerror(errno))); |
// errorMsg); |
|
} | } |
| |
// Check if the requested entry was found. If not return false. | // Check if the requested entry was found. If not return false. |
|
|
} | } |
} | } |
return false; | return false; |
|
|
#else |
|
CString user = userName.getCString(); |
|
const char * tmp = (const char *)user; |
|
AtoE((char *)tmp); |
|
return ycmCheckUserCmdAuthorities(tmp); |
|
#endif |
|
|
|
} |
|
|
|
String System::getPrivilegedUserName() |
|
{ |
|
static String userName = String::EMPTY; |
|
|
|
if (userName == String::EMPTY) |
|
{ |
|
struct passwd* pwd = NULL; |
|
#if defined(PEGASUS_OS_SOLARIS) || \ |
|
defined(PEGASUS_OS_HPUX) || \ |
|
defined(PEGASUS_OS_LINUX) || \ |
|
defined(PEGASUS_OS_OS400) |
|
const unsigned int PWD_BUFF_SIZE = 1024; |
|
struct passwd local_pwd; |
|
char buf[PWD_BUFF_SIZE]; |
|
|
|
if(getpwuid_r(0, &local_pwd, buf, PWD_BUFF_SIZE, &pwd) != 0) |
|
{ |
|
String errorMsg = String("getpwuid_r failure : ") + |
|
String(strerror(errno)); |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
|
// L10N TODO - This message needs to be added. |
|
//Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
|
// errorMsg); |
|
} |
|
#else |
|
// |
|
// get the privileged user's UID. |
|
// |
|
// (on OS/400, this is QSECOFR) |
|
pwd = getpwuid(0); |
|
#endif | #endif |
if ( pwd != NULL ) |
|
{ |
|
#if defined(PEGASUS_OS_OS400) |
|
EtoA(pwd->pw_name); |
|
#endif |
|
// |
|
// get the user name |
|
// |
|
userName.assign(pwd->pw_name); |
|
} |
|
else |
|
{ |
|
Tracer::trace (TRC_OS_ABSTRACTION, Tracer::LEVEL4, |
|
"Could not find entry."); |
|
PEGASUS_ASSERT(0); |
|
} |
|
} | } |
| |
return (userName); |
#if defined(PEGASUS_ENABLE_USERGROUP_AUTHORIZATION) |
} |
|
| |
Boolean System::isGroupMember(const char* userName, const char* groupName) | Boolean System::isGroupMember(const char* userName, const char* groupName) |
{ | { |
|
|
char pwdBuffer[PWD_BUFF_SIZE]; | char pwdBuffer[PWD_BUFF_SIZE]; |
char grpBuffer[GRP_BUFF_SIZE]; | char grpBuffer[GRP_BUFF_SIZE]; |
| |
// |
|
// Search Primary group information. | // Search Primary group information. |
// |
|
| |
// Find the entry that matches "userName" | // Find the entry that matches "userName" |
| |
|
|
{ | { |
String errorMsg = String("getpwnam_r failure : ") + | String errorMsg = String("getpwnam_r failure : ") + |
String(strerror(errno)); | String(strerror(errno)); |
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
Logger::put(Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
|
errorMsg); | errorMsg); |
throw InternalSystemError(); | throw InternalSystemError(); |
} | } |
|
|
{ | { |
String errorMsg = String("getgrgid_r failure : ") + | String errorMsg = String("getgrgid_r failure : ") + |
String(strerror(errno)); | String(strerror(errno)); |
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
Logger::put( |
Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
errorMsg); | errorMsg); |
throw InternalSystemError(); | throw InternalSystemError(); |
} | } |
|
|
// Search supplemental groups. | // Search supplemental groups. |
// Get a user group entry | // Get a user group entry |
// | // |
#if defined(PEGASUS_OS_LSB) |
|
if ( getgrnam_r((char *)groupName, &grp, | if ( getgrnam_r((char *)groupName, &grp, |
grpBuffer, GRP_BUFF_SIZE, &grpresult) != 0 ) | grpBuffer, GRP_BUFF_SIZE, &grpresult) != 0 ) |
#else |
|
if ( getgrnam_r(groupName, &grp, |
|
grpBuffer, GRP_BUFF_SIZE, &grpresult) != 0 ) |
|
|
|
#endif |
|
{ | { |
String errorMsg = String("getgrnam_r failure : ") + | String errorMsg = String("getgrnam_r failure : ") + |
String(strerror(errno)); | String(strerror(errno)); |
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, errorMsg); |
Logger::put( |
Logger::put(Logger::STANDARD_LOG, "CIMServer", Logger::WARNING, |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, errorMsg); |
errorMsg); |
|
throw InternalSystemError(); | throw InternalSystemError(); |
} | } |
| |
|
|
return retVal; | return retVal; |
} | } |
| |
#ifndef PEGASUS_OS_OS400 |
#endif /* PEGASUS_ENABLE_USERGROUP_AUTHORIZATION */ |
Boolean System::lookupUserId( |
|
const char* userName, |
|
PEGASUS_UID_T& uid, |
|
PEGASUS_GID_T& gid) |
|
{ |
|
const unsigned int PWD_BUFF_SIZE = 1024; |
|
struct passwd pwd; |
|
struct passwd *result; |
|
char pwdBuffer[PWD_BUFF_SIZE]; |
|
|
|
# if defined(PEGASUS_OS_OS400) |
|
AtoE((char *)userName); |
|
# endif |
|
|
|
int rc = getpwnam_r(userName, &pwd, pwdBuffer, PWD_BUFF_SIZE, &result); |
|
|
|
# if defined(PEGASUS_OS_OS400) |
|
EtoA((char *)userName); |
|
# endif |
|
|
|
if (rc != 0) |
|
{ |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, |
|
String("getpwnam_r failed: ") + String(strerror(errno))); |
|
return false; |
|
} |
|
|
|
if (result == 0) |
|
{ |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, |
|
"getpwnam_r failed."); |
|
return false; |
|
} |
|
|
|
uid = pwd.pw_uid; |
|
gid = pwd.pw_gid; |
|
|
|
return true; |
|
} |
|
| |
Boolean System::changeUserContext( |
|
const PEGASUS_UID_T& uid, |
|
const PEGASUS_GID_T& gid) |
|
{ |
|
Tracer::trace(TRC_OS_ABSTRACTION, Tracer::LEVEL4, |
|
"Changing user context to: uid = %d, gid = %d", |
|
(int)uid, (int)gid); |
|
|
|
if (setgid(gid) != 0) |
|
{ |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, |
|
String("setgid failed: ") + String(strerror(errno))); |
|
return false; |
|
} |
|
|
|
if (setuid(uid) != 0) |
|
{ |
|
PEG_TRACE_STRING(TRC_OS_ABSTRACTION, Tracer::LEVEL2, |
|
String("setuid failed: ") + String(strerror(errno))); |
|
return false; |
|
} |
|
|
|
return true; |
|
} |
|
#endif |
|
|
|
Uint32 System::getPID() |
|
{ |
|
// |
|
// Get the Process ID |
|
// |
|
Uint32 pid = getpid(); |
|
|
|
return pid; |
|
} |
|
|
|
Boolean System::truncateFile( |
|
const char* path, |
|
size_t newSize) |
|
{ |
|
#if !defined(PEGASUS_OS_OS400) |
|
return (truncate(path, newSize) == 0); |
|
#else |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
int fd = QlgOpen((Qlg_Path_Name_T *)&pathname, O_WRONLY); |
|
if (fd != -1) |
|
{ |
|
int rc = ftruncate(fd, newSize); |
|
close(fd); |
|
return (rc == 0); |
|
} |
|
|
|
return false; |
|
#endif |
|
} |
|
|
|
// Is absolute path? |
|
Boolean System::is_absolute_path(const char *path) |
|
{ |
|
if (path == NULL) |
|
return false; |
|
|
|
if (path[0] == '/') |
|
return true; |
|
|
|
return false; |
|
} |
|
|
|
// Changes file permissions on the given file. |
|
Boolean System::changeFilePermissions(const char* path, mode_t mode) |
|
{ |
|
Sint32 ret = 0; |
|
|
|
const char * tmp = path; |
|
|
|
#if defined(PEGASUS_OS_OS400) |
|
// ATTN: Update this code to handle UTF8 when path contains UTF8 |
|
AtoE((char *)tmp); |
|
#endif |
|
|
|
ret = ::chmod(tmp, mode); |
|
|
|
return ( ret != -1 ); |
|
} |
|
|
|
Boolean System::verifyFileOwnership(const char* path) |
|
{ |
|
struct stat st; |
|
|
|
#if defined(PEGASUS_OS_OS400) |
|
OS400_PNSTRUCT pathname; |
|
memset((void*)&pathname, 0x00, sizeof(OS400_PNSTRUCT)); |
|
pathname.qlg_struct.CCSID = 1208; |
|
#pragma convert(37) |
|
memcpy(pathname.qlg_struct.Country_ID,"US",2); |
|
memcpy(pathname.qlg_struct.Language_ID,"ENU",3); |
|
#pragma convert(0) |
|
pathname.qlg_struct.Path_Type = QLG_PTR_SINGLE; |
|
pathname.qlg_struct.Path_Length = strlen(path); |
|
pathname.qlg_struct.Path_Name_Delimiter[0] = '/'; |
|
pathname.pn = (char *)path; |
|
|
|
if (QlgStat((Qlg_Path_Name_T *)&pathname, &st) != 0) |
|
{ |
|
return false; |
|
} |
|
#else |
|
if (lstat(path, &st) != 0) |
|
{ |
|
return false; |
|
} |
|
#endif |
|
|
|
return ((st.st_uid == geteuid()) && // Verify the file owner |
|
S_ISREG(st.st_mode) && // Verify it is a regular file |
|
(st.st_nlink == 1)); // Verify it is not a hard link |
|
} |
|
|
|
void System::syslog(const String& ident, Uint32 severity, const char* message) |
|
{ |
|
#if defined(PEGASUS_OS_HPUX) || defined(PEGASUS_OS_LINUX) |
|
|
|
// Since the openlog(), syslog(), and closelog() function calls must be |
|
// coordinated (see below), we need a thread control. |
|
|
|
static Mutex logMutex; |
|
|
|
AutoMutex loglock(logMutex); |
|
|
|
// Get a const char* representation of the identifier string. Note: The |
|
// character string passed to the openlog() function must persist until |
|
// closelog() is called. The syslog() method uses this pointer directly |
|
// rather than a copy of the string it refers to. |
|
|
|
CString identCString = ident.getCString(); |
|
openlog(identCString, LOG_PID, LOG_DAEMON); |
|
|
|
// Map from the Logger log level to the system log level. |
|
|
|
Uint32 syslogLevel; |
|
if (severity & Logger::FATAL) |
|
{ |
|
syslogLevel = LOG_CRIT; |
|
} |
|
else if (severity & Logger::SEVERE) |
|
{ |
|
syslogLevel = LOG_ERR; |
|
} |
|
else if (severity & Logger::WARNING) |
|
{ |
|
syslogLevel = LOG_WARNING; |
|
} |
|
else if (severity & Logger::INFORMATION) |
|
{ |
|
syslogLevel = LOG_INFO; |
|
} |
|
else // if (severity & Logger::TRACE) |
|
{ |
|
syslogLevel = LOG_DEBUG; |
|
} |
|
|
|
// Write the message to the system log. |
|
|
|
::syslog(syslogLevel, "%s", message); |
|
|
|
closelog(); |
|
|
|
#elif defined(PEGASUS_OS_OS400) |
|
|
|
std::string replacementData = message; |
|
// All messages will go to the joblog. In the future |
|
// some messages may go to other message queues yet |
|
// to be determined. |
|
if ((severity & Logger::TRACE) || |
|
(severity & Logger::INFORMATION)) |
|
{ |
|
|
|
// turn into ycmMessage so we can put it in the job log |
|
# pragma convert(37) |
|
ycmMessage theMessage("CPIDF80", |
|
message, |
|
strlen(message), |
|
"Logger", |
|
ycmCTLCIMID, |
|
TRUE); |
|
# pragma convert(0) |
|
|
|
// put the message in the joblog |
|
theMessage.joblogIt(UnitOfWorkError, |
|
ycmMessage::Informational); |
|
} |
|
|
|
if ((severity & Logger::WARNING) || |
|
(severity & Logger::SEVERE) || |
|
(severity & Logger::FATAL)) |
|
{ |
|
// turn into ycmMessage so we can put it in the job log |
|
# pragma convert(37) |
|
ycmMessage theMessage("CPDDF82", |
|
message, |
|
strlen(message), |
|
"Logger", |
|
ycmCTLCIMID, |
|
TRUE); |
|
# pragma convert(0) |
|
// put the message in the joblog |
|
theMessage.joblogIt(UnitOfWorkError, |
|
ycmMessage::Diagnostic); |
|
} |
|
|
|
#endif |
|
} |
|
|
|
// System ID constants for Logger::put and Logger::trace |
|
#if defined(PEGASUS_PLATFORM_OS400_ISERIES_IBM) |
|
const String System::CIMSERVER = "qycmcimom"; // Server system ID |
|
#else |
|
const String System::CIMSERVER = "cimserver"; // Server system ID |
|
#endif |
|
|
|
|
|
|
|
|
|
// |
|
// System Initializater for AIX |
|
// |
|
#ifdef PEGASUS_OS_AIX |
|
#include <cstdlib> |
|
|
|
class SystemInitializer |
|
{ |
|
|
|
public: |
|
/** |
|
* |
|
* Default constructor. |
|
* |
|
*/ |
|
SystemInitializer(); |
|
}; |
|
|
|
|
|
|
|
SystemInitializer::SystemInitializer() |
|
{ |
|
putenv("XPG_SUS_ENV=ON"); |
|
} |
|
|
|
static SystemInitializer initializer; |
|
|
|
#endif |
|
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |