2021-05-04 13:22:10 +00:00
|
|
|
use crate::{
|
|
|
|
assets,
|
2021-08-09 21:25:36 +00:00
|
|
|
comp::{self, buff::BuffKind, inventory::item::try_all_item_defs, AdminRole as Role, Skill},
|
2021-08-15 11:45:50 +00:00
|
|
|
generation::try_all_entity_configs,
|
2021-05-04 13:22:10 +00:00
|
|
|
npc, terrain,
|
|
|
|
};
|
2021-04-12 18:07:34 +00:00
|
|
|
use assets::AssetExt;
|
2020-12-12 01:45:46 +00:00
|
|
|
use hashbrown::HashMap;
|
2020-05-09 02:42:51 +00:00
|
|
|
use lazy_static::lazy_static;
|
2021-04-12 18:07:34 +00:00
|
|
|
use serde::{Deserialize, Serialize};
|
2020-06-05 18:12:18 +00:00
|
|
|
use std::{
|
|
|
|
fmt::{self, Display},
|
|
|
|
str::FromStr,
|
|
|
|
};
|
2021-05-04 13:22:10 +00:00
|
|
|
use strum::IntoEnumIterator;
|
2020-06-24 03:29:46 +00:00
|
|
|
use tracing::warn;
|
2020-05-05 04:06:36 +00:00
|
|
|
|
|
|
|
/// Struct representing a command that a user can run from server chat.
|
2020-05-05 22:33:16 +00:00
|
|
|
pub struct ChatCommandData {
|
2020-05-11 22:02:21 +00:00
|
|
|
/// A list of arguments useful for both tab completion and parsing
|
2020-05-05 22:33:16 +00:00
|
|
|
pub args: Vec<ArgumentSpec>,
|
2020-05-05 04:06:36 +00:00
|
|
|
/// A one-line message that explains what the command does
|
|
|
|
pub description: &'static str,
|
2020-06-01 04:33:39 +00:00
|
|
|
/// Whether the command requires administrator permissions.
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
pub needs_role: Option<Role>,
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
|
2020-05-05 22:33:16 +00:00
|
|
|
impl ChatCommandData {
|
2020-06-01 04:33:39 +00:00
|
|
|
pub fn new(
|
|
|
|
args: Vec<ArgumentSpec>,
|
|
|
|
description: &'static str,
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
needs_role: Option<Role>,
|
2020-06-01 04:33:39 +00:00
|
|
|
) -> Self {
|
2020-05-05 04:06:36 +00:00
|
|
|
Self {
|
|
|
|
args,
|
|
|
|
description,
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
needs_role,
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-08 19:51:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Serialize, Deserialize, Clone)]
|
2021-09-04 02:06:15 +00:00
|
|
|
pub enum KitSpec {
|
|
|
|
Item(String),
|
|
|
|
ModularWeapon {
|
|
|
|
tool: comp::tool::ToolKind,
|
|
|
|
material: comp::item::Material,
|
|
|
|
},
|
|
|
|
}
|
2022-09-08 19:51:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Serialize, Deserialize, Clone)]
|
2021-09-04 02:06:15 +00:00
|
|
|
pub struct KitManifest(pub HashMap<String, Vec<(KitSpec, u32)>>);
|
2021-04-12 18:07:34 +00:00
|
|
|
impl assets::Asset for KitManifest {
|
|
|
|
type Loader = assets::RonLoader;
|
|
|
|
|
|
|
|
const EXTENSION: &'static str = "ron";
|
|
|
|
}
|
|
|
|
|
2022-09-08 19:51:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Serialize, Deserialize, Clone)]
|
2021-05-08 15:47:09 +00:00
|
|
|
pub struct SkillPresetManifest(pub HashMap<String, Vec<(Skill, u8)>>);
|
|
|
|
impl assets::Asset for SkillPresetManifest {
|
|
|
|
type Loader = assets::RonLoader;
|
|
|
|
|
|
|
|
const EXTENSION: &'static str = "ron";
|
|
|
|
}
|
|
|
|
|
2021-08-09 17:18:33 +00:00
|
|
|
pub const KIT_MANIFEST_PATH: &str = "server.manifests.kits";
|
|
|
|
pub const PRESET_MANIFEST_PATH: &str = "server.manifests.presets";
|
|
|
|
|
2020-05-09 02:42:51 +00:00
|
|
|
lazy_static! {
|
|
|
|
static ref ALIGNMENTS: Vec<String> = vec!["wild", "enemy", "npc", "pet"]
|
|
|
|
.iter()
|
|
|
|
.map(|s| s.to_string())
|
|
|
|
.collect();
|
2021-06-14 17:39:50 +00:00
|
|
|
static ref SKILL_TREES: Vec<String> = vec!["general", "sword", "axe", "hammer", "bow", "staff", "sceptre", "mining"]
|
2021-01-06 01:26:21 +00:00
|
|
|
.iter()
|
|
|
|
.map(|s| s.to_string())
|
|
|
|
.collect();
|
2020-12-12 22:14:24 +00:00
|
|
|
/// TODO: Make this use hot-reloading
|
2020-05-09 02:42:51 +00:00
|
|
|
static ref ENTITIES: Vec<String> = {
|
2020-12-12 22:14:24 +00:00
|
|
|
let npc_names = &*npc::NPC_NAMES.read();
|
2021-05-09 15:25:52 +00:00
|
|
|
let mut souls = Vec::new();
|
|
|
|
macro_rules! push_souls {
|
|
|
|
($species:tt) => {
|
|
|
|
for s in comp::$species::ALL_SPECIES.iter() {
|
|
|
|
souls.push(npc_names.$species.species[s].keyword.clone())
|
|
|
|
}
|
|
|
|
};
|
|
|
|
($base:tt, $($species:tt),+ $(,)?) => {
|
|
|
|
push_souls!($base);
|
|
|
|
push_souls!($($species),+);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for npc in npc::ALL_NPCS.iter() {
|
|
|
|
souls.push(npc_names[*npc].keyword.clone())
|
|
|
|
}
|
|
|
|
|
|
|
|
// See `[AllBodies](crate::comp::body::AllBodies)`
|
|
|
|
push_souls!(
|
|
|
|
humanoid,
|
|
|
|
quadruped_small,
|
|
|
|
quadruped_medium,
|
|
|
|
quadruped_low,
|
|
|
|
bird_medium,
|
|
|
|
bird_large,
|
|
|
|
fish_small,
|
|
|
|
fish_medium,
|
|
|
|
biped_small,
|
|
|
|
biped_large,
|
|
|
|
theropod,
|
|
|
|
dragon,
|
|
|
|
golem,
|
2021-07-25 15:16:57 +00:00
|
|
|
arthropod,
|
2021-05-09 15:25:52 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
souls
|
2020-05-09 02:42:51 +00:00
|
|
|
};
|
|
|
|
static ref OBJECTS: Vec<String> = comp::object::ALL_OBJECTS
|
|
|
|
.iter()
|
|
|
|
.map(|o| o.to_string().to_string())
|
|
|
|
.collect();
|
|
|
|
static ref TIMES: Vec<String> = vec![
|
|
|
|
"midnight", "night", "dawn", "morning", "day", "noon", "dusk"
|
|
|
|
]
|
|
|
|
.iter()
|
|
|
|
.map(|s| s.to_string())
|
|
|
|
.collect();
|
2020-05-11 22:02:21 +00:00
|
|
|
|
2022-06-02 20:51:17 +00:00
|
|
|
static ref WEATHERS: Vec<String> = vec![
|
|
|
|
"clear", "cloudy", "rain", "wind", "storm"
|
|
|
|
]
|
|
|
|
.iter()
|
|
|
|
.map(|s| s.to_string())
|
|
|
|
.collect();
|
|
|
|
|
2021-05-04 13:22:10 +00:00
|
|
|
pub static ref BUFF_PARSER: HashMap<String, BuffKind> = {
|
|
|
|
let string_from_buff = |kind| match kind {
|
|
|
|
BuffKind::Burning => "burning",
|
2022-07-15 16:59:37 +00:00
|
|
|
BuffKind::Regeneration => "regeneration",
|
2021-05-04 13:22:10 +00:00
|
|
|
BuffKind::Saturation => "saturation",
|
|
|
|
BuffKind::Bleeding => "bleeding",
|
|
|
|
BuffKind::Cursed => "cursed",
|
|
|
|
BuffKind::Potion => "potion",
|
|
|
|
BuffKind::CampfireHeal => "campfire_heal",
|
2022-09-05 14:16:18 +00:00
|
|
|
BuffKind::EnergyRegen => "energy_regen",
|
2021-05-04 13:22:10 +00:00
|
|
|
BuffKind::IncreaseMaxEnergy => "increase_max_energy",
|
|
|
|
BuffKind::IncreaseMaxHealth => "increase_max_health",
|
|
|
|
BuffKind::Invulnerability => "invulnerability",
|
|
|
|
BuffKind::ProtectingWard => "protecting_ward",
|
|
|
|
BuffKind::Frenzied => "frenzied",
|
|
|
|
BuffKind::Crippled => "crippled",
|
2021-05-30 15:51:47 +00:00
|
|
|
BuffKind::Frozen => "frozen",
|
2021-05-24 00:45:22 +00:00
|
|
|
BuffKind::Wet => "wet",
|
2021-06-20 05:37:22 +00:00
|
|
|
BuffKind::Ensnared => "ensnared",
|
2021-09-02 23:57:17 +00:00
|
|
|
BuffKind::Poisoned => "poisoned",
|
2022-02-09 01:23:23 +00:00
|
|
|
BuffKind::Hastened => "hastened",
|
2022-03-05 20:51:41 +00:00
|
|
|
BuffKind::Fortitude => "fortitude",
|
2022-09-07 01:23:12 +00:00
|
|
|
BuffKind::Parried => "parried",
|
2023-01-14 00:48:59 +00:00
|
|
|
BuffKind::PotionSickness => "potion_sickness",
|
2022-12-19 18:26:03 +00:00
|
|
|
BuffKind::Reckless => "reckless",
|
2023-03-29 23:11:59 +00:00
|
|
|
BuffKind::Polymorphed(_) => "polymorphed",
|
2021-05-04 13:22:10 +00:00
|
|
|
};
|
|
|
|
let mut buff_parser = HashMap::new();
|
2022-09-05 14:16:18 +00:00
|
|
|
for kind in BuffKind::iter() {
|
|
|
|
buff_parser.insert(string_from_buff(kind).to_string(), kind);
|
|
|
|
}
|
2021-05-04 13:22:10 +00:00
|
|
|
buff_parser
|
|
|
|
};
|
|
|
|
|
|
|
|
pub static ref BUFF_PACK: Vec<String> = {
|
|
|
|
let mut buff_pack: Vec<_> = BUFF_PARSER.keys().cloned().collect();
|
|
|
|
// Remove invulnerability as it removes debuffs
|
|
|
|
buff_pack.retain(|kind| kind != "invulnerability");
|
|
|
|
buff_pack
|
|
|
|
};
|
|
|
|
|
|
|
|
static ref BUFFS: Vec<String> = {
|
|
|
|
let mut buff_pack: Vec<_> = BUFF_PARSER.keys().cloned().collect();
|
|
|
|
// Add all as valid command
|
|
|
|
buff_pack.push("all".to_string());
|
|
|
|
buff_pack
|
|
|
|
};
|
2021-05-02 21:42:54 +00:00
|
|
|
|
2021-06-26 14:54:17 +00:00
|
|
|
static ref BLOCK_KINDS: Vec<String> = terrain::block::BlockKind::iter()
|
|
|
|
.map(|bk| bk.to_string())
|
2020-06-27 18:39:16 +00:00
|
|
|
.collect();
|
|
|
|
|
2020-09-21 15:39:20 +00:00
|
|
|
static ref SPRITE_KINDS: Vec<String> = terrain::sprite::SPRITE_KINDS
|
|
|
|
.keys()
|
|
|
|
.cloned()
|
|
|
|
.collect();
|
|
|
|
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
static ref ROLES: Vec<String> = ["admin", "moderator"].iter().copied().map(Into::into).collect();
|
|
|
|
|
2020-05-11 22:02:21 +00:00
|
|
|
/// List of item specifiers. Useful for tab completing
|
2021-08-09 21:25:36 +00:00
|
|
|
pub static ref ITEM_SPECS: Vec<String> = {
|
|
|
|
let mut items = try_all_item_defs()
|
|
|
|
.unwrap_or_else(|e| {
|
|
|
|
warn!(?e, "Failed to load item specifiers");
|
|
|
|
Vec::new()
|
|
|
|
});
|
2020-05-11 22:02:21 +00:00
|
|
|
items.sort();
|
|
|
|
items
|
|
|
|
};
|
2021-04-12 18:07:34 +00:00
|
|
|
|
2021-08-15 11:45:50 +00:00
|
|
|
/// List of all entity configs. Useful for tab completing
|
|
|
|
static ref ENTITY_CONFIGS: Vec<String> = {
|
|
|
|
try_all_entity_configs()
|
|
|
|
.unwrap_or_else(|e| {
|
|
|
|
warn!(?e, "Failed to load entity configs");
|
|
|
|
Vec::new()
|
|
|
|
})
|
|
|
|
};
|
|
|
|
|
2021-08-21 09:23:26 +00:00
|
|
|
pub static ref KITS: Vec<String> = {
|
2021-08-09 17:18:33 +00:00
|
|
|
if let Ok(kits) = KitManifest::load(KIT_MANIFEST_PATH) {
|
2021-08-21 09:23:26 +00:00
|
|
|
let mut kits = kits.read().0.keys().cloned().collect::<Vec<String>>();
|
|
|
|
kits.sort();
|
|
|
|
kits
|
2021-04-12 18:07:34 +00:00
|
|
|
} else {
|
|
|
|
Vec::new()
|
|
|
|
}
|
|
|
|
};
|
2021-05-08 15:47:09 +00:00
|
|
|
|
|
|
|
static ref PRESETS: HashMap<String, Vec<(Skill, u8)>> = {
|
2021-08-09 17:18:33 +00:00
|
|
|
if let Ok(presets) = SkillPresetManifest::load(PRESET_MANIFEST_PATH) {
|
2021-05-08 15:47:09 +00:00
|
|
|
presets.read().0.clone()
|
|
|
|
} else {
|
|
|
|
warn!("Error while loading presets");
|
|
|
|
HashMap::new()
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
static ref PRESET_LIST: Vec<String> = {
|
|
|
|
let mut preset_list: Vec<String> = PRESETS.keys().cloned().collect();
|
|
|
|
preset_list.push("clear".to_owned());
|
|
|
|
|
|
|
|
preset_list
|
|
|
|
};
|
2020-05-09 02:42:51 +00:00
|
|
|
}
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
// Please keep this sorted alphabetically :-)
|
|
|
|
#[derive(Copy, Clone, strum::EnumIter)]
|
|
|
|
pub enum ServerChatCommand {
|
|
|
|
Adminify,
|
|
|
|
Airship,
|
|
|
|
Alias,
|
|
|
|
Ban,
|
|
|
|
BattleMode,
|
|
|
|
BattleModeForce,
|
2022-08-20 12:20:27 +00:00
|
|
|
Body,
|
2023-01-22 23:50:29 +00:00
|
|
|
Buff,
|
2022-06-14 20:35:01 +00:00
|
|
|
Build,
|
|
|
|
BuildAreaAdd,
|
|
|
|
BuildAreaList,
|
|
|
|
BuildAreaRemove,
|
|
|
|
Campfire,
|
2022-11-16 09:46:53 +00:00
|
|
|
CreateLocation,
|
2022-06-14 20:35:01 +00:00
|
|
|
DebugColumn,
|
2022-10-29 18:32:48 +00:00
|
|
|
DebugWays,
|
2022-11-16 09:46:53 +00:00
|
|
|
DeleteLocation,
|
2022-06-14 20:35:01 +00:00
|
|
|
DisconnectAllPlayers,
|
|
|
|
DropAll,
|
|
|
|
Dummy,
|
|
|
|
Explosion,
|
|
|
|
Faction,
|
|
|
|
GiveItem,
|
|
|
|
Goto,
|
|
|
|
Group,
|
|
|
|
GroupInvite,
|
|
|
|
GroupKick,
|
|
|
|
GroupLeave,
|
|
|
|
GroupPromote,
|
|
|
|
Health,
|
2023-01-22 23:50:29 +00:00
|
|
|
Help,
|
2022-06-14 20:35:01 +00:00
|
|
|
JoinFaction,
|
|
|
|
Jump,
|
|
|
|
Kick,
|
|
|
|
Kill,
|
|
|
|
KillNpcs,
|
|
|
|
Kit,
|
|
|
|
Lantern,
|
|
|
|
Light,
|
2022-11-16 09:46:53 +00:00
|
|
|
Lightning,
|
|
|
|
Location,
|
2022-06-14 20:35:01 +00:00
|
|
|
MakeBlock,
|
|
|
|
MakeNpc,
|
|
|
|
MakeSprite,
|
2022-11-16 09:46:53 +00:00
|
|
|
MakeVolume,
|
2022-06-14 20:35:01 +00:00
|
|
|
Motd,
|
|
|
|
Object,
|
|
|
|
PermitBuild,
|
|
|
|
Players,
|
|
|
|
Region,
|
|
|
|
ReloadChunks,
|
|
|
|
RemoveLights,
|
2023-04-01 16:37:01 +00:00
|
|
|
Respawn,
|
2022-06-14 20:35:01 +00:00
|
|
|
RevokeBuild,
|
|
|
|
RevokeBuildAll,
|
2023-04-05 12:57:41 +00:00
|
|
|
RtsimChunk,
|
|
|
|
RtsimInfo,
|
|
|
|
RtsimNpc,
|
|
|
|
RtsimPurge,
|
|
|
|
RtsimTp,
|
2022-06-14 20:35:01 +00:00
|
|
|
Safezone,
|
|
|
|
Say,
|
2022-08-10 23:40:30 +00:00
|
|
|
Scale,
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerPhysics,
|
|
|
|
SetMotd,
|
|
|
|
Ship,
|
|
|
|
Site,
|
|
|
|
SkillPoint,
|
|
|
|
SkillPreset,
|
|
|
|
Spawn,
|
|
|
|
Sudo,
|
|
|
|
Tell,
|
|
|
|
Time,
|
|
|
|
Tp,
|
|
|
|
Unban,
|
|
|
|
Version,
|
|
|
|
Waypoint,
|
2022-11-16 09:46:53 +00:00
|
|
|
WeatherZone,
|
2022-06-14 20:35:01 +00:00
|
|
|
Whitelist,
|
|
|
|
Wiring,
|
|
|
|
World,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl ServerChatCommand {
|
2020-05-05 22:33:16 +00:00
|
|
|
pub fn data(&self) -> ChatCommandData {
|
|
|
|
use ArgumentSpec::*;
|
2020-05-09 02:42:51 +00:00
|
|
|
use Requirement::*;
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
use Role::*;
|
2020-05-05 22:33:16 +00:00
|
|
|
let cmd = ChatCommandData::new;
|
|
|
|
match self {
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Adminify => cmd(
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
vec![PlayerName(Required), Enum("role", ROLES.clone(), Optional)],
|
|
|
|
"Temporarily gives a player a restricted admin role or removes the current one \
|
|
|
|
(if not given)",
|
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Airship => cmd(
|
2021-03-12 22:14:08 +00:00
|
|
|
vec![Float("destination_degrees_ccw_of_east", 90.0, Optional)],
|
|
|
|
"Spawns an airship",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-03-12 22:14:08 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Alias => cmd(
|
2021-06-17 18:55:46 +00:00
|
|
|
vec![Any("name", Required)],
|
|
|
|
"Change your alias",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2023-01-22 23:50:29 +00:00
|
|
|
ServerChatCommand::Buff => cmd(
|
2021-05-02 21:42:54 +00:00
|
|
|
vec![
|
|
|
|
Enum("buff", BUFFS.clone(), Required),
|
|
|
|
Float("strength", 0.01, Optional),
|
|
|
|
Float("duration", 10.0, Optional),
|
|
|
|
],
|
|
|
|
"Cast a buff on player",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-05-02 21:42:54 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Ban => cmd(
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
vec![
|
2022-02-17 14:51:59 +00:00
|
|
|
PlayerName(Required),
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Boolean("overwrite", "true".to_string(), Optional),
|
|
|
|
Any("ban duration", Optional),
|
|
|
|
Message(Optional),
|
|
|
|
],
|
|
|
|
"Ban a player with a given username, for a given duration (if provided). Pass \
|
|
|
|
true for overwrite to alter an existing ban..",
|
|
|
|
Some(Moderator),
|
2020-07-15 23:36:03 +00:00
|
|
|
),
|
2021-08-27 18:49:58 +00:00
|
|
|
#[rustfmt::skip]
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::BattleMode => cmd(
|
2021-08-27 16:25:05 +00:00
|
|
|
vec![Enum(
|
|
|
|
"battle mode",
|
|
|
|
vec!["pvp".to_owned(), "pve".to_owned()],
|
|
|
|
Optional,
|
|
|
|
)],
|
2021-09-04 17:56:55 +00:00
|
|
|
"Set your battle mode to:\n\
|
|
|
|
* pvp (player vs player)\n\
|
|
|
|
* pve (player vs environment).\n\
|
2021-08-27 16:25:05 +00:00
|
|
|
If called without arguments will show current battle mode.",
|
|
|
|
None,
|
2022-06-14 20:35:01 +00:00
|
|
|
|
2021-08-27 16:25:05 +00:00
|
|
|
),
|
2022-08-20 12:20:27 +00:00
|
|
|
ServerChatCommand::Body => cmd(
|
|
|
|
vec![Enum("body", ENTITIES.clone(), Required)],
|
|
|
|
"Change your body to different species",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::BattleModeForce => cmd(
|
2021-08-27 16:25:05 +00:00
|
|
|
vec![Enum(
|
|
|
|
"battle mode",
|
|
|
|
vec!["pvp".to_owned(), "pve".to_owned()],
|
|
|
|
Required,
|
|
|
|
)],
|
|
|
|
"Change your battle mode flag without any checks",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Build => cmd(vec![], "Toggles build mode on and off", None),
|
|
|
|
ServerChatCommand::BuildAreaAdd => cmd(
|
2021-03-24 07:58:42 +00:00
|
|
|
vec![
|
|
|
|
Any("name", Required),
|
|
|
|
Integer("xlo", 0, Required),
|
|
|
|
Integer("xhi", 10, Required),
|
|
|
|
Integer("ylo", 0, Required),
|
|
|
|
Integer("yhi", 10, Required),
|
|
|
|
Integer("zlo", 0, Required),
|
|
|
|
Integer("zhi", 10, Required),
|
|
|
|
],
|
|
|
|
"Adds a new build area",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-03-24 07:58:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::BuildAreaList => cmd(vec![], "List all build areas", Some(Admin)),
|
|
|
|
ServerChatCommand::BuildAreaRemove => cmd(
|
2021-03-24 07:58:42 +00:00
|
|
|
vec![Any("name", Required)],
|
|
|
|
"Removes specified build area",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-03-24 07:58:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Campfire => cmd(vec![], "Spawns a campfire", Some(Admin)),
|
|
|
|
ServerChatCommand::DebugColumn => cmd(
|
2020-05-09 20:41:29 +00:00
|
|
|
vec![Integer("x", 15000, Required), Integer("y", 15000, Required)],
|
2020-05-05 22:33:16 +00:00
|
|
|
"Prints some debug information about a column",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-10-29 18:32:48 +00:00
|
|
|
ServerChatCommand::DebugWays => cmd(
|
|
|
|
vec![Integer("x", 15000, Required), Integer("y", 15000, Required)],
|
|
|
|
"Prints some debug information about a column's ways",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::DisconnectAllPlayers => cmd(
|
2021-04-13 22:05:47 +00:00
|
|
|
vec![Any("confirm", Required)],
|
|
|
|
"Disconnects all players from the server",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::DropAll => cmd(
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
vec![],
|
|
|
|
"Drops all your items on the ground",
|
|
|
|
Some(Moderator),
|
2021-04-13 22:05:47 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Dummy => cmd(vec![], "Spawns a training dummy", Some(Admin)),
|
|
|
|
ServerChatCommand::Explosion => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![Float("radius", 5.0, Required)],
|
2020-05-05 22:33:16 +00:00
|
|
|
"Explodes the ground around you",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-06-01 04:33:39 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Faction => cmd(
|
2020-06-01 04:33:39 +00:00
|
|
|
vec![Message(Optional)],
|
|
|
|
"Send messages to your faction",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::GiveItem => cmd(
|
2020-05-09 20:41:29 +00:00
|
|
|
vec![
|
2020-05-11 22:02:21 +00:00
|
|
|
Enum("item", ITEM_SPECS.clone(), Required),
|
2020-05-09 20:41:29 +00:00
|
|
|
Integer("num", 1, Optional),
|
|
|
|
],
|
2022-02-02 08:50:23 +00:00
|
|
|
"Give yourself some items.\nFor an example or to auto complete use Tab.",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Goto => cmd(
|
2020-05-05 22:33:16 +00:00
|
|
|
vec![
|
2020-05-09 02:42:51 +00:00
|
|
|
Float("x", 0.0, Required),
|
|
|
|
Float("y", 0.0, Required),
|
|
|
|
Float("z", 0.0, Required),
|
2020-05-05 22:33:16 +00:00
|
|
|
],
|
|
|
|
"Teleport to a position",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Group => {
|
|
|
|
cmd(vec![Message(Optional)], "Send messages to your group", None)
|
|
|
|
},
|
|
|
|
ServerChatCommand::GroupInvite => cmd(
|
2020-12-04 02:18:42 +00:00
|
|
|
vec![PlayerName(Required)],
|
|
|
|
"Invite a player to join a group",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-12-04 02:18:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::GroupKick => cmd(
|
2020-12-04 02:18:42 +00:00
|
|
|
vec![PlayerName(Required)],
|
|
|
|
"Remove a player from a group",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-12-04 02:18:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::GroupLeave => cmd(vec![], "Leave the current group", None),
|
|
|
|
ServerChatCommand::GroupPromote => cmd(
|
2020-12-04 02:18:42 +00:00
|
|
|
vec![PlayerName(Required)],
|
|
|
|
"Promote a player to group leader",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-12-04 02:18:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Health => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![Integer("hp", 100, Required)],
|
2020-05-05 22:33:16 +00:00
|
|
|
"Set your current health",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2023-01-22 23:50:29 +00:00
|
|
|
ServerChatCommand::Help => ChatCommandData::new(
|
|
|
|
vec![Command(Optional)],
|
|
|
|
"Display information about commands",
|
|
|
|
None,
|
|
|
|
),
|
2023-04-01 16:37:01 +00:00
|
|
|
ServerChatCommand::Respawn => cmd(vec![], "Teleport to your waypoint", Some(Moderator)),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::JoinFaction => ChatCommandData::new(
|
2020-06-04 09:40:05 +00:00
|
|
|
vec![Any("faction", Optional)],
|
|
|
|
"Join/leave the specified faction",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-06-04 09:40:05 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Jump => cmd(
|
2020-05-05 22:33:16 +00:00
|
|
|
vec![
|
2020-05-09 02:42:51 +00:00
|
|
|
Float("x", 0.0, Required),
|
|
|
|
Float("y", 0.0, Required),
|
|
|
|
Float("z", 0.0, Required),
|
2020-05-05 22:33:16 +00:00
|
|
|
],
|
|
|
|
"Offset your current position",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Kick => cmd(
|
2022-02-17 14:51:59 +00:00
|
|
|
vec![PlayerName(Required), Message(Optional)],
|
2020-07-15 23:36:03 +00:00
|
|
|
"Kick a player with a given username",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2020-07-15 23:36:03 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Kill => cmd(vec![], "Kill yourself", None),
|
|
|
|
ServerChatCommand::KillNpcs => cmd(vec![], "Kill the NPCs", Some(Admin)),
|
|
|
|
ServerChatCommand::Kit => cmd(
|
2021-04-12 18:07:34 +00:00
|
|
|
vec![Enum("kit_name", KITS.to_vec(), Required)],
|
2021-04-12 16:49:08 +00:00
|
|
|
"Place a set of items into your inventory.",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-04-12 16:49:08 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Lantern => cmd(
|
2020-05-05 22:33:16 +00:00
|
|
|
vec![
|
2020-05-09 02:42:51 +00:00
|
|
|
Float("strength", 5.0, Required),
|
|
|
|
Float("r", 1.0, Optional),
|
|
|
|
Float("g", 1.0, Optional),
|
|
|
|
Float("b", 1.0, Optional),
|
2020-05-05 22:33:16 +00:00
|
|
|
],
|
|
|
|
"Change your lantern's strength and color",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Light => cmd(
|
2020-05-05 22:33:16 +00:00
|
|
|
vec![
|
2020-05-09 02:42:51 +00:00
|
|
|
Float("r", 1.0, Optional),
|
|
|
|
Float("g", 1.0, Optional),
|
|
|
|
Float("b", 1.0, Optional),
|
|
|
|
Float("x", 0.0, Optional),
|
|
|
|
Float("y", 0.0, Optional),
|
|
|
|
Float("z", 0.0, Optional),
|
|
|
|
Float("strength", 5.0, Optional),
|
2020-05-05 22:33:16 +00:00
|
|
|
],
|
|
|
|
"Spawn entity with light",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::MakeBlock => cmd(
|
2021-07-23 12:04:16 +00:00
|
|
|
vec![
|
|
|
|
Enum("block", BLOCK_KINDS.clone(), Required),
|
|
|
|
Integer("r", 255, Optional),
|
|
|
|
Integer("g", 255, Optional),
|
|
|
|
Integer("b", 255, Optional),
|
|
|
|
],
|
|
|
|
"Make a block at your location with a color",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-09-21 15:39:20 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::MakeNpc => cmd(
|
2021-08-15 11:45:50 +00:00
|
|
|
vec![
|
|
|
|
Enum("entity_config", ENTITY_CONFIGS.clone(), Required),
|
|
|
|
Integer("num", 1, Optional),
|
|
|
|
],
|
2022-02-02 08:50:23 +00:00
|
|
|
"Spawn entity from config near you.\nFor an example or to auto complete use Tab.",
|
2021-08-15 11:45:50 +00:00
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::MakeSprite => cmd(
|
2020-09-21 15:39:20 +00:00
|
|
|
vec![Enum("sprite", SPRITE_KINDS.clone(), Required)],
|
|
|
|
"Make a sprite at your location",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-06-27 23:12:12 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Motd => {
|
|
|
|
cmd(vec![Message(Optional)], "View the server description", None)
|
|
|
|
},
|
|
|
|
ServerChatCommand::Object => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![Enum("object", OBJECTS.clone(), Required)],
|
|
|
|
"Spawn an object",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-09 02:42:51 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::PermitBuild => cmd(
|
2021-03-27 05:53:33 +00:00
|
|
|
vec![Any("area_name", Required)],
|
2021-03-23 08:37:29 +00:00
|
|
|
"Grants player a bounded box they can build in",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-03-23 08:37:29 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Players => cmd(vec![], "Lists players currently online", None),
|
|
|
|
ServerChatCommand::ReloadChunks => cmd(
|
2022-03-19 08:43:38 +00:00
|
|
|
vec![],
|
|
|
|
"Reloads all chunks loaded on the server",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::RemoveLights => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![Float("radius", 20.0, Optional)],
|
2020-05-05 22:33:16 +00:00
|
|
|
"Removes all lights spawned by players",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-06-01 04:33:39 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::RevokeBuild => cmd(
|
2021-03-27 05:53:33 +00:00
|
|
|
vec![Any("area_name", Required)],
|
|
|
|
"Revokes build area permission for player",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-03-24 07:58:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::RevokeBuildAll => cmd(
|
2021-03-27 05:53:33 +00:00
|
|
|
vec![],
|
|
|
|
"Revokes all build area permissions for player",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-03-24 07:58:42 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Region => cmd(
|
2020-06-01 04:33:39 +00:00
|
|
|
vec![Message(Optional)],
|
|
|
|
"Send messages to everyone in your region of the world",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-06-01 04:33:39 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Safezone => cmd(
|
2021-02-28 23:14:59 +00:00
|
|
|
vec![Float("range", 100.0, Optional)],
|
|
|
|
"Creates a safezone",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2021-02-28 23:14:59 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Say => cmd(
|
2020-06-01 04:33:39 +00:00
|
|
|
vec![Message(Optional)],
|
|
|
|
"Send messages to everyone within shouting distance",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::ServerPhysics => cmd(
|
2021-04-17 17:44:22 +00:00
|
|
|
vec![
|
2022-02-17 14:51:59 +00:00
|
|
|
PlayerName(Required),
|
2021-04-17 17:44:22 +00:00
|
|
|
Boolean("enabled", "true".to_string(), Optional),
|
|
|
|
],
|
|
|
|
"Set/unset server-authoritative physics for an account",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::SetMotd => cmd(
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
vec![Message(Optional)],
|
|
|
|
"Set the server description",
|
|
|
|
Some(Admin),
|
2021-04-17 17:44:22 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Ship => cmd(
|
2022-02-18 08:34:14 +00:00
|
|
|
vec![Float("destination_degrees_ccw_of_east", 90.0, Optional)],
|
|
|
|
"Spawns a ship",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2021-08-15 11:45:50 +00:00
|
|
|
// Uses Message because site names can contain spaces,
|
|
|
|
// which would be assumed to be separators otherwise
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Site => cmd(
|
2022-05-15 21:57:21 +00:00
|
|
|
vec![SiteName(Required)],
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
"Teleport to a site",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::SkillPoint => cmd(
|
2021-01-06 01:26:21 +00:00
|
|
|
vec![
|
|
|
|
Enum("skill tree", SKILL_TREES.clone(), Required),
|
|
|
|
Integer("amount", 1, Optional),
|
|
|
|
],
|
|
|
|
"Give yourself skill points for a particular skill tree",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-01-06 01:26:21 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::SkillPreset => cmd(
|
2021-05-08 15:47:09 +00:00
|
|
|
vec![Enum("preset_name", PRESET_LIST.to_vec(), Required)],
|
|
|
|
"Gives your character desired skills.",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2021-05-08 15:47:09 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Spawn => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![
|
|
|
|
Enum("alignment", ALIGNMENTS.clone(), Required),
|
|
|
|
Enum("entity", ENTITIES.clone(), Required),
|
|
|
|
Integer("amount", 1, Optional),
|
2020-07-02 21:53:01 +00:00
|
|
|
Boolean("ai", "true".to_string(), Optional),
|
2022-08-11 17:57:13 +00:00
|
|
|
Float("ai", 1.0, Optional),
|
2020-05-09 02:42:51 +00:00
|
|
|
],
|
|
|
|
"Spawn a test entity",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-09 02:42:51 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Sudo => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![PlayerName(Required), SubCommand],
|
2020-05-05 22:33:16 +00:00
|
|
|
"Run command as if you were another player",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Tell => cmd(
|
2020-06-01 04:33:39 +00:00
|
|
|
vec![PlayerName(Required), Message(Optional)],
|
2020-05-05 22:33:16 +00:00
|
|
|
"Send a message to another player",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-05-05 22:33:16 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Time => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![Enum("time", TIMES.clone(), Optional)],
|
|
|
|
"Set the time of day",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Admin),
|
2020-05-09 02:42:51 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Tp => cmd(
|
2020-05-09 02:42:51 +00:00
|
|
|
vec![PlayerName(Optional)],
|
|
|
|
"Teleport to another player",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2020-05-09 02:42:51 +00:00
|
|
|
),
|
2023-03-31 22:20:52 +00:00
|
|
|
ServerChatCommand::RtsimTp => cmd(
|
2022-08-12 15:57:55 +00:00
|
|
|
vec![Integer("npc index", 0, Required)],
|
2023-01-05 15:09:32 +00:00
|
|
|
"Teleport to an rtsim npc",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2023-03-31 22:20:52 +00:00
|
|
|
ServerChatCommand::RtsimInfo => cmd(
|
2023-01-05 15:09:32 +00:00
|
|
|
vec![Integer("npc index", 0, Required)],
|
|
|
|
"Display information about an rtsim NPC",
|
2022-08-12 15:57:55 +00:00
|
|
|
Some(Moderator),
|
|
|
|
),
|
2023-04-02 22:02:06 +00:00
|
|
|
ServerChatCommand::RtsimNpc => cmd(
|
|
|
|
vec![Any("query", Required)],
|
|
|
|
"List rtsim NPCs that fit a given query (e.g: simulated,merchant)",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2023-03-31 22:20:52 +00:00
|
|
|
ServerChatCommand::RtsimPurge => cmd(
|
|
|
|
vec![Boolean(
|
|
|
|
"whether purging of rtsim data should occur on next startup",
|
|
|
|
true.to_string(),
|
|
|
|
Required,
|
|
|
|
)],
|
|
|
|
"Purge rtsim data on next startup",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2023-01-06 01:16:15 +00:00
|
|
|
ServerChatCommand::RtsimChunk => cmd(
|
|
|
|
vec![],
|
|
|
|
"Display information about the current chunk from rtsim",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Unban => cmd(
|
2022-02-17 14:51:59 +00:00
|
|
|
vec![PlayerName(Required)],
|
2020-07-15 23:36:03 +00:00
|
|
|
"Remove the ban for the given username",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2020-07-15 23:36:03 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Version => cmd(vec![], "Prints server version", None),
|
|
|
|
ServerChatCommand::Waypoint => cmd(
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
vec![],
|
|
|
|
"Set your waypoint to your current position",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Wiring => cmd(vec![], "Create wiring element", Some(Admin)),
|
|
|
|
ServerChatCommand::Whitelist => cmd(
|
2022-02-17 14:51:59 +00:00
|
|
|
vec![Any("add/remove", Required), PlayerName(Required)],
|
2020-06-30 12:21:36 +00:00
|
|
|
"Adds/removes username to whitelist",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
Some(Moderator),
|
2020-06-30 12:21:36 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::World => cmd(
|
2020-06-01 04:33:39 +00:00
|
|
|
vec![Message(Optional)],
|
|
|
|
"Send messages to everyone on the server",
|
Added non-admin moderators and timed bans.
The security model has been updated to reflect this change (for example,
moderators cannot revert a ban by an administrator). Ban history is
also now recorded in the ban file, and much more information about the
ban is stored (whitelists and administrators also have extra
information).
To support the new information without losing important information,
this commit also introduces a new migration path for editable settings
(both from legacy to the new format, and between versions). Examples
of how to do this correctly, and migrate to new versions of a settings
file, are in the settings/ subdirectory.
As part of this effort, editable settings have been revamped to
guarantee atomic saves (due to the increased amount of information in
each file), some latent bugs in networking were fixed, and server-cli
has been updated to go through StructOpt for both calls through TUI
and argv, greatly simplifying parsing logic.
2021-05-08 18:22:21 +00:00
|
|
|
None,
|
2020-06-01 04:33:39 +00:00
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::MakeVolume => {
|
|
|
|
cmd(vec![], "Create a volume (experimental)", Some(Admin))
|
|
|
|
},
|
|
|
|
ServerChatCommand::Location => {
|
2022-02-17 14:51:59 +00:00
|
|
|
cmd(vec![Any("name", Required)], "Teleport to a location", None)
|
|
|
|
},
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::CreateLocation => cmd(
|
2022-02-17 14:51:59 +00:00
|
|
|
vec![Any("name", Required)],
|
|
|
|
"Create a location at the current position",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::DeleteLocation => cmd(
|
2022-02-17 14:51:59 +00:00
|
|
|
vec![Any("name", Required)],
|
|
|
|
"Delete a location",
|
|
|
|
Some(Moderator),
|
|
|
|
),
|
2022-06-02 20:51:17 +00:00
|
|
|
ServerChatCommand::WeatherZone => cmd(
|
|
|
|
vec![
|
|
|
|
Enum("weather kind", WEATHERS.clone(), Required),
|
|
|
|
Float("radius", 500.0, Optional),
|
|
|
|
Float("time", 300.0, Optional),
|
|
|
|
],
|
|
|
|
"Create a weather zone",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2022-07-09 00:59:18 +00:00
|
|
|
ServerChatCommand::Lightning => {
|
|
|
|
cmd(vec![], "Lightning strike at current position", Some(Admin))
|
|
|
|
},
|
2023-03-22 09:59:34 +00:00
|
|
|
ServerChatCommand::Scale => cmd(
|
|
|
|
vec![
|
|
|
|
Float("factor", 1.0, Required),
|
|
|
|
Boolean("reset_mass", true.to_string(), Optional),
|
|
|
|
],
|
|
|
|
"Scale your character",
|
|
|
|
Some(Admin),
|
|
|
|
),
|
2020-05-05 22:33:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
/// The keyword used to invoke the command, omitting the prefix.
|
2020-05-05 22:33:16 +00:00
|
|
|
pub fn keyword(&self) -> &'static str {
|
|
|
|
match self {
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Adminify => "adminify",
|
|
|
|
ServerChatCommand::Airship => "airship",
|
|
|
|
ServerChatCommand::Alias => "alias",
|
|
|
|
ServerChatCommand::Ban => "ban",
|
|
|
|
ServerChatCommand::BattleMode => "battlemode",
|
|
|
|
ServerChatCommand::BattleModeForce => "battlemode_force",
|
2022-08-20 12:20:27 +00:00
|
|
|
ServerChatCommand::Body => "body",
|
2023-01-22 23:50:29 +00:00
|
|
|
ServerChatCommand::Buff => "buff",
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Build => "build",
|
|
|
|
ServerChatCommand::BuildAreaAdd => "build_area_add",
|
|
|
|
ServerChatCommand::BuildAreaList => "build_area_list",
|
|
|
|
ServerChatCommand::BuildAreaRemove => "build_area_remove",
|
|
|
|
ServerChatCommand::Campfire => "campfire",
|
|
|
|
ServerChatCommand::DebugColumn => "debug_column",
|
2022-10-29 18:32:48 +00:00
|
|
|
ServerChatCommand::DebugWays => "debug_ways",
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::DisconnectAllPlayers => "disconnect_all_players",
|
|
|
|
ServerChatCommand::DropAll => "dropall",
|
|
|
|
ServerChatCommand::Dummy => "dummy",
|
|
|
|
ServerChatCommand::Explosion => "explosion",
|
|
|
|
ServerChatCommand::Faction => "faction",
|
|
|
|
ServerChatCommand::GiveItem => "give_item",
|
|
|
|
ServerChatCommand::Goto => "goto",
|
|
|
|
ServerChatCommand::Group => "group",
|
|
|
|
ServerChatCommand::GroupInvite => "group_invite",
|
|
|
|
ServerChatCommand::GroupKick => "group_kick",
|
|
|
|
ServerChatCommand::GroupPromote => "group_promote",
|
|
|
|
ServerChatCommand::GroupLeave => "group_leave",
|
|
|
|
ServerChatCommand::Health => "health",
|
2023-01-22 23:50:29 +00:00
|
|
|
ServerChatCommand::Help => "help",
|
2023-04-01 16:37:01 +00:00
|
|
|
ServerChatCommand::Respawn => "respawn",
|
2023-01-20 01:28:28 +00:00
|
|
|
ServerChatCommand::JoinFaction => "join_faction",
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Jump => "jump",
|
|
|
|
ServerChatCommand::Kick => "kick",
|
|
|
|
ServerChatCommand::Kill => "kill",
|
|
|
|
ServerChatCommand::KillNpcs => "kill_npcs",
|
2023-01-20 01:28:28 +00:00
|
|
|
ServerChatCommand::Kit => "kit",
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Lantern => "lantern",
|
|
|
|
ServerChatCommand::Light => "light",
|
|
|
|
ServerChatCommand::MakeBlock => "make_block",
|
|
|
|
ServerChatCommand::MakeNpc => "make_npc",
|
|
|
|
ServerChatCommand::MakeSprite => "make_sprite",
|
|
|
|
ServerChatCommand::Motd => "motd",
|
|
|
|
ServerChatCommand::Object => "object",
|
|
|
|
ServerChatCommand::PermitBuild => "permit_build",
|
|
|
|
ServerChatCommand::Players => "players",
|
|
|
|
ServerChatCommand::Region => "region",
|
|
|
|
ServerChatCommand::ReloadChunks => "reload_chunks",
|
|
|
|
ServerChatCommand::RemoveLights => "remove_lights",
|
|
|
|
ServerChatCommand::RevokeBuild => "revoke_build",
|
|
|
|
ServerChatCommand::RevokeBuildAll => "revoke_build_all",
|
|
|
|
ServerChatCommand::Safezone => "safezone",
|
|
|
|
ServerChatCommand::Say => "say",
|
|
|
|
ServerChatCommand::ServerPhysics => "server_physics",
|
|
|
|
ServerChatCommand::SetMotd => "set_motd",
|
|
|
|
ServerChatCommand::Ship => "ship",
|
|
|
|
ServerChatCommand::Site => "site",
|
|
|
|
ServerChatCommand::SkillPoint => "skill_point",
|
|
|
|
ServerChatCommand::SkillPreset => "skill_preset",
|
|
|
|
ServerChatCommand::Spawn => "spawn",
|
|
|
|
ServerChatCommand::Sudo => "sudo",
|
|
|
|
ServerChatCommand::Tell => "tell",
|
|
|
|
ServerChatCommand::Time => "time",
|
|
|
|
ServerChatCommand::Tp => "tp",
|
2023-03-31 22:20:52 +00:00
|
|
|
ServerChatCommand::RtsimTp => "rtsim_tp",
|
|
|
|
ServerChatCommand::RtsimInfo => "rtsim_info",
|
2023-04-02 22:02:06 +00:00
|
|
|
ServerChatCommand::RtsimNpc => "rtsim_npc",
|
2023-03-31 22:20:52 +00:00
|
|
|
ServerChatCommand::RtsimPurge => "rtsim_purge",
|
2023-01-06 01:16:15 +00:00
|
|
|
ServerChatCommand::RtsimChunk => "rtsim_chunk",
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Unban => "unban",
|
|
|
|
ServerChatCommand::Version => "version",
|
|
|
|
ServerChatCommand::Waypoint => "waypoint",
|
|
|
|
ServerChatCommand::Wiring => "wiring",
|
|
|
|
ServerChatCommand::Whitelist => "whitelist",
|
|
|
|
ServerChatCommand::World => "world",
|
|
|
|
ServerChatCommand::MakeVolume => "make_volume",
|
|
|
|
ServerChatCommand::Location => "location",
|
|
|
|
ServerChatCommand::CreateLocation => "create_location",
|
|
|
|
ServerChatCommand::DeleteLocation => "delete_location",
|
2022-06-02 20:51:17 +00:00
|
|
|
ServerChatCommand::WeatherZone => "weather_zone",
|
2022-07-09 00:59:18 +00:00
|
|
|
ServerChatCommand::Lightning => "lightning",
|
2022-08-10 23:40:30 +00:00
|
|
|
ServerChatCommand::Scale => "scale",
|
2020-05-05 22:33:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-06 22:36:25 +00:00
|
|
|
/// The short keyword used to invoke the command, omitting the leading '/'.
|
|
|
|
/// Returns None if the command doesn't have a short keyword
|
|
|
|
pub fn short_keyword(&self) -> Option<&'static str> {
|
|
|
|
Some(match self {
|
2022-06-14 20:35:01 +00:00
|
|
|
ServerChatCommand::Faction => "f",
|
|
|
|
ServerChatCommand::Group => "g",
|
|
|
|
ServerChatCommand::Region => "r",
|
|
|
|
ServerChatCommand::Say => "s",
|
|
|
|
ServerChatCommand::Tell => "t",
|
|
|
|
ServerChatCommand::World => "w",
|
2021-06-06 22:36:25 +00:00
|
|
|
_ => return None,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
/// Produce an iterator over all the available commands
|
2023-03-11 12:59:30 +00:00
|
|
|
pub fn iter() -> impl Iterator<Item = Self> + Clone { <Self as IntoEnumIterator>::iter() }
|
2022-06-14 20:35:01 +00:00
|
|
|
|
2020-05-11 22:02:21 +00:00
|
|
|
/// A message that explains what the command does
|
2020-05-05 22:33:16 +00:00
|
|
|
pub fn help_string(&self) -> String {
|
|
|
|
let data = self.data();
|
|
|
|
let usage = std::iter::once(format!("/{}", self.keyword()))
|
|
|
|
.chain(data.args.iter().map(|arg| arg.usage_string()))
|
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.join(" ");
|
|
|
|
format!("{}: {}", usage, data.description)
|
|
|
|
}
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
/// Produce an iterator that first goes over all the short keywords
|
|
|
|
/// and their associated commands and then iterates over all the normal
|
|
|
|
/// keywords with their associated commands
|
|
|
|
pub fn iter_with_keywords() -> impl Iterator<Item = (&'static str, Self)> {
|
|
|
|
Self::iter()
|
|
|
|
// Go through all the shortcuts first
|
|
|
|
.filter_map(|c| c.short_keyword().map(|s| (s, c)))
|
|
|
|
.chain(Self::iter().map(|c| (c.keyword(), c)))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn needs_role(&self) -> Option<comp::AdminRole> { self.data().needs_role }
|
2020-05-05 22:33:16 +00:00
|
|
|
|
2020-05-11 22:02:21 +00:00
|
|
|
/// Returns a format string for parsing arguments with scan_fmt
|
2020-05-05 22:33:16 +00:00
|
|
|
pub fn arg_fmt(&self) -> String {
|
|
|
|
self.data()
|
|
|
|
.args
|
|
|
|
.iter()
|
|
|
|
.map(|arg| match arg {
|
|
|
|
ArgumentSpec::PlayerName(_) => "{}",
|
2022-05-15 21:57:21 +00:00
|
|
|
ArgumentSpec::SiteName(_) => "{/.*/}",
|
2020-05-08 21:38:58 +00:00
|
|
|
ArgumentSpec::Float(_, _, _) => "{}",
|
2020-05-05 22:33:16 +00:00
|
|
|
ArgumentSpec::Integer(_, _, _) => "{d}",
|
|
|
|
ArgumentSpec::Any(_, _) => "{}",
|
|
|
|
ArgumentSpec::Command(_) => "{}",
|
2020-06-01 04:33:39 +00:00
|
|
|
ArgumentSpec::Message(_) => "{/.*/}",
|
2020-05-08 21:38:58 +00:00
|
|
|
ArgumentSpec::SubCommand => "{} {/.*/}",
|
2020-06-05 18:12:18 +00:00
|
|
|
ArgumentSpec::Enum(_, _, _) => "{}",
|
2020-07-02 21:53:01 +00:00
|
|
|
ArgumentSpec::Boolean(_, _, _) => "{}",
|
2020-05-05 22:33:16 +00:00
|
|
|
})
|
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.join(" ")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
impl Display for ServerChatCommand {
|
2020-06-05 18:12:18 +00:00
|
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> {
|
|
|
|
write!(f, "{}", self.keyword())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
impl FromStr for ServerChatCommand {
|
2020-05-05 22:33:16 +00:00
|
|
|
type Err = ();
|
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
fn from_str(keyword: &str) -> Result<ServerChatCommand, ()> {
|
|
|
|
Self::iter()
|
|
|
|
// Go through all the shortcuts first
|
|
|
|
.filter_map(|c| c.short_keyword().map(|s| (s, c)))
|
|
|
|
.chain(Self::iter().map(|c| (c.keyword(), c)))
|
2021-06-06 22:36:25 +00:00
|
|
|
// Find command with matching string as keyword
|
2022-09-08 19:51:02 +00:00
|
|
|
.find_map(|(kwd, command)| (kwd == keyword).then_some(command))
|
2021-06-06 22:36:25 +00:00
|
|
|
// Return error if not found
|
|
|
|
.ok_or(())
|
2020-05-05 22:33:16 +00:00
|
|
|
}
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
|
2020-06-12 17:44:29 +00:00
|
|
|
#[derive(Eq, PartialEq, Debug)]
|
2020-05-09 02:42:51 +00:00
|
|
|
pub enum Requirement {
|
|
|
|
Required,
|
|
|
|
Optional,
|
|
|
|
}
|
|
|
|
|
2020-05-05 04:06:36 +00:00
|
|
|
/// Representation for chat command arguments
|
2020-05-05 22:33:16 +00:00
|
|
|
pub enum ArgumentSpec {
|
2020-05-05 04:06:36 +00:00
|
|
|
/// The argument refers to a player by alias
|
2020-05-09 02:42:51 +00:00
|
|
|
PlayerName(Requirement),
|
2022-05-15 21:57:21 +00:00
|
|
|
// The argument refers to a site, by name.
|
|
|
|
SiteName(Requirement),
|
2020-05-05 04:06:36 +00:00
|
|
|
/// The argument is a float. The associated values are
|
|
|
|
/// * label
|
2020-05-09 02:42:51 +00:00
|
|
|
/// * suggested tab-completion
|
2020-05-05 04:06:36 +00:00
|
|
|
/// * whether it's optional
|
2020-05-09 02:42:51 +00:00
|
|
|
Float(&'static str, f32, Requirement),
|
2021-05-08 15:47:09 +00:00
|
|
|
/// The argument is an integer. The associated values are
|
2020-05-05 04:06:36 +00:00
|
|
|
/// * label
|
2020-05-09 02:42:51 +00:00
|
|
|
/// * suggested tab-completion
|
2020-05-05 04:06:36 +00:00
|
|
|
/// * whether it's optional
|
2020-05-09 02:42:51 +00:00
|
|
|
Integer(&'static str, i32, Requirement),
|
2020-05-05 22:33:16 +00:00
|
|
|
/// The argument is any string that doesn't contain spaces
|
2020-05-09 02:42:51 +00:00
|
|
|
Any(&'static str, Requirement),
|
|
|
|
/// The argument is a command name (such as in /help)
|
|
|
|
Command(Requirement),
|
2020-05-05 22:33:16 +00:00
|
|
|
/// This is the final argument, consuming all characters until the end of
|
|
|
|
/// input.
|
2020-06-01 04:33:39 +00:00
|
|
|
Message(Requirement),
|
2020-05-08 05:35:07 +00:00
|
|
|
/// This command is followed by another command (such as in /sudo)
|
|
|
|
SubCommand,
|
2020-05-05 04:06:36 +00:00
|
|
|
/// The argument is likely an enum. The associated values are
|
|
|
|
/// * label
|
|
|
|
/// * Predefined string completions
|
|
|
|
/// * whether it's optional
|
2020-05-09 02:42:51 +00:00
|
|
|
Enum(&'static str, Vec<String>, Requirement),
|
2020-07-02 21:53:01 +00:00
|
|
|
/// The argument is likely a boolean. The associated values are
|
|
|
|
/// * label
|
|
|
|
/// * suggested tab-completion
|
|
|
|
/// * whether it's optional
|
|
|
|
Boolean(&'static str, String, Requirement),
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
|
2020-05-05 22:33:16 +00:00
|
|
|
impl ArgumentSpec {
|
|
|
|
pub fn usage_string(&self) -> String {
|
|
|
|
match self {
|
2020-05-09 02:42:51 +00:00
|
|
|
ArgumentSpec::PlayerName(req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2020-05-05 04:06:36 +00:00
|
|
|
"<player>".to_string()
|
|
|
|
} else {
|
2020-05-09 02:42:51 +00:00
|
|
|
"[player]".to_string()
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
},
|
2022-05-15 21:57:21 +00:00
|
|
|
ArgumentSpec::SiteName(req) => {
|
|
|
|
if &Requirement::Required == req {
|
|
|
|
"<site>".to_string()
|
|
|
|
} else {
|
|
|
|
"[site]".to_string()
|
|
|
|
}
|
|
|
|
},
|
2020-05-09 02:42:51 +00:00
|
|
|
ArgumentSpec::Float(label, _, req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2020-05-05 04:06:36 +00:00
|
|
|
format!("<{}>", label)
|
2020-05-09 02:42:51 +00:00
|
|
|
} else {
|
|
|
|
format!("[{}]", label)
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
},
|
2020-05-09 02:42:51 +00:00
|
|
|
ArgumentSpec::Integer(label, _, req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2020-05-05 04:06:36 +00:00
|
|
|
format!("<{}>", label)
|
2020-05-09 02:42:51 +00:00
|
|
|
} else {
|
|
|
|
format!("[{}]", label)
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
},
|
2020-05-09 02:42:51 +00:00
|
|
|
ArgumentSpec::Any(label, req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2020-05-05 22:33:16 +00:00
|
|
|
format!("<{}>", label)
|
2020-05-09 02:42:51 +00:00
|
|
|
} else {
|
|
|
|
format!("[{}]", label)
|
2020-05-05 22:33:16 +00:00
|
|
|
}
|
|
|
|
},
|
2020-05-09 02:42:51 +00:00
|
|
|
ArgumentSpec::Command(req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2020-05-05 04:06:36 +00:00
|
|
|
"<[/]command>".to_string()
|
2020-05-09 02:42:51 +00:00
|
|
|
} else {
|
|
|
|
"[[/]command]".to_string()
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
},
|
2020-06-01 04:33:39 +00:00
|
|
|
ArgumentSpec::Message(req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2020-06-01 04:33:39 +00:00
|
|
|
"<message>".to_string()
|
|
|
|
} else {
|
2020-06-12 17:44:29 +00:00
|
|
|
"[message]".to_string()
|
2020-06-01 04:33:39 +00:00
|
|
|
}
|
|
|
|
},
|
2020-05-08 05:35:07 +00:00
|
|
|
ArgumentSpec::SubCommand => "<[/]command> [args...]".to_string(),
|
2020-05-09 02:42:51 +00:00
|
|
|
ArgumentSpec::Enum(label, _, req) => {
|
2020-06-12 17:44:29 +00:00
|
|
|
if &Requirement::Required == req {
|
2021-08-15 11:45:50 +00:00
|
|
|
format!("<{}>", label)
|
2020-05-09 02:42:51 +00:00
|
|
|
} else {
|
2021-08-15 11:45:50 +00:00
|
|
|
format!("[{}]", label)
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
},
|
2020-07-02 21:53:01 +00:00
|
|
|
ArgumentSpec::Boolean(label, _, req) => {
|
|
|
|
if &Requirement::Required == req {
|
|
|
|
format!("<{}>", label)
|
|
|
|
} else {
|
|
|
|
format!("[{}]", label)
|
|
|
|
}
|
|
|
|
},
|
2020-05-05 04:06:36 +00:00
|
|
|
}
|
|
|
|
}
|
2020-05-08 05:35:07 +00:00
|
|
|
}
|
2021-05-22 12:47:56 +00:00
|
|
|
|
2022-06-14 20:35:01 +00:00
|
|
|
/// Parse a series of command arguments into values, including collecting all
|
|
|
|
/// trailing arguments.
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! parse_cmd_args {
|
|
|
|
($args:expr, $($t:ty),* $(, ..$tail:ty)? $(,)?) => {
|
|
|
|
{
|
|
|
|
let mut args = $args.into_iter().peekable();
|
|
|
|
(
|
|
|
|
// We only consume the input argument when parsing is successful. If this fails, we
|
|
|
|
// will then attempt to parse it as the next argument type. This is done regardless
|
|
|
|
// of whether the argument is optional because that information is not available
|
|
|
|
// here. Nevertheless, if the caller only precedes to use the parsed arguments when
|
|
|
|
// all required arguments parse successfully to `Some(val)` this should not create
|
|
|
|
// any unexpected behavior.
|
|
|
|
//
|
|
|
|
// This does mean that optional arguments will be included in the trailing args or
|
|
|
|
// that one optional arg could be interpreted as another, if the user makes a
|
|
|
|
// mistake that causes an optional arg to fail to parse. But there is no way to
|
|
|
|
// discern this in the current model with the optional args and trailing arg being
|
|
|
|
// solely position based.
|
|
|
|
$({
|
|
|
|
let parsed = args.peek().and_then(|s| s.parse::<$t>().ok());
|
|
|
|
// Consume successfully parsed arg.
|
|
|
|
if parsed.is_some() { args.next(); }
|
|
|
|
parsed
|
|
|
|
}),*
|
|
|
|
$(, args.map(|s| s.to_string()).collect::<$tail>())?
|
|
|
|
)
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-05-22 12:47:56 +00:00
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
2021-08-09 17:18:33 +00:00
|
|
|
use crate::comp::Item;
|
|
|
|
|
2023-01-20 01:28:28 +00:00
|
|
|
#[test]
|
|
|
|
fn verify_cmd_list_sorted() {
|
|
|
|
let mut list = ServerChatCommand::iter()
|
|
|
|
.map(|c| c.keyword())
|
|
|
|
.collect::<Vec<_>>();
|
|
|
|
|
|
|
|
// Vec::is_sorted is unstable, so we do it the hard way
|
|
|
|
let list2 = list.clone();
|
|
|
|
list.sort_unstable();
|
|
|
|
assert_eq!(list, list2);
|
|
|
|
}
|
|
|
|
|
2021-08-09 17:18:33 +00:00
|
|
|
#[test]
|
|
|
|
fn test_loading_skill_presets() { SkillPresetManifest::load_expect(PRESET_MANIFEST_PATH); }
|
2021-05-22 12:47:56 +00:00
|
|
|
|
|
|
|
#[test]
|
2021-08-09 17:18:33 +00:00
|
|
|
fn test_load_kits() {
|
|
|
|
let kits = KitManifest::load_expect(KIT_MANIFEST_PATH).read();
|
2022-05-05 02:53:24 +00:00
|
|
|
let mut rng = rand::thread_rng();
|
2021-08-09 17:18:33 +00:00
|
|
|
for kit in kits.0.values() {
|
|
|
|
for (item_id, _) in kit.iter() {
|
2021-09-04 02:06:15 +00:00
|
|
|
match item_id {
|
2022-05-05 02:53:24 +00:00
|
|
|
KitSpec::Item(item_id) => {
|
|
|
|
Item::new_from_asset_expect(item_id);
|
|
|
|
},
|
2021-09-04 02:06:15 +00:00
|
|
|
KitSpec::ModularWeapon { tool, material } => {
|
2022-05-05 02:53:24 +00:00
|
|
|
comp::item::modular::random_weapon(*tool, *material, None, &mut rng)
|
|
|
|
.unwrap_or_else(|_| {
|
|
|
|
panic!(
|
|
|
|
"Failed to synthesize a modular {tool:?} made of {material:?}."
|
|
|
|
)
|
|
|
|
});
|
2021-09-04 02:06:15 +00:00
|
|
|
},
|
|
|
|
}
|
2021-08-09 17:18:33 +00:00
|
|
|
}
|
|
|
|
}
|
2021-05-22 12:47:56 +00:00
|
|
|
}
|
|
|
|
}
|