July force wipe

This commit is contained in:
bmgjet 2024-07-04 19:33:48 +12:00 committed by GitHub
parent 26ce1be6cc
commit da1a0fdb7e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 65 additions and 177 deletions

View File

@ -1,11 +1,6 @@
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using UnityEngine;
namespace Oxide.Plugins
{
[Info("LazyRail", "bmgjet", "0.0.3")]
[Info("LazyRail", "bmgjet", "0.0.5")]
[Description("Help above ground rails function on custom maps")]
class LazyRail : RustPlugin
{
@ -13,17 +8,7 @@ namespace Oxide.Plugins
public bool DisablePlayerSuicideWhenOnTrain = true;
public bool DisableDecayOnTrain = true;
public bool TrainUnlimitedFuel = true;
public int WagonAmount = 60;
public int WagonsPerTrain = 10;
public int ScanDelaySeconds = 300;
public int SidingMinLength = 20;
public int SidingMaxLength = 50;
public bool ShowDebug = false;
public List<string> wagons = new List<string>() { "assets/content/vehicles/trains/caboose/traincaboose.entity.prefab", "assets/content/vehicles/trains/wagons/trainwagonunloadable.entity.prefab", "assets/content/vehicles/trains/wagons/trainwagonunloadablefuel.entity.prefab", "assets/content/vehicles/trains/wagons/trainwagonunloadableloot.entity.prefab", };
public List<TrainCar> trains = new List<TrainCar>();
private List<Coroutine> Threads = new List<Coroutine>();
private List<Vector3> railnodes = new List<Vector3>();
private int Spawned = 0;
private object OnPlayerViolation(BasePlayer player, AntiHackType type, float amount)
{
@ -33,93 +18,14 @@ namespace Oxide.Plugins
if (be != null && be is TrainCar)
{
if (ShowDebug) { Puts("Prevented Player Violation"); }
if (type == AntiHackType.InsideTerrain) return false;
if (type == AntiHackType.NoClip) return false;
if (type == AntiHackType.FlyHack) return false;
if (type == AntiHackType.InsideTerrain) return true;
if (type == AntiHackType.NoClip) return true;
if (type == AntiHackType.FlyHack) return true;
}
}
return null;
}
void OnServerInitialized() { if (WagonAmount != 0) { Threads.Add(ServerMgr.Instance.StartCoroutine(TrainChecker())); } }
private void Unload()
{
if (Threads != null && Threads.Count != 0)
{
foreach (Coroutine co in Threads) { if (co != null) ServerMgr.Instance.StopCoroutine(co); }
Threads = null;
}
foreach (TrainCar t in trains)
{
if (!t.IsDestroyed) { t.Kill(); }
}
}
private IEnumerator TrainChecker()
{
int checks = 0;
var _instruction = ConVar.FPS.limit > 80 ? CoroutineEx.waitForSeconds(0.01f) : null;
foreach (PathList pathList in World.GetPaths("Rail").AsEnumerable<PathList>())
{
if (pathList.Path.Points.Count() < SidingMaxLength && pathList.Path.Points.Count() > SidingMinLength)
{
for (int i = 10; i < pathList.Path.Points.Count() - 10; i++)
{
if (++checks >= 1000)
{
checks = 0;
yield return _instruction;
}
railnodes.Add(pathList.Path.Points[i]);
}
}
}
if (railnodes.Count > 30) { Puts("Found " + railnodes.Count + " Side rails"); }
else
{
Puts("Not enough Side rails found");
yield break;
}
trains.Clear();
while (true)
{
for (int i = 0; i < trains.Count; i++)
{
try
{
if (trains[i] == null || trains[i].IsDestroyed)
{
if (ShowDebug) { Puts("Removed Dead wagon reference"); }
trains.RemoveAt(i);
}
}
catch { }
}
if (trains.Count < WagonAmount)
{
foreach (BaseEntity bn in BaseEntity.serverEntities.entityList.Values)
{
if (bn == null) continue;
if (bn is TrainCar) { if (!trains.Contains(bn as TrainCar)) { trains.Add(bn as TrainCar); } }
if (++checks >= 500)
{
checks = 0;
yield return _instruction;
}
}
}
for (int i2 = 0; i2 < WagonAmount - trains.Count; i2++) { SpawnEntity(railnodes.GetRandom()); }
yield return CoroutineEx.waitForSeconds(ScanDelaySeconds);
}
}
[ChatCommand("showsides")]
private void ShowsideCmd(BasePlayer player) { if (!player.IsAdmin) { return; } foreach (Vector3 v in railnodes) { if (Vector3.Distance(v, player.transform.position) < 500) { player.SendConsoleCommand("ddraw.sphere", 8f, Color.blue, v, 1f); } } }
[ChatCommand("showwagons")]
private void ShowwagonCmd(BasePlayer player) { if (!player.IsAdmin) { return; } foreach (TrainCar v in trains) { if (v != null) { player.SendConsoleCommand("ddraw.sphere", 8f, Color.blue, v.transform.position, 1f); } } }
private object OnEntityTakeDamage(BasePlayer player, HitInfo hitInfo)
{
if (DisablePlayerSuicideWhenOnTrain && player != null || hitInfo != null)
@ -132,26 +38,8 @@ namespace Oxide.Plugins
return null;
}
private bool SpawnEntity(Vector3 position)
private void OnEntitySpawned(TrainCar _trainCar)
{
string prefab;
if (Spawned >= WagonsPerTrain) { prefab = "assets/content/vehicles/trains/locomotive/locomotive.entity.prefab"; Spawned = 0; }
else { prefab = wagons.GetRandom(); }
TrainCar trainCar = GameManager.server.CreateEntity(prefab, position) as TrainCar;
trainCar.enableSaving = false;
trainCar.platformParentTrigger.ParentNPCPlayers = true;
trainCar.Spawn();
trainCar.transform.position = position;
if (trainCar == null || trainCar.IsDestroyed) { return false; }
if (ShowDebug) { Puts("Spawned wagon @ " + trainCar.transform.position); }
trains.Add(trainCar);
Spawned++;
return true;
}
private void OnEntitySpawned(BaseEntity baseEntity)
{
TrainCar _trainCar = baseEntity as TrainCar;
if (_trainCar != null)
{
_trainCar.frontCollisionTrigger.interestLayers = Rust.Layers.Mask.Vehicle_World;
@ -167,7 +55,7 @@ namespace Oxide.Plugins
_trainEngine.maxFuelPerSec = 0f;
NextFrame(() =>
{
StorageContainer fuelContainer = _trainEngine.GetFuelSystem()?.GetFuelContainer();
StorageContainer fuelContainer = BaseNetworkable.serverEntities.Find(_trainEngine.GetFuelSystem().GetInstanceID()) as StorageContainer;
if (fuelContainer != null)
{
fuelContainer.inventory.AddItem(fuelContainer.allowedItem, 1);