/* * 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 "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.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,""); ui.circleComboBox->loadCircles(GXS_CIRCLE_CHOOSER_EXTERNAL,""); ui.localComboBox->loadCircles(GXS_CIRCLE_CHOOSER_PERSONAL,""); 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::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() { 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())); 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!! } RsGxsGroupUpdateMeta updateMeta(mGrpMeta.mGroupId); if (!buildUpdateMeta(mGrpMeta, newMeta, updateMeta)) { /* error message */ QMessageBox::warning(this, "RetroShare", tr("Failed to Build UpdateMeta - Attempted to change field that is not allowed"), 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, updateMeta, 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::buildUpdateMeta( const RsGroupMetaData &origMeta, const RsGroupMetaData &newMeta, RsGxsGroupUpdateMeta &updateMeta) { /* check through the fields, and note which have changed */ if (origMeta.mGroupId != newMeta.mGroupId) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " GroupId Mismatch"; std::cerr << std::endl; return false; } if (origMeta.mGroupName != newMeta.mGroupName) { updateMeta.setMetaUpdate(RsGxsGroupUpdateMeta::NAME, newMeta.mGroupName); } // These are not allowed to be changed yet! bool metaOk = true; if (origMeta.mGroupFlags != newMeta.mGroupFlags) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " GroupFlags Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mSignFlags != newMeta.mSignFlags) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " SignFlags Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mAuthorId != newMeta.mAuthorId) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " AuthorId Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mAuthenFlags != newMeta.mAuthenFlags) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " AuthenFlags Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mParentGrpId != newMeta.mParentGrpId) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " ParentGrpId Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mCircleType != newMeta.mCircleType) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " CircleType Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mCircleId != newMeta.mCircleId) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " CircleId Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } if (origMeta.mInternalCircle != newMeta.mInternalCircle) { std::cerr << "GxsGroupDialog::buildUpdateMeta()"; std::cerr << " InternalCircle Differences - Not Allowed"; std::cerr << std::endl; metaOk = false; } return metaOk; } bool GxsGroupDialog::prepareGroupMetaData(RsGroupMetaData &meta) { std::cerr << "GxsGroupDialog::prepareGroupMetaData()"; std::cerr << std::endl; 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; } // 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; } std::cerr << "void GxsGroupDialog::prepareGroupMetaData() meta.mCircleType: "; std::cerr << meta.mCircleType << " Internal: " << meta.mInternalCircle; std::cerr << " External: " << meta.mCircleId; std::cerr << std::endl; ui.idChooser->getChosenId(meta.mAuthorId); 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 = "Internal Circle Id"; 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->document()->toPlainText(); } /*********************************************************************************** Share Lists. ***********************************************************************************/ void GxsGroupDialog::sendShareList(std::string groupId) { (void) 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; if (service_loadGroup(token, mMode, mGrpMeta)) { updateFromExistingMeta(); } } bool GxsGroupDialog::service_loadGroup(uint32_t token, Mode mode, RsGroupMetaData& groupMetaData) { (void) mode; (void) groupMetaData; std::cerr << "GxsGroupDialog::service_loadGroup(" << token << ") NOT IMPLEMENTED"; std::cerr << std::endl; return false; } 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; } } }