Config
Explanations for all config values.
shared/config.lua
Settings
debug
If set to true, it will print out information in the console, false to disable it. Some information will still be printed out, such as missing arguments, despite this being disabled.
displayZones
Will display all blocked and allowed zones if set to true
.
threadUpdateInterval
How often the script will update the plants in seconds, if you have insanely high values you can make this 10 seconds or more, but if you have low values, you can make this 1 second or less, 5+ seconds is recommended, I've optimized the script as much as possible but looping through and checking values for 500 plants every second is a huge task, so my recommendation is to keep it at 5+ seconds.
gatherClosePlantsInterval
How often the script will gather the closest plants to the player in seconds, this is to maintain high performance and not to have a lot of plants loaded at the same time.
databaseUpdateInterval
How many seconds between each time the database is updated, recommended to keep at around 5 minutes, which is 60 * 5, plants are always updated on script stop unless there's a connection loss to the database, in which case nothing on the server will be saved at all.
displayPressE
If the "Press E" box top left should be displayed or not, makes it easier to see if you're close enough to the plant BUT does use a bit of performance, therefore I added it as a setting.
distanceBetweenPlants
Can't place plants within the specified distance to prevent unrealistic spamming.
autoRemove
In seconds how long until the entity (plant and light) will be automatically removed, this is to prevent old entities sitting in impossible to find spots taking up performance, set to 0 to disable but is highly recommended to keep enabled, this will be checked every time databaseUpdateInterval is reached, meaning it will clear after all plants are saved.
logsEnabled
If logs should be enabled or not, if you don't want logs, set this to false
. Webhook is in server/unlocked.lua to prevent people from stealing your webhook and spamming it.
logs
A collection of logs you can enable or disable.
logs.onPlant
When planting your plant
logs.onHandle
When watering / picking up etc
logs.onHarvest
When harvesting your plant (Items and amount is included)
logs.onLight
When handling a light (Placement/Pickup)
GlobalBlockedZones
You can't grow anything inside of these zones. If you want to disable a certain plant for a certain spot, you can do that in the plant's settings.
pos
The location where you want to block planting, has to be a vector3.
radius
The radius, aka how large the circle is.
Lights
interiorId
Basically, if the interior ID is 0, AKA outside, you will automatically have 65 light "points" added, or whatever you change it to. Feel free to add any interior ID in here as you wish. I've added a command called "getinteriorid" which will print the interior ID of the interior you are inside of in your F8 console, so you can easily add it to the table. You set the interior ID as the key and then the default light value as the value for that key. View the already entered ones as reference.
timeMultipliers
Each of these values represent the multiplier for an hour from 0-24, first table being 00:00, second being 01:00 etc and the last being 24:00, disable by setting all multipliers to 1.0. Basically, it fetches the IRL time using os.date(). It will then pick the corresponding multiplier for the hour. It will then multiply the interior light points by the multiplier. So if you have lights placed out during the night and it turns day because you have long plant timers, the light will be multiplied by a different value and might make it too bright. This feature is kind of hardcore but thought I'd add it in case anyone wanted to use it, if not, just set all multipliers to 1.0. The reason this is not based on the actual in-game time is simply because you can't fetch that server sided, meaning you need to have someone online to host the time etc.
props
The different lights you can place out and their settings.
props.model
The model of the prop.
item
The item name you use in order to place down a light.
radius
The radius the light can affect plants.
lightPoints
The maximum amount of light points that this light can give.
pointMultiplier
Depending on how far away you are from the light, you will get different light values. It is recommended to keep this as the default value, which is 0.1 to simulate realistic lighting.
zDecrease
Some props are weird, they can either float in the air or be in the ground. This value can be changed based on that, but is normally 0.985 to get it on the ground.
Plants
Every plant needs a unique key to be access easily. In order to not confuse this, the item you use is the same as that key. For example, when I use the item "coke_seed", it will access the Config.Plants.coke_seed values.
label
The label that will be displayed throughout the script for that plant.
growthTime
How long it will take for the plant to grow, in seconds.
settings
A collection of settings to handle the plant's growth values.
settings.removeOverTime
These are settings that will be removed over time, the amount depends on the values below. You can change the water and nutrition values here. They both have the same settings available.
settings.removeOverTime[x].label
The label that will be displayed throughout the script for this value.
settings.removeOverTime[x].min & settings.removeOverTime[x].max
The minimum and maximum for this value, recommended to keep at their default values 0 & 100.
settings.removeOverTime[x].bestValue.min & settings.removeOverTime[x].bestValue.max
The value you have to aim to hit in between in order for your plants to grow without losing quality.
settings.removeOverTime[x].valueToRemove
The amount of value of this setting you will lose, if this makes you go below the minimum best value you will start to lose quality.
settings.removeOverTime[x].valueRemoveTime
Time before a value "point" is lost, in seconds.
settings.removeOverTime[x].qualityToRemove
The amount of quality you remove everytime you cross the interval. Recommended to keep at 1, since anything higher might kill the plant insanely fast. For example, set it to 100 and the plant will instantly lose all it's quality.
settings.removeOverTime[x].qualityRemoveTime
In seconds, how long it takes before that quality is removed.
settings.other[x]
Works the same as above, only has small differences.
settings.other[x].timeToAdd
If your light value is too poor, you will have additional growth time added simulating that the plant struggles to grow without proper light. Make sure this value is not too harsh, otherwise it will end up making your plant completely passive and restricts it from growing.
settings.other[x].qualityRemoveTime
Works the same as qualityRemoveTime for removeOverTime settings, but it's now the interval for adding to your growth time.
plantingItems
Items that you need to use when planting your plant. Don't forget to add your seed in here, otherwise it won't be removed when used.
plantingItems.item
The item that you will set the values for.
plantingItems.remove
Whether to remove the item or not, set to true
to remove upon use and false
to keep the item when planting.
plantingItems.amount
The amount that you will need in order to plant. Also the amount that will be removed, given back etc.
plantingItems.giveBackOnHarvest
Set to true
to give this item back on harvest, set to false
or remove it completely to not get it back.
plantingItems.giveBackOnPickup
Set to true
to give this item back on pickup, set to false
or remove it completely to not get it back.
handlePlant
Which items, the amount and how much (0-100) you want to add to that value. Note that you can not change the water
and nutrition
key, they have to stay.
handlePlant.item
The item that will be used when handling the plant with this action.
handlePlant.amount
The item amount that will be used when handling the plant with this action.
handlePlant.toAdd
How much you want to add to the plant's value when handling the plant with this action.
reward
This is based on the quality of the plant, if you have the default values below this is how it works. If it has 33 in quality it will skip over 20 and check the next, the next one is 50 and the quality is not high enough meaning it will default back to the 20. If your values below are too high and it can't even reach the first one, you won't get anything from the plant and a notifiction stating the quality is too low. I would recommend similar values to the default ones but it's completely free to change, as long as it's between 0-100 and you follow the template. I recommend looking these over to ensure your server's economy align with the values. Note that you can add more than just one reward for each quality, view below.
reward[x].item
The item that you will be given.
reward[x].amount
A random amount between the first and last value that you will be given.
lowerOutside
If you wish to automatically lower the plant when placed outside, edit this value. It was put in place so that you can simulate it being used in soil whilst also allowing you to plant it inside with a pot. Please note that using a smaller prop model and lowering it may cause it to be unreachable. We recommend that you only use the medium and large marijuana plant prop if you do decide to change this value.
growthState
In here you change the different labels and models for the plant's growth state. In the coke plant example, the plant will start out as a seed, then grow into a small plant, then a medium plant and finally a big plant. All props can be found at: https://forge.plebmasters.de/objects.
growthState.label
The label that will be displayed throughout the script for the growth state.
growthState.model
The model for that plant's state.
growthState.zDecrease
To predictibly place the plant on the ground in front of a player when planting, you remove 0.985 to the z coordinate. Some props don't work the same, so I left this value available to change in case you run into that issue.
growthState.growthValue
The growth value the plant has to hit in order to change it's label and prop.
blocked
If set to true
, the zones below will be blocked to place in, if set to false
, the zones below will be the only ones you can place in.
zones
The zones for the blocked variable above.
zones.pos
The position for the middle of the circle. Has to be a vector3 value.
zones.radius
The radius for the zone.
blipColour
The color of the bip and area if you are displaying the blocked / restricted zones.
surfaceChecking
If set to true
, it will check if the plant is on a surface that is allowed, if set to false
, it will not check
surfaces
Set the values below to true
if you want to be able to plant on that surface, all other surfaces that are not listed will block planting. View the example below.
Last updated