2020-01-23 23:15:26 +01:00
|
|
|
import os
|
2020-04-22 00:17:28 +02:00
|
|
|
import sys
|
2020-01-23 23:15:26 +01:00
|
|
|
import subprocess
|
|
|
|
import atexit
|
2020-01-26 02:29:34 +01:00
|
|
|
from threading import Timer
|
2020-01-23 23:15:26 +01:00
|
|
|
import string
|
|
|
|
import random
|
2020-02-14 23:27:57 +01:00
|
|
|
import time
|
2020-07-03 22:50:21 +02:00
|
|
|
import socket
|
|
|
|
import codecs
|
2020-01-23 23:15:26 +01:00
|
|
|
|
2020-06-12 02:01:39 +02:00
|
|
|
looptestPath = '/home/gameservers/.steam/steam/steamapps/common/Counter-Strike Source/cstrike/cfg/looptest.cfg'
|
2020-05-21 00:19:49 +02:00
|
|
|
chatmsg = ""
|
2020-02-14 23:27:57 +01:00
|
|
|
|
2020-01-23 23:15:26 +01:00
|
|
|
def writeCfgInput(Input):
|
|
|
|
with open(looptestPath, 'w') as f:
|
|
|
|
f.write(Input)
|
2020-06-12 02:01:39 +02:00
|
|
|
|
2020-01-23 23:15:26 +01:00
|
|
|
def resetCfgInputShortWait():
|
2020-06-12 02:01:39 +02:00
|
|
|
str = "wait 5; "
|
2020-01-23 23:15:26 +01:00
|
|
|
with open(looptestPath, 'w') as f:
|
|
|
|
f.write(str)
|
2020-04-22 00:17:28 +02:00
|
|
|
time.sleep(0.5)
|
2020-01-23 23:15:26 +01:00
|
|
|
|
|
|
|
def exit_handler():
|
2020-06-12 02:01:39 +02:00
|
|
|
print('reached exithandler')
|
|
|
|
resetCfgInputShortWait()
|
2020-01-26 02:29:34 +01:00
|
|
|
|
2020-01-23 23:15:26 +01:00
|
|
|
def joinTeam():
|
2020-04-22 00:17:28 +02:00
|
|
|
str = "jointeam 2; wait 2; zspawn; wait 1; {0}; wait 5;"
|
2020-01-23 23:15:26 +01:00
|
|
|
writeCfgInput(str)
|
2020-04-22 00:17:28 +02:00
|
|
|
time.sleep(4.5)
|
|
|
|
print('jointeam func: ')
|
2020-07-21 01:03:06 +02:00
|
|
|
|
|
|
|
def bot_process_keyinput(input_line):
|
|
|
|
movement_input = input_line[input_line.index("keyinput:") + len("keyinput:"):input_line.index("dist_target:")]
|
|
|
|
dist_target = input_line[input_line.index("dist_target:") + len("dist_target:"):]
|
|
|
|
dist_target = float(dist_target)
|
|
|
|
strInput = f"""{movement_input}; wait 5; """
|
|
|
|
writeCfgInput(strInput)
|
|
|
|
print('dist_target: ', dist_target, ' movement strinput: ', strInput)
|
|
|
|
time.sleep(0.1)
|
|
|
|
writeCfgInput("wait 5;")
|
|
|
|
|
2020-07-15 02:14:00 +02:00
|
|
|
def bot_process_movement(input_line):
|
|
|
|
dist_target = input_line[input_line.index("dist_target:") + len("dist_target:"):input_line.index("targethuman:")]
|
|
|
|
targethuman = input_line[input_line.index("targethuman:") + len("targethuman:"):input_line.index("bot_on_type:")]
|
2020-07-21 01:03:06 +02:00
|
|
|
bot_on_type = input_line[input_line.index("bot_on_type:") + len("bot_on_type:"):input_line.index("enemy_distance:")]
|
|
|
|
enemy_distance = input_line[input_line.index("enemy_distance:") + len("enemy_distance:"):input_line.index("bot_stuck:")]
|
|
|
|
bot_stuck = input_line[input_line.index("bot_stuck:") + len("bot_stuck:"):]
|
2020-07-15 02:14:00 +02:00
|
|
|
dist_target = float(dist_target)
|
2020-07-21 01:03:06 +02:00
|
|
|
enemy_distance = float(enemy_distance)
|
2020-07-15 02:14:00 +02:00
|
|
|
bot_on_type = int(bot_on_type)
|
2020-07-21 01:03:06 +02:00
|
|
|
bot_stuck = int(bot_stuck)
|
2020-07-17 01:44:18 +02:00
|
|
|
strInput = ""
|
2020-07-21 01:03:06 +02:00
|
|
|
distance_cap = 2.5
|
|
|
|
if dist_target < distance_cap and bot_on_type not in [0, 2]:
|
2020-07-19 00:05:07 +02:00
|
|
|
strInput += "-forward; wait 3; -back; wait 3; -moveleft; waii 3; -moveright; wait 3; "
|
2020-07-21 01:03:06 +02:00
|
|
|
print('reduced movement, too close')
|
2020-07-17 01:44:18 +02:00
|
|
|
strInput += "-attack; wait 2; -use; wait 5; -jump; wait 5; -duck; wait 5; +attack; wait 5; cl_minmodels 1; wait 2; +use; "
|
|
|
|
|
2020-07-21 01:03:06 +02:00
|
|
|
if bot_stuck:
|
2020-07-17 01:44:18 +02:00
|
|
|
strInput += "wait 5; +jump; wait 5; +duck; "
|
|
|
|
|
2020-07-15 02:14:00 +02:00
|
|
|
if bot_on_type == 0:
|
|
|
|
print('bot_on_type ladder ')
|
2020-07-21 01:03:06 +02:00
|
|
|
strInput += "setang -90 90 0; wait 5; -back; wait 3; -moveleft; wait 3; -moveright; wait 5; -jump; wait 3; -duck; wait 3; +forward; wait 5;"
|
2020-07-17 01:44:18 +02:00
|
|
|
elif bot_on_type == 2:
|
|
|
|
print('bot surfing')
|
|
|
|
#make some setup to allow surfing/mimic
|
2020-07-15 02:14:00 +02:00
|
|
|
else:
|
|
|
|
if bot_on_type == 1:
|
|
|
|
print('bot_on_type water')
|
|
|
|
strInput += "+jump; wait 5;"
|
2020-07-21 01:03:06 +02:00
|
|
|
print('target human: ', targethuman, ' dist_target: ', dist_target, ' enemy distance: ', enemy_distance)
|
|
|
|
strInput += "+forward; wait 5; "
|
2020-07-17 01:44:18 +02:00
|
|
|
|
|
|
|
#print('strInput final:', strInput)
|
2020-07-03 22:50:21 +02:00
|
|
|
writeCfgInput(strInput)
|
2020-07-19 00:05:07 +02:00
|
|
|
time.sleep(0.2)
|
2020-07-03 22:50:21 +02:00
|
|
|
writeCfgInput("wait 5;")
|
2020-01-23 23:15:26 +01:00
|
|
|
|
2020-07-03 22:50:21 +02:00
|
|
|
def bot_connect_ze():
|
|
|
|
#use whatever ip you want here to connect with
|
|
|
|
strdev = "connect 151.80.230.149:27019/test132;"
|
|
|
|
str1 = "connect 151.80.230.149:27015;"
|
2020-07-15 02:14:00 +02:00
|
|
|
writeCfgInput(str1)
|
2020-07-03 22:50:21 +02:00
|
|
|
time.sleep(0.2)
|
|
|
|
writeCfgInput("wait 5;")
|
|
|
|
time.sleep(15.50)
|
|
|
|
print('not yet connected')
|
2020-06-12 02:01:39 +02:00
|
|
|
|
2020-01-23 23:15:26 +01:00
|
|
|
if __name__ == '__main__':
|
2020-06-12 02:01:39 +02:00
|
|
|
atexit.register(exit_handler)
|
|
|
|
resetCfgInputShortWait()
|
2020-07-03 22:50:21 +02:00
|
|
|
local_ip = "127.0.0.1"
|
|
|
|
local_port = 48477
|
|
|
|
udp_external_ip = "62.210.110.245"
|
|
|
|
buffer_size = 4096 #potentially not large enough?
|
|
|
|
with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as sock:
|
|
|
|
with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as sock_external:
|
|
|
|
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
|
|
|
sock.bind(("", local_port))
|
|
|
|
print('reached deadlock')
|
|
|
|
try:
|
|
|
|
while True:
|
|
|
|
data, addr = sock.recvfrom(buffer_size)
|
|
|
|
databyte = data
|
|
|
|
data = codecs.decode(data, "utf-8", "ignore")
|
|
|
|
ip = addr[0]
|
|
|
|
port = addr[1]
|
2020-07-15 02:14:00 +02:00
|
|
|
#print('port: ', port, " ip: ", ip)
|
2020-07-03 22:50:21 +02:00
|
|
|
if not data:
|
|
|
|
continue
|
|
|
|
if ip not in [local_ip, udp_external_ip]:
|
|
|
|
continue
|
|
|
|
if ip == udp_external_ip:
|
|
|
|
print("enabled remote UDP packet")
|
|
|
|
response_msg = f"""say {data}"""
|
|
|
|
writeCfgInput(response_msg)
|
|
|
|
time.sleep(0.5)
|
|
|
|
resetCfgInputShortWait()
|
|
|
|
time.sleep(0.2)
|
2020-07-15 02:14:00 +02:00
|
|
|
#print('data: ', data)
|
2020-07-03 22:50:21 +02:00
|
|
|
if data == "autismo connected":
|
|
|
|
print('Bot connected!')
|
|
|
|
time.sleep(2)
|
|
|
|
joinTeam()
|
|
|
|
elif data == "connect to ze":
|
|
|
|
bot_connect_ze()
|
|
|
|
elif "clientmessage:" in data:
|
|
|
|
sock_external.sendto(databyte, (udp_external_ip, local_port))
|
|
|
|
print('sent databyte: ', databyte)
|
2020-07-21 01:03:06 +02:00
|
|
|
elif data.startswith("dist_target:"):
|
|
|
|
bot_process_movement(data)
|
2020-07-03 22:50:21 +02:00
|
|
|
elif data.startswith("keyinput:"):
|
2020-07-21 01:03:06 +02:00
|
|
|
bot_process_keyinput(data)
|
2020-07-03 22:50:21 +02:00
|
|
|
except KeyboardInterrupt:
|
|
|
|
pass
|
2020-02-09 00:26:05 +01:00
|
|
|
|
2020-06-12 02:01:39 +02:00
|
|
|
#/home/gameservers/.steam/debian-installation/steamapps/common/Counter-Strike Source/cstrike/cfg/autoexec.cfg:
|
2020-04-22 00:17:28 +02:00
|
|
|
#/home/nonroot/.steam/steam/steamapps/common/Counter-Strike Source/cstrike/cfg/autoexec.cfg:
|
2020-05-05 23:52:01 +02:00
|
|
|
#alias loop "exec looptest.cfg; wait 5; loop;"; wait 5; loop;
|
2020-04-22 00:17:28 +02:00
|
|
|
|
|
|
|
#-condebug
|
|
|
|
#cd /home/nonroot/.steam/
|
2020-06-12 02:01:39 +02:00
|
|
|
#cd /home/gameservers/.steam/debian-installation/
|
2020-05-21 00:19:49 +02:00
|
|
|
#./steam.sh -applaunch 240 -textmode -textmessagedebug -novid -nosound -noipx -nojoy -noshaderapi +exec looptest.cfg
|
2020-06-12 02:01:39 +02:00
|
|
|
|
|
|
|
#cd /home/gameservers/ze_runner_files
|
|
|
|
#./play.sh
|
|
|
|
#screen -A -d -m -S ze_runner ./play.sh
|