blob: 9e0cf6b2f1cbee896a91019862ebd86275c4f2b6 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*/
#include <activemq/commands/ConnectionInfo.h>
#include <activemq/exceptions/ActiveMQException.h>
#include <activemq/state/CommandVisitor.h>
#include <decaf/lang/exceptions/NullPointerException.h>
using namespace std;
using namespace activemq;
using namespace activemq::exceptions;
using namespace activemq::commands;
using namespace decaf::lang;
using namespace decaf::lang::exceptions;
/*
*
* Command code for OpenWire format for ConnectionInfo
*
* NOTE!: This file is auto generated - do not modify!
* if you need to make a change, please see the Java Classes in the
* activemq-cpp-openwire-generator module
*
*/
////////////////////////////////////////////////////////////////////////////////
ConnectionInfo::ConnectionInfo() :
BaseCommand(), connectionId(NULL), clientId(""), password(""), userName(""), brokerPath(), brokerMasterConnector(false),
manageable(false), clientMaster(false), faultTolerant(false), failoverReconnect(false), clientIp("") {
}
////////////////////////////////////////////////////////////////////////////////
ConnectionInfo::~ConnectionInfo() {
}
////////////////////////////////////////////////////////////////////////////////
ConnectionInfo* ConnectionInfo::cloneDataStructure() const {
std::auto_ptr<ConnectionInfo> connectionInfo(new ConnectionInfo());
// Copy the data from the base class or classes
connectionInfo->copyDataStructure(this);
return connectionInfo.release();
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::copyDataStructure(const DataStructure* src) {
// Protect against invalid self assignment.
if (this == src) {
return;
}
const ConnectionInfo* srcPtr = dynamic_cast<const ConnectionInfo*>(src);
if (srcPtr == NULL || src == NULL) {
throw decaf::lang::exceptions::NullPointerException(
__FILE__, __LINE__,
"ConnectionInfo::copyDataStructure - src is NULL or invalid");
}
// Copy the data of the base class or classes
BaseCommand::copyDataStructure(src);
this->setConnectionId(srcPtr->getConnectionId());
this->setClientId(srcPtr->getClientId());
this->setPassword(srcPtr->getPassword());
this->setUserName(srcPtr->getUserName());
this->setBrokerPath(srcPtr->getBrokerPath());
this->setBrokerMasterConnector(srcPtr->isBrokerMasterConnector());
this->setManageable(srcPtr->isManageable());
this->setClientMaster(srcPtr->isClientMaster());
this->setFaultTolerant(srcPtr->isFaultTolerant());
this->setFailoverReconnect(srcPtr->isFailoverReconnect());
this->setClientIp(srcPtr->getClientIp());
}
////////////////////////////////////////////////////////////////////////////////
unsigned char ConnectionInfo::getDataStructureType() const {
return ConnectionInfo::ID_CONNECTIONINFO;
}
////////////////////////////////////////////////////////////////////////////////
std::string ConnectionInfo::toString() const {
ostringstream stream;
stream << "ConnectionInfo { "
<< "commandId = " << this->getCommandId() << ", "
<< "responseRequired = " << boolalpha << this->isResponseRequired();
stream << ", ";
stream << "ConnectionId = ";
if (this->getConnectionId() != NULL) {
stream << this->getConnectionId()->toString();
} else {
stream << "NULL";
}
stream << ", ";
stream << "ClientId = " << this->getClientId();
stream << ", ";
stream << "Password = " << this->getPassword();
stream << ", ";
stream << "UserName = " << this->getUserName();
stream << ", ";
stream << "BrokerPath = ";
if (this->getBrokerPath().size() > 0) {
stream << "[";
for (size_t ibrokerPath = 0; ibrokerPath < this->getBrokerPath().size(); ++ibrokerPath) {
if (this->getBrokerPath()[ibrokerPath] != NULL) {
stream << this->getBrokerPath()[ibrokerPath]->toString() << ", ";
} else {
stream << "NULL" << ", ";
}
}
stream << "]";
} else {
stream << "NULL";
}
stream << ", ";
stream << "BrokerMasterConnector = " << this->isBrokerMasterConnector();
stream << ", ";
stream << "Manageable = " << this->isManageable();
stream << ", ";
stream << "ClientMaster = " << this->isClientMaster();
stream << ", ";
stream << "FaultTolerant = " << this->isFaultTolerant();
stream << ", ";
stream << "FailoverReconnect = " << this->isFailoverReconnect();
stream << ", ";
stream << "ClientIp = " << this->getClientIp();
stream << " }";
return stream.str();
}
////////////////////////////////////////////////////////////////////////////////
bool ConnectionInfo::equals(const DataStructure* value) const {
if (this == value) {
return true;
}
const ConnectionInfo* valuePtr = dynamic_cast<const ConnectionInfo*>(value);
if (valuePtr == NULL || value == NULL) {
return false;
}
if (this->getConnectionId() != NULL) {
if (!this->getConnectionId()->equals(valuePtr->getConnectionId().get())) {
return false;
}
} else if (valuePtr->getConnectionId() != NULL) {
return false;
}
if (this->getClientId() != valuePtr->getClientId()) {
return false;
}
if (this->getPassword() != valuePtr->getPassword()) {
return false;
}
if (this->getUserName() != valuePtr->getUserName()) {
return false;
}
for (size_t ibrokerPath = 0; ibrokerPath < this->getBrokerPath().size(); ++ibrokerPath) {
if (this->getBrokerPath()[ibrokerPath] != NULL ) {
if (!this->getBrokerPath()[ibrokerPath]->equals(valuePtr->getBrokerPath()[ibrokerPath].get())) {
return false;
}
} else if (valuePtr->getBrokerPath()[ibrokerPath] != NULL) {
return false;
}
}
if (this->isBrokerMasterConnector() != valuePtr->isBrokerMasterConnector()) {
return false;
}
if (this->isManageable() != valuePtr->isManageable()) {
return false;
}
if (this->isClientMaster() != valuePtr->isClientMaster()) {
return false;
}
if (this->isFaultTolerant() != valuePtr->isFaultTolerant()) {
return false;
}
if (this->isFailoverReconnect() != valuePtr->isFailoverReconnect()) {
return false;
}
if (this->getClientIp() != valuePtr->getClientIp()) {
return false;
}
if (!BaseCommand::equals(value)) {
return false;
}
return true;
}
////////////////////////////////////////////////////////////////////////////////
const decaf::lang::Pointer<ConnectionId>& ConnectionInfo::getConnectionId() const {
return connectionId;
}
////////////////////////////////////////////////////////////////////////////////
decaf::lang::Pointer<ConnectionId>& ConnectionInfo::getConnectionId() {
return connectionId;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setConnectionId(const decaf::lang::Pointer<ConnectionId>& connectionId) {
this->connectionId = connectionId;
}
////////////////////////////////////////////////////////////////////////////////
const std::string& ConnectionInfo::getClientId() const {
return clientId;
}
////////////////////////////////////////////////////////////////////////////////
std::string& ConnectionInfo::getClientId() {
return clientId;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setClientId(const std::string& clientId) {
this->clientId = clientId;
}
////////////////////////////////////////////////////////////////////////////////
const std::string& ConnectionInfo::getPassword() const {
return password;
}
////////////////////////////////////////////////////////////////////////////////
std::string& ConnectionInfo::getPassword() {
return password;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setPassword(const std::string& password) {
this->password = password;
}
////////////////////////////////////////////////////////////////////////////////
const std::string& ConnectionInfo::getUserName() const {
return userName;
}
////////////////////////////////////////////////////////////////////////////////
std::string& ConnectionInfo::getUserName() {
return userName;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setUserName(const std::string& userName) {
this->userName = userName;
}
////////////////////////////////////////////////////////////////////////////////
const std::vector< decaf::lang::Pointer<BrokerId> >& ConnectionInfo::getBrokerPath() const {
return brokerPath;
}
////////////////////////////////////////////////////////////////////////////////
std::vector< decaf::lang::Pointer<BrokerId> >& ConnectionInfo::getBrokerPath() {
return brokerPath;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setBrokerPath(const std::vector< decaf::lang::Pointer<BrokerId> >& brokerPath) {
this->brokerPath = brokerPath;
}
////////////////////////////////////////////////////////////////////////////////
bool ConnectionInfo::isBrokerMasterConnector() const {
return brokerMasterConnector;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setBrokerMasterConnector(bool brokerMasterConnector) {
this->brokerMasterConnector = brokerMasterConnector;
}
////////////////////////////////////////////////////////////////////////////////
bool ConnectionInfo::isManageable() const {
return manageable;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setManageable(bool manageable) {
this->manageable = manageable;
}
////////////////////////////////////////////////////////////////////////////////
bool ConnectionInfo::isClientMaster() const {
return clientMaster;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setClientMaster(bool clientMaster) {
this->clientMaster = clientMaster;
}
////////////////////////////////////////////////////////////////////////////////
bool ConnectionInfo::isFaultTolerant() const {
return faultTolerant;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setFaultTolerant(bool faultTolerant) {
this->faultTolerant = faultTolerant;
}
////////////////////////////////////////////////////////////////////////////////
bool ConnectionInfo::isFailoverReconnect() const {
return failoverReconnect;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setFailoverReconnect(bool failoverReconnect) {
this->failoverReconnect = failoverReconnect;
}
////////////////////////////////////////////////////////////////////////////////
const std::string& ConnectionInfo::getClientIp() const {
return clientIp;
}
////////////////////////////////////////////////////////////////////////////////
std::string& ConnectionInfo::getClientIp() {
return clientIp;
}
////////////////////////////////////////////////////////////////////////////////
void ConnectionInfo::setClientIp(const std::string& clientIp) {
this->clientIp = clientIp;
}
////////////////////////////////////////////////////////////////////////////////
decaf::lang::Pointer<commands::Command> ConnectionInfo::visit(activemq::state::CommandVisitor* visitor) {
return visitor->processConnectionInfo(this);
}
////////////////////////////////////////////////////////////////////////////////
Pointer<RemoveInfo> ConnectionInfo::createRemoveCommand() const {
Pointer<RemoveInfo> info(new RemoveInfo());
info->setResponseRequired(this->isResponseRequired());
info->setObjectId(this->getConnectionId());
return info;
}