summaryrefslogtreecommitdiff
path: root/game
diff options
context:
space:
mode:
authorJesusaves <cpntb1@ymail.com>2021-06-06 14:08:52 -0300
committerJesusaves <cpntb1@ymail.com>2021-06-06 14:08:52 -0300
commitf2a1dcee69af446cd34815e80daed06a29c2ee27 (patch)
treec95dce920ddda3119d45eeed54f91ad079998c9d /game
parent1aa85a3c89d3131d3cd28cb4e562af227765c7d9 (diff)
downloadrenpy-f2a1dcee69af446cd34815e80daed06a29c2ee27.tar.gz
renpy-f2a1dcee69af446cd34815e80daed06a29c2ee27.tar.bz2
renpy-f2a1dcee69af446cd34815e80daed06a29c2ee27.tar.xz
renpy-f2a1dcee69af446cd34815e80daed06a29c2ee27.zip
Sanitize input to avoid some (but not every) arbitrary shell code execution
Diffstat (limited to 'game')
-rw-r--r--game/client.rpy17
1 files changed, 15 insertions, 2 deletions
diff --git a/game/client.rpy b/game/client.rpy
index bfc7797..e01d0b3 100644
--- a/game/client.rpy
+++ b/game/client.rpy
@@ -29,7 +29,7 @@ init 2 python:
HOST=persistent.serverlist[idx]["Host"]
PORT=persistent.serverlist[idx]["Port"]
CMD=handle_client(launch=True)
- OPT="-s %s -y evol2 -p %s" % (HOST, PORT)
+ OPT="-s %s -y evol2 -p %s -S" % (HOST, PORT)
stdout("%s %s" % (CMD, OPT))
########################################################################
@@ -83,12 +83,25 @@ init 2 python:
if not renpy.mobile and persistent.iconify:
renpy.iconify()
+ ## Sanitize input to avoid arbitrary code execution
+ CMD=CMD.replace(";", "").replace("&", "").replace(">", "").replace("<", "").replace("|", "")
+ OPT=OPT.replace(";", "").replace("&", "").replace(">", "").replace("<", "").replace("|", "")
+ PWD=PWD.replace(";", "").replace("&", "").replace(">", "").replace("<", "").replace("|", "")
+
## Launch your prefered game client, wait for it to finish
if renpy.windows:
app=execute("\"%s\" %s%s" % (CMD, OPT, PWD), shell=True)
else:
app=execute("%s %s%s" % (CMD, OPT, PWD), shell=True)
- if app:
+
+ ## Determine error messages
+ if app == 7:
+ stdout("[CLIENT] Mirror Lake trigger.")
+ ## Give "plenty" time to ensure data will be available
+ statusmsg=_("Synchronizing data...")
+ time.sleep(0.5)
+
+ elif app:
traceback.print_exc()
stdout("[CLIENT] An error happened: %d" % app)
#responsive = False