/* * Retroshare Gxs Support * * Copyright 2012-2013 by Robert Fernie. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License Version 2.1 as published by the Free Software Foundation. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA. * * Please report all bugs and problems to "retroshare@lunamutt.com". * */ #include #include "util/misc.h" #include "GxsGroupDialog.h" #include "gui/common/PeerDefs.h" #include "gui/Identity/IdDialog.h" #include "retroshare/rsgxsflags.h" #include #include #include #include // Control of Publish Signatures. #define RSGXS_GROUP_SIGN_PUBLISH_MASK 0x000000ff #define RSGXS_GROUP_SIGN_PUBLISH_ENCRYPTED 0x00000001 #define RSGXS_GROUP_SIGN_PUBLISH_ALLSIGNED 0x00000002 #define RSGXS_GROUP_SIGN_PUBLISH_THREADHEAD 0x00000004 #define RSGXS_GROUP_SIGN_PUBLISH_NONEREQ 0x00000008 // Author Signature. #define RSGXS_GROUP_SIGN_AUTHOR_MASK 0x0000ff00 #define RSGXS_GROUP_SIGN_AUTHOR_GPG 0x00000100 #define RSGXS_GROUP_SIGN_AUTHOR_REQUIRED 0x00000200 #define RSGXS_GROUP_SIGN_AUTHOR_IFNOPUBSIGN 0x00000400 #define RSGXS_GROUP_SIGN_AUTHOR_NONE 0x00000800 #define GXSGROUP_NEWGROUPID 1 #define GXSGROUP_LOADGROUP 2 #define GXSGROUP_INTERNAL_LOADGROUP 3 /** Constructor */ GxsGroupDialog::GxsGroupDialog(TokenQueue *tokenExternalQueue, uint32_t enableFlags, uint32_t defaultFlags, QWidget *parent) : QDialog(parent, Qt::WindowSystemMenuHint | Qt::WindowTitleHint | Qt::WindowCloseButtonHint), mTokenService(NULL), mExternalTokenQueue(tokenExternalQueue), mInternalTokenQueue(NULL), mGrpMeta(), mMode(MODE_CREATE), mEnabledFlags(enableFlags), mReadonlyFlags(0), mDefaultsFlags(defaultFlags) { /* Invoke the Qt Designer generated object setup routine */ ui.setupUi(this); mInternalTokenQueue = NULL; init(); } GxsGroupDialog::GxsGroupDialog(TokenQueue *tokenExternalQueue, RsTokenService *tokenService, Mode mode, RsGxsGroupId groupId, uint32_t enableFlags, uint32_t defaultFlags, QWidget *parent) : QDialog(parent, Qt::WindowSystemMenuHint | Qt::WindowTitleHint | Qt::WindowCloseButtonHint), mTokenService(NULL), mExternalTokenQueue(tokenExternalQueue), mInternalTokenQueue(NULL), mGrpMeta(), mMode(mode), mEnabledFlags(enableFlags), mReadonlyFlags(0), mDefaultsFlags(defaultFlags) { /* Invoke the Qt Designer generated object setup routine */ ui.setupUi(this); mTokenService = tokenService; mInternalTokenQueue = new TokenQueue(tokenService, this); mGrpMeta.mGroupId = groupId; init(); } void GxsGroupDialog::init() { // connect up the buttons. connect( ui.buttonBox, SIGNAL(accepted()), this, SLOT(submitGroup())); connect( ui.buttonBox, SIGNAL(rejected()), this, SLOT(cancelDialog())); connect( ui.pubKeyShare_cb, SIGNAL( clicked() ), this, SLOT( setShareList( ) )); connect( ui.toolButton_NewId, SIGNAL(clicked()), this, SLOT(createNewGxsId())); connect( ui.groupLogo, SIGNAL(clicked() ), this , SLOT(addGroupLogo())); connect( ui.addLogoButton, SIGNAL(clicked() ), this , SLOT(addGroupLogo())); ui.typePublic->setChecked(true); updateCircleOptions(); connect( ui.typePublic, SIGNAL(clicked()), this , SLOT(updateCircleOptions())); connect( ui.typeGroup, SIGNAL(clicked()), this , SLOT(updateCircleOptions())); connect( ui.typeLocal, SIGNAL(clicked()), this , SLOT(updateCircleOptions())); if (!ui.pubKeyShare_cb->isChecked()) { ui.contactsdockWidget->hide(); this->resize(this->size().width() - ui.contactsdockWidget->size().width(), this->size().height()); } /* initialize key share list */ ui.keyShareList->setHeaderText(tr("Contacts:")); ui.keyShareList->setModus(FriendSelectionWidget::MODUS_CHECK); ui.keyShareList->start(); /* Setup Reasonable Defaults */ ui.idChooser->loadIds(0,RsGxsId()); ui.circleComboBox->loadCircles(GXS_CIRCLE_CHOOSER_EXTERNAL,RsGxsCircleId()); ui.localComboBox->loadCircles(GXS_CIRCLE_CHOOSER_PERSONAL,RsGxsCircleId()); initMode(); } void GxsGroupDialog::showEvent(QShowEvent*) { ui.headerFrame->setHeaderImage(serviceImage()); initUi(); } void GxsGroupDialog::setUiText(UiType uiType, const QString &text) { switch (uiType) { case UITYPE_SERVICE_HEADER: setWindowTitle(text); ui.headerFrame->setHeaderText(text); break; case UITYPE_KEY_SHARE_CHECKBOX: ui.pubKeyShare_cb->setText(text); break; case UITYPE_CONTACTS_DOCK: ui.contactsdockWidget->setWindowTitle(text); break; case UITYPE_BUTTONBOX_OK: ui.buttonBox->button(QDialogButtonBox::Ok)->setText(text); break; } } void GxsGroupDialog::initMode() { setAllReadonly(); switch (mode()) { case MODE_CREATE: { ui.buttonBox->setStandardButtons(QDialogButtonBox::Ok | QDialogButtonBox::Cancel); ui.buttonBox->button(QDialogButtonBox::Ok)->setText(tr("Create Forum")); newGroup(); } break; case MODE_SHOW: { mReadonlyFlags = 0xffffffff; // Force all to readonly. ui.buttonBox->setStandardButtons(QDialogButtonBox::Close); requestGroup(mGrpMeta.mGroupId); } break; case MODE_EDIT: { ui.buttonBox->setStandardButtons(QDialogButtonBox::Ok | QDialogButtonBox::Cancel); ui.buttonBox->button(QDialogButtonBox::Ok)->setText(tr("Submit Group Changes")); requestGroup(mGrpMeta.mGroupId); } break; } } void GxsGroupDialog::createNewGxsId() { IdEditDialog dlg(this); dlg.setupNewId(false); dlg.exec(); ui.idChooser->setDefaultId(dlg.getLastIdName()); } void GxsGroupDialog::clearForm() { ui.groupName->clear(); ui.groupDesc->clear(); ui.groupName->setFocus(); } void GxsGroupDialog::setupDefaults() { /* Enable / Show Parts based on Flags */ if (mDefaultsFlags & GXS_GROUP_DEFAULTS_DISTRIB_MASK) { if (mDefaultsFlags & GXS_GROUP_DEFAULTS_DISTRIB_PUBLIC) { ui.typePublic->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_DISTRIB_GROUP) { ui.typeGroup->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_DISTRIB_LOCAL) { ui.typeLocal->setChecked(true); } else { // default ui.typePublic->setChecked(true); } } if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PUBLISH_MASK) { if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PUBLISH_ENCRYPTED) { ui.publish_encrypt->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PUBLISH_REQUIRED) { ui.publish_required->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PUBLISH_THREADS) { ui.publish_threads->setChecked(true); } else { // default ui.publish_open->setChecked(true); } } if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PERSONAL_MASK) { if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PERSONAL_PGP) { ui.personal_pgp->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PERSONAL_REQUIRED) { ui.personal_required->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_PERSONAL_IFNOPUB) { ui.personal_ifnopub->setChecked(true); } else { // default ui.personal_ifnopub->setChecked(true); } } if (mDefaultsFlags & GXS_GROUP_DEFAULTS_COMMENTS_MASK) { if (mDefaultsFlags & GXS_GROUP_DEFAULTS_COMMENTS_YES) { ui.comments_allowed->setChecked(true); } else if (mDefaultsFlags & GXS_GROUP_DEFAULTS_COMMENTS_NO) { ui.comments_no->setChecked(true); } else { // default ui.comments_no->setChecked(true); } } } void GxsGroupDialog::setupVisibility() { ui.groupName->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_NAME); ui.groupLogo->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_ICON); ui.addLogoButton->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_ICON); ui.groupDesc->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_DESCRIPTION); ui.groupDescLabel->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_DESCRIPTION); ui.distribGroupBox->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_DISTRIBUTION); ui.publishGroupBox->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_PUBLISHSIGN); ui.pubKeyShare_cb->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_SHAREKEYS); ui.personalGroupBox->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_PERSONALSIGN); ui.commentGroupBox->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS); ui.extraFrame->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_EXTRA); } void GxsGroupDialog::setAllReadonly() { uint32_t origReadonlyFlags = mReadonlyFlags; mReadonlyFlags = 0xffffffff; setupReadonly(); mReadonlyFlags = origReadonlyFlags; } void GxsGroupDialog::setupReadonly() { ui.groupName->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_NAME)); ui.groupLogo->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_ICON)); ui.addLogoButton->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_ICON)); ui.groupDesc->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_DESCRIPTION)); ui.groupDescLabel->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_DESCRIPTION)); ui.distribGroupBox->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_DISTRIBUTION)); ui.publishGroupBox->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_PUBLISHSIGN)); ui.pubKeyShare_cb->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_SHAREKEYS)); ui.personalGroupBox->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_PERSONALSIGN)); ui.idChooser->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_PERSONALSIGN)); ui.commentGroupBox->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_COMMENTS)); ui.extraFrame->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_EXTRA)); } void GxsGroupDialog::newGroup() { setupDefaults(); setupVisibility(); setupReadonly(); clearForm(); } void GxsGroupDialog::updateFromExistingMeta(const QString &description) { std::cerr << "void GxsGroupDialog::updateFromExistingMeta()"; std::cerr << std::endl; std::cerr << "void GxsGroupDialog::updateFromExistingMeta() mGrpMeta.mCircleType: "; std::cerr << mGrpMeta.mCircleType << " Internal: " << mGrpMeta.mInternalCircle; std::cerr << " External: " << mGrpMeta.mCircleId; std::cerr << std::endl; setupDefaults(); setupVisibility(); setupReadonly(); clearForm(); /* setup name */ ui.groupName->setText(QString::fromUtf8(mGrpMeta.mGroupName.c_str())); /* set description */ ui.groupDesc->setPlainText(description); switch(mGrpMeta.mCircleType) { case GXS_CIRCLE_TYPE_YOUREYESONLY: ui.typeLocal->setChecked(true); ui.localComboBox->loadCircles(GXS_CIRCLE_CHOOSER_PERSONAL, mGrpMeta.mInternalCircle); break; case GXS_CIRCLE_TYPE_PUBLIC: ui.typePublic->setChecked(true); break; case GXS_CIRCLE_TYPE_EXTERNAL: ui.typeGroup->setChecked(true); ui.circleComboBox->loadCircles(GXS_CIRCLE_CHOOSER_EXTERNAL, mGrpMeta.mCircleId); break; default: std::cerr << "CreateCircleDialog::updateCircleGUI() INVALID mCircleType"; std::cerr << std::endl; break; } ui.idChooser->loadIds(0, mGrpMeta.mAuthorId); updateCircleOptions(); } void GxsGroupDialog::submitGroup() { std::cerr << "GxsGroupDialog::submitGroup()"; std::cerr << std::endl; /* switch depending on mode */ switch (mode()) { case MODE_CREATE: { /* just close if down */ createGroup(); } break; case MODE_SHOW: { /* just close if down */ cancelDialog(); } break; case MODE_EDIT: { editGroup(); } break; } } void GxsGroupDialog::editGroup() { std::cerr << "GxsGroupDialog::editGroup()" << std::endl; RsGroupMetaData newMeta; newMeta.mGroupId = mGrpMeta.mGroupId; if(!prepareGroupMetaData(newMeta)) { /* error message */ QMessageBox::warning(this, "RetroShare", tr("Failed to Prepare Group MetaData - please Review"), QMessageBox::Ok, QMessageBox::Ok); return; //Don't add a empty name!! } std::cerr << "GxsGroupDialog::editGroup() calling service_EditGroup"; std::cerr << std::endl; uint32_t token; if (service_EditGroup(token, newMeta)) { // get the Queue to handle response. if(mExternalTokenQueue != NULL) mExternalTokenQueue->queueRequest(token, TOKENREQ_GROUPINFO, RS_TOKREQ_ANSTYPE_ACK, GXSGROUP_NEWGROUPID); } else { std::cerr << "GxsGroupDialog::editGroup() ERROR"; std::cerr << std::endl; } close(); } bool GxsGroupDialog::prepareGroupMetaData(RsGroupMetaData &meta) { std::cerr << "GxsGroupDialog::prepareGroupMetaData()"; std::cerr << std::endl; switch (ui.idChooser->getChosenId(meta.mAuthorId)) { case GxsIdChooser::KnowId: case GxsIdChooser::UnKnowId: break; case GxsIdChooser::NoId: case GxsIdChooser::None: default: return false; }//switch (ui.idChooser->getChosenId(meta.mAuthorId)) QString name = misc::removeNewLine(ui.groupName->text()); uint32_t flags = GXS_SERV::FLAG_PRIVACY_PUBLIC; if(name.isEmpty()) { std::cerr << "GxsGroupDialog::prepareGroupMetaData()"; std::cerr << " Invalid GroupName"; std::cerr << std::endl; return false; }//if(name.isEmpty()) // Fill in the MetaData as best we can. meta.mGroupName = std::string(name.toUtf8()); meta.mGroupFlags = flags; meta.mSignFlags = getGroupSignFlags(); if (!setCircleParameters(meta)){ std::cerr << "GxsGroupDialog::prepareGroupMetaData()"; std::cerr << " Invalid Circles"; std::cerr << std::endl; return false; }//if (!setCircleParameters(meta)) std::cerr << "void GxsGroupDialog::prepareGroupMetaData() meta.mCircleType: "; std::cerr << meta.mCircleType << " Internal: " << meta.mInternalCircle; std::cerr << " External: " << meta.mCircleId; std::cerr << std::endl; return true; } void GxsGroupDialog::createGroup() { std::cerr << "GxsGroupDialog::createGroup()"; std::cerr << std::endl; QString name = misc::removeNewLine(ui.groupName->text()); if(name.isEmpty()) { /* error message */ QMessageBox::warning(this, "RetroShare", tr("Please add a Name"), QMessageBox::Ok, QMessageBox::Ok); return; //Don't add a empty name!! } uint32_t token; RsGroupMetaData meta; if (!prepareGroupMetaData(meta)) { /* error message */ QMessageBox::warning(this, "RetroShare", tr("Failed to Prepare Group MetaData - please Review"), QMessageBox::Ok, QMessageBox::Ok); return; //Don't add with invalid circle. } if (service_CreateGroup(token, meta)) { // get the Queue to handle response. if(mExternalTokenQueue != NULL) mExternalTokenQueue->queueRequest(token, TOKENREQ_GROUPINFO, RS_TOKREQ_ANSTYPE_ACK, GXSGROUP_NEWGROUPID); } close(); } uint32_t GxsGroupDialog::getGroupSignFlags() { /* grab from the ui options -> */ uint32_t signFlags = 0; if (ui.publish_encrypt->isChecked()) { signFlags |= RSGXS_GROUP_SIGN_PUBLISH_ENCRYPTED; } else if (ui.publish_required->isChecked()) { signFlags |= RSGXS_GROUP_SIGN_PUBLISH_ALLSIGNED; } else if (ui.publish_threads->isChecked()) { signFlags |= RSGXS_GROUP_SIGN_PUBLISH_THREADHEAD; } else { // publish_open (default). signFlags |= RSGXS_GROUP_SIGN_PUBLISH_NONEREQ; } // Author Signature. if (ui.personal_pgp->isChecked()) { signFlags |= RSGXS_GROUP_SIGN_AUTHOR_GPG; } else if (ui.personal_required->isChecked()) { signFlags |= RSGXS_GROUP_SIGN_AUTHOR_REQUIRED; } else if (ui.personal_ifnopub->isChecked()) { signFlags |= RSGXS_GROUP_SIGN_AUTHOR_IFNOPUBSIGN; } else { // shouldn't allow this one. signFlags |= RSGXS_GROUP_SIGN_AUTHOR_NONE; } return signFlags; } void GxsGroupDialog::setGroupSignFlags(uint32_t signFlags) { if (signFlags & RSGXS_GROUP_SIGN_PUBLISH_ENCRYPTED) { ui.publish_encrypt->setChecked(true); } else if (signFlags & RSGXS_GROUP_SIGN_PUBLISH_ALLSIGNED) { ui.publish_required->setChecked(true); } else if (signFlags & RSGXS_GROUP_SIGN_PUBLISH_THREADHEAD) { ui.publish_threads->setChecked(true); } else if (signFlags & RSGXS_GROUP_SIGN_PUBLISH_NONEREQ) { ui.publish_open->setChecked(true); } if (signFlags & RSGXS_GROUP_SIGN_AUTHOR_GPG) { ui.personal_pgp->setChecked(true); } else if (signFlags & RSGXS_GROUP_SIGN_AUTHOR_REQUIRED) { ui.personal_required->setChecked(true); } else if (signFlags & RSGXS_GROUP_SIGN_AUTHOR_IFNOPUBSIGN) { ui.personal_ifnopub->setChecked(true); } else if (signFlags & RSGXS_GROUP_SIGN_AUTHOR_NONE) { // Its the same... but not quite. //ui.personal_noifpub->setChecked(); } /* guess at comments */ if ((signFlags & RSGXS_GROUP_SIGN_PUBLISH_THREADHEAD) && (signFlags & RSGXS_GROUP_SIGN_AUTHOR_IFNOPUBSIGN)) { ui.comments_allowed->setChecked(true); } else { ui.comments_no->setChecked(true); } } /**** Above logic is flawed, and will be removed shortly * * ****/ void GxsGroupDialog::updateCircleOptions() { if (ui.typeGroup->isChecked()) { ui.circleComboBox->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_DISTRIBUTION)); ui.circleComboBox->setVisible(true); } else { ui.circleComboBox->setEnabled(false); ui.circleComboBox->setVisible(false); } if (ui.typeLocal->isChecked()) { ui.localComboBox->setEnabled(!(mReadonlyFlags & GXS_GROUP_FLAGS_DISTRIBUTION)); ui.localComboBox->setVisible(true); } else { ui.localComboBox->setEnabled(false); ui.localComboBox->setVisible(false); } } bool GxsGroupDialog::setCircleParameters(RsGroupMetaData &meta) { meta.mCircleType = GXS_CIRCLE_TYPE_PUBLIC; meta.mCircleId.clear(); meta.mOriginator.clear(); meta.mInternalCircle.clear(); if (ui.typePublic->isChecked()) { meta.mCircleType = GXS_CIRCLE_TYPE_PUBLIC; meta.mCircleId.clear(); } else if (ui.typeGroup->isChecked()) { meta.mCircleType = GXS_CIRCLE_TYPE_EXTERNAL; if (!ui.circleComboBox->getChosenCircle(meta.mCircleId)) { return false; } } else if (ui.typeLocal->isChecked()) { meta.mCircleType = GXS_CIRCLE_TYPE_YOUREYESONLY; meta.mCircleId.clear(); meta.mOriginator.clear(); meta.mInternalCircle.clear() ; if (!ui.localComboBox->getChosenCircle(meta.mInternalCircle)) { return false; } } else { return false; } return true; } void GxsGroupDialog::cancelDialog() { std::cerr << "GxsGroupDialog::cancelDialog() Should Close!"; std::cerr << std::endl; close(); } void GxsGroupDialog::addGroupLogo() { QPixmap img = misc::getOpenThumbnailedPicture(this, tr("Load Group Logo"), 64, 64); if (img.isNull()) return; picture = img; // to show the selected ui.groupLogo->setPixmap(picture); } QPixmap GxsGroupDialog::getLogo() { return picture; } QString GxsGroupDialog::getDescription() { return ui.groupDesc->toPlainText(); } /*********************************************************************************** Share Lists. ***********************************************************************************/ void GxsGroupDialog::sendShareList(std::string /*groupId*/) { close(); } void GxsGroupDialog::setShareList() { if (ui.pubKeyShare_cb->isChecked()){ this->resize(this->size().width() + ui.contactsdockWidget->size().width(), this->size().height()); ui.contactsdockWidget->show(); } else { // hide share widget ui.contactsdockWidget->hide(); this->resize(this->size().width() - ui.contactsdockWidget->size().width(), this->size().height()); } } /*********************************************************************************** Loading Group. ***********************************************************************************/ void GxsGroupDialog::requestGroup(const RsGxsGroupId &groupId) { RsTokReqOptions opts; opts.mReqType = GXS_REQUEST_TYPE_GROUP_DATA; std::list groupIds; groupIds.push_back(groupId); std::cerr << "GxsGroupDialog::requestGroup() Requesting Group Summary(" << groupId << ")"; std::cerr << std::endl; uint32_t token; mInternalTokenQueue->requestGroupInfo(token, RS_TOKREQ_ANSTYPE_DATA, opts, groupIds, GXSGROUP_INTERNAL_LOADGROUP); } void GxsGroupDialog::loadGroup(uint32_t token) { std::cerr << "GxsGroupDialog::loadGroup(" << token << ")"; std::cerr << std::endl; QString description; if (service_loadGroup(token, mMode, mGrpMeta, description)) { updateFromExistingMeta(description); } } void GxsGroupDialog::loadRequest(const TokenQueue *queue, const TokenRequest &req) { std::cerr << "GxsGroupDialog::loadRequest() UserType: " << req.mUserType; std::cerr << std::endl; if (queue == mInternalTokenQueue) { /* now switch on req */ switch(req.mUserType) { case GXSGROUP_INTERNAL_LOADGROUP: loadGroup(req.mToken); break; default: std::cerr << "GxsGroupDialog::loadGroup() UNKNOWN UserType "; std::cerr << std::endl; break; } } }