version 1.21, 2005/02/05 22:59:23
|
version 1.24.18.1, 2008/01/02 21:00:39
|
|
|
//%2005//////////////////////////////////////////////////////////////////////// |
//%2006//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development | // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. | // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
|
|
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. | // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; | // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
// EMC Corporation; VERITAS Software Corporation; The Open Group. | // 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 | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// | // |
//============================================================================== | //============================================================================== |
// | // |
// Author: Mike Brasher (mbrasher@bmc.com) |
|
// |
|
// Modified By: Carol Ann Krug Graves, Hewlett-Packard Company |
|
// (carolann_graves@hp.com) |
|
// Dan Gorey, IBM (djgorey@us.ibm.com) |
|
// Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) |
|
// |
|
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
#ifndef Pegasus_HTTPConnector_h | #ifndef Pegasus_HTTPConnector_h |
#define Pegasus_HTTPConnector_h | #define Pegasus_HTTPConnector_h |
| |
#include <Pegasus/Common/Config.h> | #include <Pegasus/Common/Config.h> |
#include <Pegasus/Common/MessageQueueService.h> |
#include <Pegasus/Common/MessageQueue.h> |
#include <Pegasus/Common/Monitor.h> | #include <Pegasus/Common/Monitor.h> |
#include <Pegasus/Common/String.h> | #include <Pegasus/Common/String.h> |
#include <Pegasus/Common/TLS.h> | #include <Pegasus/Common/TLS.h> |
|
|
server. For each established connection, a HTTPConnection object | server. For each established connection, a HTTPConnection object |
is created. | is created. |
*/ | */ |
class PEGASUS_COMMON_LINKAGE HTTPConnector : public MessageQueueService |
class PEGASUS_COMMON_LINKAGE HTTPConnector : public MessageQueue |
{ | { |
public: | public: |
| |
typedef MessageQueueService Base; |
typedef MessageQueue Base; |
| |
/** Constructor. | /** Constructor. |
@param monitor pointer to monitor object which this class uses to | @param monitor pointer to monitor object which this class uses to |
|
|
| |
@param host indicates host to connect to | @param host indicates host to connect to |
@param portNumber indicates port number to use | @param portNumber indicates port number to use |
@param outputMessageQueue output message queue for the HTTPConnection |
|
that will be created. |
|
@exception InvalidLocatorException |
|
@exception CannotCreateSocketException |
|
@exception CannotConnectException |
|
*/ |
|
inline HTTPConnection* connect( |
|
const String& host, |
|
const Uint32 portNumber, |
|
MessageQueue* outputMessageQueue) |
|
{ |
|
return connect(host, portNumber, NULL, outputMessageQueue); |
|
} |
|
|
|
/** Establishes a new connection and creates an HTTPConnection object |
|
to represent it. |
|
|
|
@param host indicates host to connect to |
|
@param portNumber indicates port number to use |
|
@param sslContext Specifies the SSL context to use for this connection | @param sslContext Specifies the SSL context to use for this connection |
|
@param timeoutMilliseconds Specifies the connection timeout. |
|
If a socket is non-blocking and a connection is in progress after |
|
the initial attempt, the connection will be attempted until the |
|
specified timeout is reached. If the specified timeout is zero, |
|
the connection will not be re-attempted. The timeout is not |
|
applicable for a blocking socket. |
@param outputMessageQueue output message queue for the HTTPConnection | @param outputMessageQueue output message queue for the HTTPConnection |
that will be created. | that will be created. |
@exception InvalidLocatorException | @exception InvalidLocatorException |
|
|
const String& host, | const String& host, |
const Uint32 portNumber, | const Uint32 portNumber, |
SSLContext * sslContext, | SSLContext * sslContext, |
|
Uint32 timeoutMilliseconds, |
MessageQueue* outputMessageQueue); | MessageQueue* outputMessageQueue); |
| |
/** Destroys all the connections created by this connector. */ | /** Destroys all the connections created by this connector. */ |
|
|
| |
SSLContext * _sslcontext; | SSLContext * _sslcontext; |
int _entry_index; | int _entry_index; |
|
|
}; | }; |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |