![]() ![]() |
![]() |
File: [Pegasus] / pegasus / src / slp / slp_agent / peg_slp_agent.cpp
(download)
Revision: 1.12, Wed Feb 8 00:21:17 2006 UTC (18 years, 4 months ago) by jim.wunderlich Branch: MAIN CVS Tags: TASK_PEP233_EmbeddedInstSupport-merge_out_trunk, TASK_BUG_5314_IPC_REFACTORING_ROOT, TASK_BUG_5191_QUEUE_CONSOLIDATION_ROOT, TASK_BUG_5191_QUEUE_CONSOLIDATION_BRANCH, TASK-PEP250_RPMProvider-root, TASK-PEP250_RPMProvider-merged_out_to_branch, TASK-PEP250_RPMProvider-merged_out_from_trunk, TASK-PEP250_RPMProvider-merged_in_to_trunk, TASK-PEP250_RPMProvider-merged_in_from_branch, TASK-PEP250_RPMProvider-branch, TASK-PEP245_CimErrorInfrastructure-root, TASK-PEP245_CimErrorInfrastructure-merged_out_to_branch, TASK-PEP245_CimErrorInfrastructure-merged_out_from_trunk, TASK-PEP245_CimErrorInfrastructure-merged_in_to_trunk, TASK-PEP245_CimErrorInfrastructure-merged_in_from_branch, TASK-PEP245_CimErrorInfrastructure-branch, TASK-PEP241_OpenPegasusStressTests-root, TASK-PEP241_OpenPegasusStressTests-merged_out_to_branch, TASK-PEP241_OpenPegasusStressTests-merged_out_from_trunk, TASK-PEP241_OpenPegasusStressTests-merged_in_to_trunk, TASK-PEP241_OpenPegasusStressTests-merged_in_from_branch, TASK-PEP241_OpenPegasusStressTests-branch, TASK-BUG4011_WinLocalConnect-root, TASK-BUG4011_WinLocalConnect-merged_out_to_branch, TASK-BUG4011_WinLocalConnect-merged_out_from_trunk, TASK-BUG4011_WinLocalConnect-merged_in_to_trunk, TASK-BUG4011_WinLocalConnect-merged_in_from_branch, TASK-BUG4011_WinLocalConnect-branch, RELEASE_2_5_5-RC2, RELEASE_2_5_5-RC1, RELEASE_2_5_5, RELEASE_2_5_4-RC2, RELEASE_2_5_4-RC1, RELEASE_2_5_4, RELEASE_2_5_3-RC1, RELEASE_2_5_3, RELEASE_2_5_2-RC1, RELEASE_2_5_2, RELEASE_2_5_1-RC1, RELEASE_2_5_1, RELEASE_2_5-root, RELEASE_2_5-branch Branch point for: TASK_BUG_5314_IPC_REFACTORING_BRANCH Changes since 1.11: +64 -1 lines BUG#: 4722 TITLE: SLP must offer alternative of using OpenSLP libraries DESCRIPTION: Changes to allow use of OpenSLP with Pegasus. Uses environment variables at build time to specify the use of the OpenSLP. See comments added to config.mak for environment variables to set. |
//%2006//////////////////////////////////////////////////////////////////////// // // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; // IBM Corp.; EMC Corporation, The Open Group. // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; // EMC Corporation; VERITAS Software Corporation; The Open Group. // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; // EMC Corporation; Symantec Corporation; The Open Group. // // 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 Day (mdday@us.ibm.com) // // Modified By: David Dillard, VERITAS Software Corp. // (david.dillard@veritas.com) // //%///////////////////////////////////////////////////////////////////////////// #include "peg_slp_agent.h" #ifdef PEGASUS_USE_OPENSLP #include <slp.h> #endif /* PEGASUS_USE_OPENSLP */ PEGASUS_USING_STD; PEGASUS_NAMESPACE_BEGIN class sa_reg_params { public: sa_reg_params(const char*, const char*, const char*, const char*, unsigned short); ~sa_reg_params(void); char* url; char* attrs; char* type; char* scopes; Uint32 lifetime; Uint32 expire; private: sa_reg_params(void); sa_reg_params(const sa_reg_params&); sa_reg_params& operator=(const sa_reg_params&); }; sa_reg_params::sa_reg_params(const char* _url, const char* _attrs, const char* _type, const char* _scopes, unsigned short _lifetime) { if(_url) url = strdup(_url); if(_attrs) attrs = strdup(_attrs); if(_type) type = strdup(_type); if(_scopes) scopes = strdup(_scopes); lifetime = _lifetime; Uint32 msec, now; System::getCurrentTime(now, msec); expire = 0; } sa_reg_params::~sa_reg_params(void) { if(url) free(url); if(attrs) free(attrs); if(type) free(type); if(scopes) free(scopes); } #ifdef PEGASUS_USE_OPENSLP void SLPRegCallback(SLPHandle slp_handle, SLPError errcode, void* cookie) { /* return the error code in the cookie */ *(SLPError*)cookie = errcode; /* You could do something else here like print out */ /* the errcode, etc. Remember, as a general rule, */ /* do not try to do too much in a callback because */ /* it is being executed by the same thread that is */ /* reading slp packets from the wire. */ } #endif /* PEGASUS_USE_OPENSLP */ slp_service_agent::slp_service_agent(void) : _listen_thread(service_listener, this, false), _initialized(0) { try { _init(); } catch(...) { } if(_initialized.get() && _lib_handle && _create_client) { _rep = _create_client("239.255.255.253", 0, 427, "DSA", "DEFAULT", TRUE, FALSE); } } slp_service_agent::slp_service_agent(const char *local_interface, unsigned short target_port, const char *scopes, Boolean listen, Boolean use_da) : _listen_thread(service_listener, this, false), _initialized(0) { try { _init(); } catch(...) { } if(_initialized.get() && _lib_handle && _create_client) { _rep = _create_client("239.255.255.253", local_interface, target_port, "DSA", "scopes", listen, use_da); } } slp_service_agent::~slp_service_agent(void) { try { _de_init(); } catch(...) { } } void slp_service_agent::_init(void) { #if defined(PEGASUS_OS_ZOS) char * pegasusHome; if (pegasusHome = getenv("PEGASUS_HOME")) { _lib_fileName.append(pegasusHome); _lib_fileName.append("/lib/"); } #endif _initialized = 0; #ifdef PEGASUS_OS_TYPE_WINDOWS _lib_fileName.append("pegslp_client.dll"); #elif defined(PEGASUS_OS_HPUX) _lib_fileName.append("pegslp_client.sl"); #elif defined(PEGASUS_OS_OS400) _lib_fileName.append("pegslp_client"); #else _lib_fileName.append("libpegslp_client.so"); #endif _lib_handle = System::loadDynamicLibrary((const char *)_lib_fileName.getCString()); if(_lib_handle) { _create_client = (slp_client * (*)(const char*, const char*, uint16, const char*, const char*, BOOL, BOOL)) System::loadDynamicSymbol(_lib_handle, "create_slp_client"); _destroy_client = (void (*)(struct slp_client *)) System::loadDynamicSymbol(_lib_handle, "destroy_slp_client"); _find_das = (int (*)(struct slp_client *, const char *, const char *)) System::loadDynamicSymbol(_lib_handle, "find_das"); _test_reg = (uint32 (*)(char*, char*, char*, char*)) System::loadDynamicSymbol(_lib_handle, "test_srv_reg"); _initialized = 1; if(_create_client == 0 || _destroy_client == 0 || _find_das == 0 || _test_reg == 0) { _initialized = 0; String symbol; if (_create_client == 0){symbol = "create_slp_client";} if (_destroy_client == 0){symbol = "destroy_slp_client";} if (_find_das == 0){symbol = "find_das";} if (_test_reg == 0){symbol = "test_srv_reg";} Logger::put(Logger::ERROR_LOG, "slp_agent", Logger::SEVERE, "Link Error to library: $0, symbol: $1" , _lib_fileName, symbol); System::unloadDynamicLibrary(_lib_handle); } } } void slp_service_agent::_de_init(void) { if(_initialized.get() && _lib_handle) { if(_rep) { _destroy_client(_rep); _rep = 0; } try { System::unloadDynamicLibrary(_lib_handle); _lib_handle = 0; } catch(...) { _lib_handle = 0; } } } Boolean slp_service_agent::srv_register(const char* url, const char* attributes, const char* type, const char* scopes, unsigned short lifetime) { if(_initialized.get() == 0 ) throw UninitializedObjectException(); if(url == 0 || attributes == 0 || type == 0) return false; sa_reg_params* rp = 0; _internal_regs.lookup(url, rp); if(rp ) { _internal_regs.remove(url); delete rp; } rp = new sa_reg_params(url, attributes, type, scopes, lifetime); _internal_regs.insert(url, rp); #ifdef PEGASUS_USE_OPENSLP SLPHandle slp_handle = 0; SLPError slpErr = SLP_OK; SLPError callbackErr = SLP_OK; if ((slpErr = SLPOpen(NULL, SLP_FALSE, &slp_handle)) == SLP_OK) { slpErr = SLPReg(slp_handle, url, lifetime, type, attributes, SLP_TRUE, SLPRegCallback, &callbackErr); if ((slpErr != SLP_OK) || (callbackErr != SLP_OK)) { SLPClose(slp_handle); return false; } SLPClose(slp_handle); } else { return false; } #endif /* PEGASUS_USE_OPENSLP */ return true; } void slp_service_agent::unregister(void) { if(_initialized.get() == 0 ) throw UninitializedObjectException(); #ifndef PEGASUS_USE_OPENSLP _should_listen = 0; _listen_thread.join(); #endif /* PEGASUS_USE_OPENSLP */ while(slp_reg_table::Iterator i = _internal_regs.start()) { sa_reg_params *rp = i.value(); #ifdef PEGASUS_USE_OPENSLP SLPHandle slp_handle = 0; SLPError slpErr = SLP_OK; SLPError callbackErr=SLP_OK; if ((slpErr = SLPOpen(NULL, SLP_FALSE, &slp_handle)) == SLP_OK) { slpErr = SLPDereg(slp_handle, rp->url, SLPRegCallback, &callbackErr); if ((slpErr != SLP_OK) || (callbackErr != SLP_OK)) { SLPClose(slp_handle); continue; // No need to report error since we're probably shutting down anyway. } SLPClose(slp_handle); } else { continue; // No need to report error since we're probably shutting down anyway. } #endif /* PEGASUS_USE_OPENSLP */ _internal_regs.remove(rp->url); delete rp; } } Uint32 slp_service_agent::test_registration(const char *url, const char *attrs, const char *type, const char *scopes) { if(_initialized.get() == 0 ) throw UninitializedObjectException(); //cout << "test_registration. type= " << type << endl; if(type == 0) return 1; if(url == 0) return 2; if(attrs == 0) return 3; if(scopes == 0) return 4; char* _type = strdup(type); char* _url = strdup(url); char* _attrs = strdup(attrs); char* _scopes = strdup(scopes); Uint32 ccode = _test_reg(_type, _url, _attrs, _scopes); //cout << "rtn from _tst_reg: " << ccode << endl; free(_type); free(_url); free(_attrs); free(_scopes); return ccode; } void slp_service_agent::start_listener(void) { // see if we need to use an slp directory agent if(_initialized.get() == 0 ) throw UninitializedObjectException(); #ifndef PEGASUS_USE_OPENSLP _using_das = _find_das(_rep, NULL, "DEFAULT"); _should_listen = 1; _listen_thread.run(); #endif /* PEGASUS_USE_OPENSLP */ } PEGASUS_THREAD_RETURN PEGASUS_THREAD_CDECL slp_service_agent::service_listener(void *parm) { #ifndef PEGASUS_USE_OPENSLP Thread *myself = (Thread *)parm; if(myself == 0) throw NullPointer(); slp_service_agent *agent = (slp_service_agent *)myself->get_parm(); lslpMsg msg_list; while(agent->_should_listen.get()) { Uint32 now, msec; System::getCurrentTime(now, msec); // now register everything for(slp_reg_table::Iterator i = agent->_internal_regs.start(); i ; i++) { sa_reg_params *rp = i.value(); if(rp->expire == 0 || rp->expire < now - 1) { rp->expire = now + rp->lifetime; if(agent->_using_das.get()) { agent->_rep->srv_reg_all( agent->_rep, rp->url, rp->attrs, rp->type, rp->scopes, rp->lifetime); } else { agent->_rep->srv_reg_local( agent->_rep, rp->url, rp->attrs, rp->type, rp->scopes, rp->lifetime); } } } agent->_rep->service_listener(agent->_rep, 0, &msg_list); _LSLP_SLEEP(1); } myself->exit_self((PEGASUS_THREAD_RETURN) 0) ; #endif /* PEGASUS_USE_OPENSLP */ return(0); } PEGASUS_NAMESPACE_END
No CVS admin address has been configured |
Powered by ViewCVS 0.9.2 |