373 lines
12 KiB
C++
373 lines
12 KiB
C++
/**
|
|
* @file llfloaterperms.cpp
|
|
* @brief Asset creation permission preferences.
|
|
* @author Jonathan Yap
|
|
*
|
|
* $LicenseInfo:firstyear=2001&license=viewergpl$
|
|
*
|
|
* Copyright (c) 2001-2009, Linden Research, Inc.
|
|
*
|
|
* Second Life Viewer Source Code
|
|
* The source code in this file ("Source Code") is provided by Linden Lab
|
|
* to you under the terms of the GNU General Public License, version 2.0
|
|
* ("GPL"), unless you have obtained a separate licensing agreement
|
|
* ("Other License"), formally executed by you and Linden Lab. Terms of
|
|
* the GPL can be found in doc/GPL-license.txt in this distribution, or
|
|
* online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
|
|
*
|
|
* There are special exceptions to the terms and conditions of the GPL as
|
|
* it is applied to this Source Code. View the full text of the exception
|
|
* in the file doc/FLOSS-exception.txt in this software distribution, or
|
|
* online at
|
|
* http://secondlifegrid.net/programs/open_source/licensing/flossexception
|
|
*
|
|
* By copying, modifying or distributing this software, you acknowledge
|
|
* that you have read and understood your obligations described above,
|
|
* and agree to abide by those obligations.
|
|
*
|
|
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
|
|
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
|
|
* COMPLETENESS OR PERFORMANCE.
|
|
* $/LicenseInfo$
|
|
*/
|
|
|
|
#include "llviewerprecompiledheaders.h"
|
|
#include "lfsimfeaturehandler.h"
|
|
#include "llagent.h"
|
|
#include "llcheckboxctrl.h"
|
|
#include "llfloaterperms.h"
|
|
#include "llnotificationsutil.h"
|
|
#include "llviewercontrol.h"
|
|
#include "llviewerregion.h"
|
|
#include "llviewerwindow.h"
|
|
#include "lluictrlfactory.h"
|
|
#include "llpermissions.h"
|
|
#include "llsdserialize.h"
|
|
#include "hippogridmanager.h"
|
|
|
|
extern class AIHTTPTimeoutPolicy floaterPermsResponder_timeout;
|
|
|
|
//static
|
|
U32 LLFloaterPerms::getGroupPerms(std::string prefix)
|
|
{
|
|
return gSavedSettings.getBOOL(prefix+"ShareWithGroup") ? PERM_COPY | PERM_MOVE | PERM_MODIFY : PERM_NONE;
|
|
}
|
|
|
|
//static
|
|
U32 LLFloaterPerms::getEveryonePerms(std::string prefix)
|
|
{
|
|
U32 flags = PERM_NONE;
|
|
if (prefix != "Bulk" && LFSimFeatureHandler::instance().simSupportsExport() && prefix.empty() && gSavedPerAccountSettings.getBOOL(prefix+"EveryoneExport")) // Singu TODO: Bulk?
|
|
flags |= PERM_EXPORT;
|
|
if (gSavedSettings.getBOOL(prefix+"EveryoneCopy"))
|
|
flags |= PERM_COPY;
|
|
return flags;
|
|
}
|
|
|
|
//static
|
|
U32 LLFloaterPerms::getNextOwnerPerms(std::string prefix)
|
|
{
|
|
U32 flags = PERM_MOVE;
|
|
if ( gSavedSettings.getBOOL(prefix+"NextOwnerCopy") )
|
|
{
|
|
flags |= PERM_COPY;
|
|
}
|
|
if ( gSavedSettings.getBOOL(prefix+"NextOwnerModify") )
|
|
{
|
|
flags |= PERM_MODIFY;
|
|
}
|
|
if ( gSavedSettings.getBOOL(prefix+"NextOwnerTransfer") )
|
|
{
|
|
flags |= PERM_TRANSFER;
|
|
}
|
|
return flags;
|
|
}
|
|
|
|
//static
|
|
U32 LLFloaterPerms::getNextOwnerPermsInverted(std::string prefix)
|
|
{
|
|
// Sets bits for permissions that are off
|
|
U32 flags = PERM_MOVE;
|
|
if (!gSavedSettings.getBOOL(prefix+"NextOwnerCopy"))
|
|
{
|
|
flags |= PERM_COPY;
|
|
}
|
|
if (!gSavedSettings.getBOOL(prefix+"NextOwnerModify"))
|
|
{
|
|
flags |= PERM_MODIFY;
|
|
}
|
|
if (!gSavedSettings.getBOOL(prefix+"NextOwnerTransfer"))
|
|
{
|
|
flags |= PERM_TRANSFER;
|
|
}
|
|
return flags;
|
|
}
|
|
|
|
namespace
|
|
{
|
|
void handle_checkboxes(LLView* view, const std::string& ctrl_name, const LLSD& value, const std::string& type)
|
|
{
|
|
if (ctrl_name == type+"everyone_export")
|
|
{
|
|
view->getChildView(type+"next_owner_copy")->setEnabled(!value);
|
|
view->getChildView(type+"next_owner_modify")->setEnabled(!value);
|
|
view->getChildView(type+"next_owner_transfer")->setEnabled(!value);
|
|
}
|
|
else
|
|
{
|
|
if (ctrl_name == type+"next_owner_copy")
|
|
{
|
|
if (!value) // Implements fair use
|
|
gSavedSettings.setBOOL(type+"NextOwnerTransfer", true);
|
|
view->getChildView(type+"next_owner_transfer")->setEnabled(value);
|
|
}
|
|
if (!value) // If any of these are unchecked, export can no longer be checked.
|
|
view->getChildView(type+"everyone_export")->setEnabled(false);
|
|
else
|
|
view->getChildView(type+"everyone_export")->setEnabled(LFSimFeatureHandler::instance().simSupportsExport() && (LLFloaterPerms::getNextOwnerPerms(type) & PERM_ITEM_UNRESTRICTED) == PERM_ITEM_UNRESTRICTED);
|
|
}
|
|
}
|
|
}
|
|
|
|
static bool mCapSent = false;
|
|
|
|
LLFloaterPermsDefault::LLFloaterPermsDefault(const LLSD& seed)
|
|
: LLFloater()
|
|
{
|
|
mCommitCallbackRegistrar.add("PermsDefault.OK", boost::bind(&LLFloaterPermsDefault::onClickOK, this));
|
|
mCommitCallbackRegistrar.add("PermsDefault.Cancel", boost::bind(&LLFloaterPermsDefault::onClickCancel, this));
|
|
LLUICtrlFactory::getInstance()->buildFloater(this, "floater_perm_prefs.xml");
|
|
}
|
|
|
|
|
|
// String equivalents of enum Categories - initialization order must match enum order!
|
|
const std::string LLFloaterPermsDefault::sCategoryNames[CAT_LAST] =
|
|
{
|
|
"Objects",
|
|
"Uploads",
|
|
"Scripts",
|
|
"Notecards",
|
|
"Gestures",
|
|
"Wearables"
|
|
};
|
|
|
|
void LLFloaterPermsDefault::initCheckboxes(bool export_support, const std::string& type)
|
|
{
|
|
const U32 next_owner_perms = LLFloaterPerms::getNextOwnerPerms(type);
|
|
getChildView(type + "everyone_export")->setEnabled(export_support && (next_owner_perms & PERM_ITEM_UNRESTRICTED) == PERM_ITEM_UNRESTRICTED);
|
|
|
|
if (!(next_owner_perms & PERM_COPY))
|
|
{
|
|
getChildView(type + "next_owner_transfer")->setEnabled(false);
|
|
}
|
|
else if (export_support)
|
|
{
|
|
bool export_off = !gSavedPerAccountSettings.getBOOL(type+"EveryoneExport");
|
|
getChildView(type + "next_owner_copy")->setEnabled(export_off);
|
|
getChildView(type + "next_owner_modify")->setEnabled(export_off);
|
|
getChildView(type + "next_owner_transfer")->setEnabled(export_off);
|
|
}
|
|
else // Set type+EveryoneExport false, just in case.
|
|
gSavedPerAccountSettings.setBOOL(type+"EveryoneExport", false);
|
|
}
|
|
|
|
BOOL LLFloaterPermsDefault::postBuild()
|
|
{
|
|
//handle_checkboxes
|
|
bool export_support = LFSimFeatureHandler::instance().simSupportsExport();
|
|
bool is_sl = gHippoGridManager->getCurrentGrid()->isSecondLife();
|
|
for (S32 i = 0; i < CAT_LAST; ++i)
|
|
{
|
|
const std::string& type(sCategoryNames[i]);
|
|
initCheckboxes(export_support, type);
|
|
commit_callback_t handle_checks(boost::bind(handle_checkboxes, this, boost::bind(&LLView::getName, _1), _2, type));
|
|
getChild<LLUICtrl>(type + "next_owner_copy")->setCommitCallback(handle_checks);
|
|
getChild<LLUICtrl>(type + "next_owner_modify")->setCommitCallback(handle_checks);
|
|
getChild<LLUICtrl>(type + "next_owner_transfer")->setCommitCallback(handle_checks);
|
|
if (is_sl)
|
|
getChildView(type + "everyone_export")->setVisible(false);
|
|
else
|
|
getChild<LLUICtrl>(type + "everyone_export")->setCommitCallback(handle_checks);
|
|
}
|
|
if (is_sl)
|
|
{
|
|
LLView* view(getChildView("ExportationLabel"));
|
|
S32 shift(view->getRect().getWidth()); // Determine size of export area
|
|
LLRect rect(getRect());
|
|
rect.mRight -= shift;
|
|
setRect(rect); // Cut off the export side
|
|
view->setVisible(false); // Hide label
|
|
// Move bottom buttons over so they look nice.
|
|
shift /= -2;
|
|
view = getChildView("ok");
|
|
rect = view->getRect();
|
|
rect.translate(shift, 0);
|
|
view->setRect(rect);
|
|
view = getChildView("cancel");
|
|
rect = view->getRect();
|
|
rect.translate(shift, 0);
|
|
view->setRect(rect);
|
|
}
|
|
|
|
refresh();
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
void LLFloaterPermsDefault::onClickOK()
|
|
{
|
|
ok();
|
|
close();
|
|
}
|
|
|
|
void LLFloaterPermsDefault::onClickCancel()
|
|
{
|
|
cancel();
|
|
close();
|
|
}
|
|
|
|
struct LLFloaterPermsRequester final : LLSingleton<LLFloaterPermsRequester>
|
|
{
|
|
friend class LLSingleton<LLFloaterPermsRequester>;
|
|
std::string mUrl;
|
|
LLSD mReport;
|
|
U8 mRetriesCount = 0;
|
|
static void init(const std::string url, const LLSD report)
|
|
{
|
|
auto& inst = instance();
|
|
inst.mUrl = url;
|
|
inst.mReport = report;
|
|
inst.retry();
|
|
}
|
|
bool retry();
|
|
};
|
|
|
|
class LLFloaterPermsResponder final : public LLHTTPClient::ResponderWithResult
|
|
{
|
|
static std::string sPreviousReason;
|
|
|
|
void httpFailure() override
|
|
{
|
|
auto* requester = LLFloaterPermsRequester::getIfExists();
|
|
if (!requester || requester->retry()) return;
|
|
|
|
LLFloaterPermsRequester::deleteSingleton();
|
|
const std::string& reason = getReason();
|
|
// Do not display the same error more than once in a row
|
|
if (reason != sPreviousReason)
|
|
{
|
|
sPreviousReason = reason;
|
|
LLSD args;
|
|
args["REASON"] = reason;
|
|
LLNotificationsUtil::add("DefaultObjectPermissions", args);
|
|
}
|
|
}
|
|
void httpSuccess() override
|
|
{
|
|
//const LLSD& content = getContent();
|
|
//dump_sequential_xml("perms_responder_result.xml", content);
|
|
|
|
// Since we have had a successful POST call be sure to display the next error message
|
|
// even if it is the same as a previous one.
|
|
sPreviousReason = "";
|
|
LL_INFOS("ObjectPermissionsFloater") << "Default permissions successfully sent to simulator" << LL_ENDL;
|
|
}
|
|
AIHTTPTimeoutPolicy const& getHTTPTimeoutPolicy() const override { return floaterPermsResponder_timeout; }
|
|
char const* getName() const override { return "LLFloaterPermsResponder"; }
|
|
};
|
|
|
|
bool LLFloaterPermsRequester::retry()
|
|
{
|
|
if (++mRetriesCount < 5)
|
|
{
|
|
LLHTTPClient::post(mUrl, mReport, new LLFloaterPermsResponder);
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
std::string LLFloaterPermsResponder::sPreviousReason;
|
|
|
|
void LLFloaterPermsDefault::sendInitialPerms()
|
|
{
|
|
if (!mCapSent)
|
|
{
|
|
updateCap();
|
|
mCapSent = true;
|
|
}
|
|
}
|
|
|
|
void LLFloaterPermsDefault::updateCap()
|
|
{
|
|
std::string object_url = gAgent.getRegionCapability("AgentPreferences");
|
|
|
|
if (!object_url.empty())
|
|
{
|
|
LLSD report = LLSD::emptyMap();
|
|
report["default_object_perm_masks"]["Group"] =
|
|
(LLSD::Integer)LLFloaterPerms::getGroupPerms(sCategoryNames[CAT_OBJECTS]);
|
|
report["default_object_perm_masks"]["Everyone"] =
|
|
(LLSD::Integer)LLFloaterPerms::getEveryonePerms(sCategoryNames[CAT_OBJECTS]);
|
|
report["default_object_perm_masks"]["NextOwner"] =
|
|
(LLSD::Integer)LLFloaterPerms::getNextOwnerPerms(sCategoryNames[CAT_OBJECTS]);
|
|
|
|
{
|
|
std::ostringstream sent_perms_log;
|
|
LLSDSerialize::toPrettyXML(report, sent_perms_log);
|
|
LL_DEBUGS("ObjectPermissionsFloater") << "Sending default permissions to '"
|
|
<< object_url << "'\n"
|
|
<< sent_perms_log.str() << LL_ENDL;
|
|
}
|
|
LLFloaterPermsRequester::init(object_url, report);
|
|
}
|
|
else
|
|
{
|
|
LL_DEBUGS("ObjectPermissionsFloater") << "AgentPreferences cap not available." << LL_ENDL;
|
|
}
|
|
}
|
|
|
|
void LLFloaterPermsDefault::ok()
|
|
{
|
|
// Changes were already applied automatically to saved settings.
|
|
// Refreshing internal values makes it official.
|
|
refresh();
|
|
|
|
// We know some setting has changed but not which one. Just in case it was a setting for
|
|
// object permissions tell the server what the values are.
|
|
updateCap();
|
|
}
|
|
|
|
void LLFloaterPermsDefault::cancel()
|
|
{
|
|
for (U32 iter = CAT_OBJECTS; iter < CAT_LAST; iter++)
|
|
{
|
|
gSavedSettings.setBOOL(sCategoryNames[iter]+"NextOwnerCopy", mNextOwnerCopy[iter]);
|
|
gSavedSettings.setBOOL(sCategoryNames[iter]+"NextOwnerModify", mNextOwnerModify[iter]);
|
|
gSavedSettings.setBOOL(sCategoryNames[iter]+"NextOwnerTransfer", mNextOwnerTransfer[iter]);
|
|
gSavedSettings.setBOOL(sCategoryNames[iter]+"ShareWithGroup", mShareWithGroup[iter]);
|
|
gSavedSettings.setBOOL(sCategoryNames[iter]+"EveryoneCopy", mEveryoneCopy[iter]);
|
|
gSavedPerAccountSettings.setBOOL(sCategoryNames[iter]+"EveryoneExport", mEveryoneExport[iter]);
|
|
}
|
|
}
|
|
|
|
void LLFloaterPermsDefault::refresh()
|
|
{
|
|
for (U32 iter = CAT_OBJECTS; iter < CAT_LAST; iter++)
|
|
{
|
|
mShareWithGroup[iter] = gSavedSettings.getBOOL(sCategoryNames[iter]+"ShareWithGroup");
|
|
mEveryoneCopy[iter] = gSavedSettings.getBOOL(sCategoryNames[iter]+"EveryoneCopy");
|
|
mNextOwnerCopy[iter] = gSavedSettings.getBOOL(sCategoryNames[iter]+"NextOwnerCopy");
|
|
mNextOwnerModify[iter] = gSavedSettings.getBOOL(sCategoryNames[iter]+"NextOwnerModify");
|
|
mNextOwnerTransfer[iter] = gSavedSettings.getBOOL(sCategoryNames[iter]+"NextOwnerTransfer");
|
|
mEveryoneExport[iter] = gSavedPerAccountSettings.getBOOL(sCategoryNames[iter]+"EveryoneExport");
|
|
}
|
|
}
|
|
|
|
void LLFloaterPermsDefault::onClose(bool app_quitting)
|
|
{
|
|
// Cancel any unsaved changes before closing.
|
|
// Note: when closed due to the OK button this amounts to a no-op.
|
|
cancel();
|
|
LLFloater::onClose(app_quitting);
|
|
}
|