* Updates BetaGridLikeMoneyModule
* Several people have asked for a way to limit uploads, so I've decided to show people how to do this in the BetaGridLikeMoneyModule. * Configure it in OpenSim.ini using the [Economy] header. See the bottom of the OpenSim.ini.example for more information. * This also fleshes out the Economy API a bit more.0.6.0-stable
parent
b85624db18
commit
06967e230f
|
@ -430,6 +430,8 @@ namespace OpenSim.Framework
|
|||
|
||||
public delegate void ObjectPermissions(IClientAPI controller, LLUUID agentID, LLUUID sessionID, byte field, uint localId, uint mask, byte set);
|
||||
|
||||
public delegate void EconomyDataRequest(LLUUID agentID);
|
||||
|
||||
public interface IClientAPI
|
||||
{
|
||||
event ImprovedInstantMessage OnInstantMessage;
|
||||
|
@ -538,10 +540,12 @@ namespace OpenSim.Framework
|
|||
|
||||
// Financial packets
|
||||
event MoneyTransferRequest OnMoneyTransferRequest;
|
||||
event EconomyDataRequest OnEconomyDataRequest;
|
||||
|
||||
event MoneyBalanceRequest OnMoneyBalanceRequest;
|
||||
event UpdateAvatarProperties OnUpdateAvatarProperties;
|
||||
|
||||
|
||||
|
||||
LLVector3 StartPos { get; set; }
|
||||
|
||||
|
@ -647,6 +651,12 @@ namespace OpenSim.Framework
|
|||
void SendBulkUpdateInventory(InventoryItemBase item);
|
||||
|
||||
void SendXferPacket(ulong xferID, uint packet, byte[] data);
|
||||
|
||||
void SendEconomyData(float EnergyEfficiency, int ObjectCapacity, int ObjectCount, int PriceEnergyUnit,
|
||||
int PriceGroupCreate, int PriceObjectClaim, float PriceObjectRent, float PriceObjectScaleFactor,
|
||||
int PriceParcelClaim, float PriceParcelClaimFactor, int PriceParcelRent, int PricePublicObjectDecay,
|
||||
int PricePublicObjectDelete, int PriceRentLight, int PriceUpload, int TeleportMinPrice, float TeleportPriceExponent);
|
||||
|
||||
void SendAvatarPickerReply(AvatarPickerReplyPacket Pack);
|
||||
|
||||
void SendAgentDataUpdate(LLUUID agentid, LLUUID activegroupid, string firstname, string lastname, ulong grouppowers, string groupname, string grouptitle);
|
||||
|
|
|
@ -214,6 +214,8 @@ namespace OpenSim.Region.ClientStack
|
|||
private ViewerEffectEventHandler handlerViewerEffect = null; //OnViewerEffect;
|
||||
private Action<IClientAPI> handlerLogout = null; //OnLogout;
|
||||
private MoneyTransferRequest handlerMoneyTransferRequest = null; //OnMoneyTransferRequest;
|
||||
private EconomyDataRequest handlerEconomoyDataRequest = null;
|
||||
|
||||
private UpdateVector handlerUpdatePrimSinglePosition = null; //OnUpdatePrimSinglePosition;
|
||||
private UpdatePrimSingleRotation handlerUpdatePrimSingleRotation = null; //OnUpdatePrimSingleRotation;
|
||||
private UpdateVector handlerUpdatePrimScale = null; //OnUpdatePrimScale;
|
||||
|
@ -223,6 +225,7 @@ namespace OpenSim.Region.ClientStack
|
|||
private PacketStats handlerPacketStats = null; // OnPacketStats;#
|
||||
private RequestAsset handlerRequestAsset = null; // OnRequestAsset;
|
||||
|
||||
|
||||
/* Properties */
|
||||
|
||||
public LLUUID SecureSessionId
|
||||
|
@ -763,6 +766,7 @@ namespace OpenSim.Region.ClientStack
|
|||
public event PacketStats OnPacketStats;
|
||||
|
||||
public event MoneyTransferRequest OnMoneyTransferRequest;
|
||||
public event EconomyDataRequest OnEconomyDataRequest;
|
||||
|
||||
public event MoneyBalanceRequest OnMoneyBalanceRequest;
|
||||
|
||||
|
@ -1523,6 +1527,34 @@ namespace OpenSim.Region.ClientStack
|
|||
OutPacket(sendXfer, ThrottleOutPacketType.Task);
|
||||
}
|
||||
|
||||
public void SendEconomyData(float EnergyEfficiency, int ObjectCapacity, int ObjectCount, int PriceEnergyUnit,
|
||||
int PriceGroupCreate, int PriceObjectClaim, float PriceObjectRent, float PriceObjectScaleFactor,
|
||||
int PriceParcelClaim, float PriceParcelClaimFactor, int PriceParcelRent, int PricePublicObjectDecay,
|
||||
int PricePublicObjectDelete, int PriceRentLight, int PriceUpload, int TeleportMinPrice, float TeleportPriceExponent)
|
||||
{
|
||||
EconomyDataPacket economyData = (EconomyDataPacket)PacketPool.Instance.GetPacket(PacketType.EconomyData);
|
||||
economyData.Info.EnergyEfficiency = EnergyEfficiency;
|
||||
economyData.Info.ObjectCapacity = ObjectCapacity;
|
||||
economyData.Info.ObjectCount = ObjectCount;
|
||||
economyData.Info.PriceEnergyUnit = PriceEnergyUnit;
|
||||
economyData.Info.PriceGroupCreate = PriceGroupCreate;
|
||||
economyData.Info.PriceObjectClaim = PriceObjectClaim;
|
||||
economyData.Info.PriceObjectRent = PriceObjectRent;
|
||||
economyData.Info.PriceObjectScaleFactor = PriceObjectScaleFactor;
|
||||
economyData.Info.PriceParcelClaim = PriceParcelClaim;
|
||||
economyData.Info.PriceParcelClaimFactor = PriceParcelClaimFactor;
|
||||
economyData.Info.PriceParcelRent = PriceParcelRent;
|
||||
economyData.Info.PricePublicObjectDecay = PricePublicObjectDecay;
|
||||
economyData.Info.PricePublicObjectDelete = PricePublicObjectDelete;
|
||||
economyData.Info.PriceRentLight = PriceRentLight;
|
||||
economyData.Info.PriceUpload = PriceUpload;
|
||||
economyData.Info.TeleportMinPrice = TeleportMinPrice;
|
||||
economyData.Info.TeleportPriceExponent = TeleportPriceExponent;
|
||||
economyData.Header.Reliable = true;
|
||||
OutPacket(economyData, ThrottleOutPacketType.Unknown);
|
||||
|
||||
}
|
||||
|
||||
public void SendAvatarPickerReply(AvatarPickerReplyPacket replyPacket)
|
||||
{
|
||||
OutPacket(replyPacket, ThrottleOutPacketType.Task);
|
||||
|
@ -4155,17 +4187,7 @@ namespace OpenSim.Region.ClientStack
|
|||
|
||||
#endregion
|
||||
|
||||
case PacketType.MoneyBalanceRequest:
|
||||
MoneyBalanceRequestPacket moneybalancerequestpacket = (MoneyBalanceRequestPacket)Pack;
|
||||
|
||||
handlerMoneyBalanceRequest = OnMoneyBalanceRequest;
|
||||
|
||||
if (handlerMoneyBalanceRequest != null)
|
||||
{
|
||||
handlerMoneyBalanceRequest(this, moneybalancerequestpacket.AgentData.AgentID, moneybalancerequestpacket.AgentData.SessionID, moneybalancerequestpacket.MoneyData.TransactionID);
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
case PacketType.UUIDNameRequest:
|
||||
UUIDNameRequestPacket incoming = (UUIDNameRequestPacket)Pack;
|
||||
foreach (UUIDNameRequestPacket.UUIDNameBlockBlock UUIDBlock in incoming.UUIDNameBlock)
|
||||
|
@ -4373,6 +4395,32 @@ namespace OpenSim.Region.ClientStack
|
|||
|
||||
#endregion
|
||||
|
||||
#region Economy/Transaction Packets
|
||||
|
||||
case PacketType.MoneyBalanceRequest:
|
||||
MoneyBalanceRequestPacket moneybalancerequestpacket = (MoneyBalanceRequestPacket)Pack;
|
||||
|
||||
handlerMoneyBalanceRequest = OnMoneyBalanceRequest;
|
||||
|
||||
if (handlerMoneyBalanceRequest != null)
|
||||
{
|
||||
handlerMoneyBalanceRequest(this, moneybalancerequestpacket.AgentData.AgentID, moneybalancerequestpacket.AgentData.SessionID, moneybalancerequestpacket.MoneyData.TransactionID);
|
||||
}
|
||||
|
||||
break;
|
||||
case PacketType.EconomyDataRequest:
|
||||
|
||||
handlerEconomoyDataRequest = OnEconomyDataRequest;
|
||||
if (handlerEconomoyDataRequest != null)
|
||||
{
|
||||
handlerEconomoyDataRequest(AgentId);
|
||||
}
|
||||
// TODO: handle this packet
|
||||
//m_log.Warn("[CLIENT]: unhandled EconomyDataRequest packet");
|
||||
break;
|
||||
|
||||
#endregion
|
||||
|
||||
#region unimplemented handlers
|
||||
|
||||
case PacketType.StartPingCheck:
|
||||
|
@ -4422,10 +4470,7 @@ namespace OpenSim.Region.ClientStack
|
|||
// TODO: Don't display this one, we handle it at a lower level
|
||||
//m_log.Warn("[CLIENT]: unhandled UseCircuitCode packet");
|
||||
break;
|
||||
case PacketType.EconomyDataRequest:
|
||||
// TODO: handle this packet
|
||||
m_log.Warn("[CLIENT]: unhandled EconomyDataRequest packet");
|
||||
break;
|
||||
|
||||
case PacketType.AgentHeightWidth:
|
||||
// TODO: handle this packet
|
||||
m_log.Warn("[CLIENT]: unhandled AgentHeightWidth packet");
|
||||
|
|
|
@ -56,10 +56,39 @@ namespace OpenSim.Region.Environment.Modules
|
|||
|
||||
private bool gridmode = false;
|
||||
|
||||
private float EnergyEfficiency = 0f;
|
||||
private int ObjectCapacity = 45000;
|
||||
private int ObjectCount = 0;
|
||||
private int PriceEnergyUnit = 0;
|
||||
private int PriceGroupCreate = 0;
|
||||
private int PriceObjectClaim = 0;
|
||||
private float PriceObjectRent = 0f;
|
||||
private float PriceObjectScaleFactor = 0f;
|
||||
private int PriceParcelClaim = 0;
|
||||
private float PriceParcelClaimFactor = 0f;
|
||||
private int PriceParcelRent = 0;
|
||||
private int PricePublicObjectDecay = 0;
|
||||
private int PricePublicObjectDelete = 0;
|
||||
private int PriceRentLight = 0;
|
||||
private int PriceUpload = 0;
|
||||
private int TeleportMinPrice = 0;
|
||||
private int UserLevelPaysFees = 2;
|
||||
|
||||
float TeleportPriceExponent = 0f;
|
||||
|
||||
LLUUID EconomyBaseAccount = LLUUID.Zero;
|
||||
|
||||
public void Initialise(Scene scene, IConfigSource config)
|
||||
{
|
||||
m_gConfig = config;
|
||||
ReadConfigAndPopulate();
|
||||
|
||||
IConfig startupConfig = m_gConfig.Configs["Startup"];
|
||||
IConfig economyConfig = m_gConfig.Configs["Economy"];
|
||||
|
||||
|
||||
|
||||
ReadConfigAndPopulate(scene, startupConfig, "Startup");
|
||||
ReadConfigAndPopulate(scene, economyConfig, "Economy");
|
||||
|
||||
if (m_enabled)
|
||||
{
|
||||
|
@ -79,14 +108,47 @@ namespace OpenSim.Region.Environment.Modules
|
|||
scene.EventManager.OnNewClient += OnNewClient;
|
||||
scene.EventManager.OnMoneyTransfer += MoneyTransferAction;
|
||||
scene.EventManager.OnClientClosed += ClientClosed;
|
||||
scene.EventManager.OnNewInventoryItemUploadComplete += NewInventoryItemEconomyHandler;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
private void ReadConfigAndPopulate()
|
||||
private void ReadConfigAndPopulate(Scene scene, IConfig startupConfig, string config)
|
||||
{
|
||||
IConfig startupConfig = m_gConfig.Configs["Startup"];
|
||||
gridmode = startupConfig.GetBoolean("gridmode", false);
|
||||
m_enabled = (startupConfig.GetString("moneymodule", "BetaGridLikeMoneyModule") == "BetaGridLikeMoneyModule");
|
||||
if (config == "Startup")
|
||||
{
|
||||
gridmode = startupConfig.GetBoolean("gridmode", false);
|
||||
m_enabled = (startupConfig.GetString("economymodule", "BetaGridLikeMoneyModule") == "BetaGridLikeMoneyModule");
|
||||
}
|
||||
|
||||
if (config == "Economy")
|
||||
{
|
||||
ObjectCapacity = startupConfig.GetInt("ObjectCapacity", 45000);
|
||||
PriceEnergyUnit = startupConfig.GetInt("PriceEnergyUnit", 100);
|
||||
PriceObjectClaim = startupConfig.GetInt("PriceObjectClaim", 10);
|
||||
PricePublicObjectDecay = startupConfig.GetInt("PricePublicObjectDecay", 4);
|
||||
PricePublicObjectDelete = startupConfig.GetInt("PricePublicObjectDelete", 4);
|
||||
PriceParcelClaim = startupConfig.GetInt("PriceParcelClaim", 1);
|
||||
PriceParcelClaimFactor = startupConfig.GetFloat("PriceParcelClaimFactor", 1f);
|
||||
PriceUpload = startupConfig.GetInt("PriceUpload", 0);
|
||||
PriceRentLight = startupConfig.GetInt("PriceRentLight", 5);
|
||||
TeleportMinPrice = startupConfig.GetInt("TeleportMinPrice", 2);
|
||||
TeleportPriceExponent = startupConfig.GetFloat("TeleportPriceExponent", 2f);
|
||||
EnergyEfficiency = startupConfig.GetFloat("EnergyEfficiency", 1);
|
||||
PriceObjectRent = startupConfig.GetFloat("PriceObjectRent", 1);
|
||||
PriceObjectScaleFactor = startupConfig.GetFloat("PriceObjectScaleFactor", 10);
|
||||
PriceParcelRent = startupConfig.GetInt("PriceParcelRent", 1);
|
||||
PriceGroupCreate = startupConfig.GetInt("PriceGroupCreate", -1);
|
||||
string EBA = startupConfig.GetString("EconomyBaseAccount", LLUUID.Zero.ToString());
|
||||
Helpers.TryParse(EBA,out EconomyBaseAccount);
|
||||
UserLevelPaysFees = startupConfig.GetInt("UserLevelPaysFees", -1);
|
||||
m_stipend = startupConfig.GetInt("UserStipend", 500);
|
||||
m_minFundsBeforeRefresh = startupConfig.GetInt("IssueStipendWhenClientIsBelowAmount", 10);
|
||||
m_keepMoneyAcrossLogins = startupConfig.GetBoolean("KeepMoneyAcrossLogins", true);
|
||||
}
|
||||
|
||||
// Send ObjectCapacity to Scene.. Which sends it to the SimStatsReporter.
|
||||
scene.SetObjectCapacity(ObjectCapacity);
|
||||
}
|
||||
|
||||
private void OnNewClient(IClientAPI client)
|
||||
|
@ -105,8 +167,11 @@ namespace OpenSim.Region.Environment.Modules
|
|||
}
|
||||
|
||||
// Subscribe to Money messages
|
||||
client.OnEconomyDataRequest += EconomyDataRequestHandler;
|
||||
client.OnMoneyBalanceRequest += SendMoneyBalance;
|
||||
client.OnLogout += ClientClosed;
|
||||
|
||||
|
||||
}
|
||||
|
||||
public void ClientClosed(LLUUID AgentID)
|
||||
|
@ -118,6 +183,16 @@ namespace OpenSim.Region.Environment.Modules
|
|||
}
|
||||
}
|
||||
|
||||
public void EconomyDataRequestHandler(LLUUID agentId)
|
||||
{
|
||||
IClientAPI user = LocateClientObject(agentId);
|
||||
|
||||
user.SendEconomyData(EnergyEfficiency, ObjectCapacity, ObjectCount, PriceEnergyUnit, PriceGroupCreate,
|
||||
PriceObjectClaim, PriceObjectRent, PriceObjectScaleFactor, PriceParcelClaim, PriceParcelClaimFactor,
|
||||
PriceParcelRent, PricePublicObjectDecay, PricePublicObjectDelete, PriceRentLight, PriceUpload,
|
||||
TeleportMinPrice, TeleportPriceExponent);
|
||||
}
|
||||
|
||||
private void MoneyTransferAction (Object osender, MoneyTransferArgs e)
|
||||
{
|
||||
IClientAPI sender = null;
|
||||
|
@ -150,6 +225,22 @@ namespace OpenSim.Region.Environment.Modules
|
|||
}
|
||||
}
|
||||
|
||||
private void NewInventoryItemEconomyHandler(LLUUID Uploader, LLUUID AssetID, String AssetName, int userlevel)
|
||||
{
|
||||
// Presumably a normal grid would actually send this information to a server somewhere.
|
||||
// We're going to apply the UploadCost here.
|
||||
if (m_enabled)
|
||||
{
|
||||
// Only make users that are below the UserLevelPaysFees value pay.
|
||||
// Use this to exclude Region Owners (2), Estate Managers(1), Users (0), Disabled(-1)
|
||||
if (PriceUpload > 0 && userlevel <= UserLevelPaysFees)
|
||||
{
|
||||
doMoneyTranfer(Uploader, EconomyBaseAccount, PriceUpload);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private bool doMoneyTranfer(LLUUID Sender, LLUUID Receiver, int amount)
|
||||
{
|
||||
bool result = false;
|
||||
|
|
|
@ -73,6 +73,17 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
{
|
||||
userInfo.AddItem(remoteClient.AgentId, item);
|
||||
remoteClient.SendInventoryItemCreateUpdate(item);
|
||||
|
||||
int userlevel = 0;
|
||||
if (PermissionsMngr.IsEstateManager(remoteClient.AgentId))
|
||||
{
|
||||
userlevel = 1;
|
||||
}
|
||||
if (m_regInfo.MasterAvatarAssignedUUID == remoteClient.AgentId)
|
||||
{
|
||||
userlevel = 2;
|
||||
}
|
||||
EventManager.TriggerOnNewInventoryItemUploadComplete(remoteClient.AgentId, item.AssetID, item.Name, userlevel);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -219,6 +219,8 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
set { m_innerScene.RestorePresences = value; }
|
||||
}
|
||||
|
||||
public int objectCapacity = 45000;
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
@ -299,6 +301,9 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
|
||||
m_statsReporter = new SimStatsReporter(regInfo);
|
||||
m_statsReporter.OnSendStatsResult += SendSimStatsPackets;
|
||||
|
||||
m_statsReporter.SetObjectCapacity(objectCapacity);
|
||||
|
||||
string OSString = "";
|
||||
|
||||
if (System.Environment.OSVersion.Platform != PlatformID.Unix)
|
||||
|
@ -2016,6 +2021,15 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
}
|
||||
}
|
||||
|
||||
public void SetObjectCapacity(int objects)
|
||||
{
|
||||
if (m_statsReporter != null)
|
||||
{
|
||||
m_statsReporter.SetObjectCapacity(objects);
|
||||
}
|
||||
objectCapacity = objects;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Other Methods
|
||||
|
|
|
@ -137,6 +137,10 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
|
||||
public event OnNewPresenceDelegate OnMakeChildAgent;
|
||||
|
||||
public delegate void NewInventoryItemUploadComplete(LLUUID avatarID, LLUUID assetID, string name, int userlevel);
|
||||
|
||||
public event NewInventoryItemUploadComplete OnNewInventoryItemUploadComplete;
|
||||
|
||||
/// <summary>
|
||||
/// RegisterCapsEvent is called by Scene after the Caps object
|
||||
/// has been instantiated and before it is return to the
|
||||
|
@ -207,6 +211,7 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
private OnTerrainTickDelegate handlerTerrainTick = null; // OnTerainTick;
|
||||
private RegisterCapsEvent handlerRegisterCaps = null; // OnRegisterCaps;
|
||||
private DeregisterCapsEvent handlerDeregisterCaps = null; // OnDeregisterCaps;
|
||||
private NewInventoryItemUploadComplete handlerNewInventoryItemUpdateComplete = null;
|
||||
|
||||
public void TriggerOnScriptChangedEvent(uint localID, uint change)
|
||||
{
|
||||
|
@ -462,5 +467,14 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
handlerDeregisterCaps(agentID, caps);
|
||||
}
|
||||
}
|
||||
|
||||
public void TriggerOnNewInventoryItemUploadComplete(LLUUID agentID, LLUUID AssetID, String AssetName, int userlevel)
|
||||
{
|
||||
handlerNewInventoryItemUpdateComplete = OnNewInventoryItemUploadComplete;
|
||||
if (handlerNewInventoryItemUpdateComplete != null)
|
||||
{
|
||||
handlerNewInventoryItemUpdateComplete(agentID, AssetID, AssetName, userlevel);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -100,6 +100,8 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
private int m_pendingUploads = 0;
|
||||
private int m_activeScripts = 0;
|
||||
private int m_scriptLinesPerSecond = 0;
|
||||
|
||||
private int objectCapacity = 45000;
|
||||
|
||||
|
||||
SimStatsPacket.StatBlock[] sb = new SimStatsPacket.StatBlock[21];
|
||||
|
@ -152,7 +154,7 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
{
|
||||
statpack.Region.RegionFlags = (uint) 0;
|
||||
}
|
||||
statpack.Region.ObjectCapacity = (uint) 45000;
|
||||
statpack.Region.ObjectCapacity = (uint) objectCapacity;
|
||||
|
||||
#region various statistic googly moogly
|
||||
|
||||
|
@ -389,6 +391,11 @@ namespace OpenSim.Region.Environment.Scenes
|
|||
m_activeScripts = count;
|
||||
}
|
||||
|
||||
public void SetObjectCapacity(int objects)
|
||||
{
|
||||
objectCapacity = objects;
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
|
|
|
@ -155,6 +155,8 @@ namespace OpenSim.Region.Examples.SimpleModule
|
|||
public event FriendActionDelegate OnDenyFriendRequest;
|
||||
public event FriendshipTermination OnTerminateFriendship;
|
||||
public event PacketStats OnPacketStats;
|
||||
|
||||
public event EconomyDataRequest OnEconomyDataRequest;
|
||||
public event MoneyBalanceRequest OnMoneyBalanceRequest;
|
||||
public event UpdateAvatarProperties OnUpdateAvatarProperties;
|
||||
|
||||
|
@ -408,6 +410,13 @@ namespace OpenSim.Region.Examples.SimpleModule
|
|||
{
|
||||
}
|
||||
|
||||
public virtual void SendEconomyData(float EnergyEfficiency, int ObjectCapacity, int ObjectCount, int PriceEnergyUnit,
|
||||
int PriceGroupCreate, int PriceObjectClaim, float PriceObjectRent, float PriceObjectScaleFactor,
|
||||
int PriceParcelClaim, float PriceParcelClaimFactor, int PriceParcelRent, int PricePublicObjectDecay,
|
||||
int PricePublicObjectDelete, int PriceRentLight, int PriceUpload, int TeleportMinPrice, float TeleportPriceExponent)
|
||||
{
|
||||
|
||||
}
|
||||
public virtual void SendNameReply(LLUUID profileId, string firstname, string lastname)
|
||||
{
|
||||
}
|
||||
|
|
|
@ -301,3 +301,53 @@ snapshot_cache_directory = "DataSnapshot"
|
|||
; This semicolon-separated string serves to notify specific data services
|
||||
; about the existence of this sim.
|
||||
data_services="http://metaverseink.com/cgi-bin/register.py"
|
||||
|
||||
[Economy]
|
||||
; These economy values get used in the BetaGridLikeMoneyModule
|
||||
|
||||
; 45000 is the highest value that the sim could possibly report because of protocol constraints
|
||||
ObjectCapacity = 45000
|
||||
|
||||
; Money Unit fee to upload textures, animations etc
|
||||
PriceUpload = 0
|
||||
|
||||
; Money Unit fee to create groups
|
||||
PriceGroupCreate = 0
|
||||
|
||||
; This is the account Money goes to for fees. Remember, economy requires that money circulates somewhere... even if it's an upload fee
|
||||
EconomyBaseAccount = 00000000-0000-0000-0000-000000000000
|
||||
|
||||
; This is the type of user that will pay fees.
|
||||
; Set this to 2 for users, estate managers and Estate Owners
|
||||
; Set this to 1 for Users and Estate Managers
|
||||
; Set this to 0 for Users only.
|
||||
; -1 disables
|
||||
UserLevelPaysFees = -1
|
||||
|
||||
; Amount to give to user as a stipend
|
||||
UserStipend = 1000
|
||||
|
||||
; When a user gets low on money units and logs off, then logs back on, issue a new stipend if they have less money units then this
|
||||
; amount. Be aware that the account money isn't stored anywhere so users will get a stipend if you restart the simulator
|
||||
IssueStipendWhenClientIsBelowAmount = 10
|
||||
|
||||
; If this is true, the simulator will remember account balances until the simulator is shutdown or restarted.
|
||||
KeepMoneyAcrossLogins = true
|
||||
|
||||
; We don't really know what the rest of these values do. These get sent to the client
|
||||
; These taken from Agni at a Public Telehub. Change at your own risk.
|
||||
ObjectCount = 0
|
||||
PriceEnergyUnit = 100
|
||||
PriceObjectClaim = 10
|
||||
PricePublicObjectDecay = 4
|
||||
PricePublicObjectDelete = 4
|
||||
PriceParcelClaim = 1
|
||||
PriceParcelClaimFactor = 1
|
||||
|
||||
PriceRentLight = 5
|
||||
TeleportMinPrice = 2
|
||||
TeleportPriceExponent = 2
|
||||
EnergyEfficiency = 1
|
||||
PriceObjectRent = 1
|
||||
PriceObjectScaleFactor = 10
|
||||
PriceParcelRent = 1
|
Loading…
Reference in New Issue