summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/emap/init.c1
-rw-r--r--src/emap/script_buildins.c34
-rw-r--r--src/emap/script_buildins.h1
3 files changed, 36 insertions, 0 deletions
diff --git a/src/emap/init.c b/src/emap/init.c
index dc2976c..05ba6fa 100644
--- a/src/emap/init.c
+++ b/src/emap/init.c
@@ -218,6 +218,7 @@ HPExport void plugin_init (void)
addScriptCommand("instanceowner", "i", InstanceOwner);
addScriptCommand("aggravate", "i", aggravate);
addScriptCommand("getnpcsubtype", "?", getNpcSubtype);
+ addScriptCommand("kick", "v?", kick);
do_init_langs();
diff --git a/src/emap/script_buildins.c b/src/emap/script_buildins.c
index 3e1a15a..86cf32f 100644
--- a/src/emap/script_buildins.c
+++ b/src/emap/script_buildins.c
@@ -2537,3 +2537,37 @@ BUILDIN(aggravate)
script_pushint(st, true);
return true;
}
+
+BUILDIN(kick)
+{
+ struct map_session_data *tsd = NULL;
+
+ if (script_isstringtype(st, 2)) {
+ tsd = map->nick2sd(script_getstr(st, 2), false);
+ } else {
+ tsd = map->id2sd(script_getnum(st, 2));
+ }
+
+ if (tsd == NULL) {
+ // silently fail
+ script_pushint(st, 0);
+ return true;
+ }
+
+ // clif_authfail_fd reason
+ // see https://github.com/ManaPlus/ManaPlus/blob/master/src/net/eathena/generalrecv.cpp#L48
+ int reason = 15; // default: 15 - disconnection forced by a GM
+
+ if (script_hasdata(st, 3)) {
+ reason = script_getnum(st, 3);
+ }
+
+ if (tsd->fd > 0) {
+ clif->authfail_fd(tsd->fd, reason);
+ } else {
+ map->quit(tsd);
+ }
+
+ script_pushint(st, 1);
+ return true;
+}
diff --git a/src/emap/script_buildins.h b/src/emap/script_buildins.h
index 7582828..01c6b65 100644
--- a/src/emap/script_buildins.h
+++ b/src/emap/script_buildins.h
@@ -103,5 +103,6 @@ BUILDIN(readBattleParam);
BUILDIN(InstanceOwner);
BUILDIN(aggravate);
BUILDIN(getNpcSubtype);
+BUILDIN(kick);
#endif // EVOL_MAP_SCRIPT_BUILDINS