forked from appenz/minebot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
chat.py
208 lines (175 loc) · 7.2 KB
/
chat.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
#
# Misc chat functions
#
import time
import datetime
import botlib
from javascript import require, On, Once, AsyncTask, once, off
pathfinder = require('mineflayer-pathfinder')
class ChatBot:
stopActivity = True
activity_start = 0
activity_name = "None"
activity_major = False
activity_last_duration = 0
def __init__(self):
print('chat ', end='')
# Command : [function, name, major activity flag, min_arguments]
self.commandList = {
"analyze": [self.analyzeBuild, "Analyze building", False, 0],
"build": [self.doBuild, "Build a blueprint", True, 1],
"chop": [self.chopWood, "Chop wood", True, 0],
"deposit": [self.depositToChest, "Deposit all in chest", False, 0],
"eat": [self.eatFood, "Eat Something", False, 0],
"farm": [self.doFarming, "Farming", True , 0],
"hello": [self.sayHello, "Say Hello", False, 0],
"inventory": [self.printInventory, "List Inventory", False, 0],
"mine": [self.doMining, "Mine for resources", True, 1],
"sleep": [self.sleepInBed, "Sleep in a bed", False, 0],
"stop": [self.stopThis, "Stop all activities", False, 0],
"status": [self.sayStatus, "Report status", False, 0],
"wake": [self.wakeUp, "Stop sleeping", False, 0],
"yeet": [self.exitGame, "Exit the game", False, 0],
}
def chat(self,txt):
self.bot.chat(txt)
self.pdebug(f' chat: {txt}',0)
def sayStatus(self):
self.pdebug(f' level : {self.bot.experience.level}',0)
self.pdebug(f' health: {int(100*self.bot.health/20)}%',0)
self.pdebug(f' food : {int(100*self.bot.food/20)}%',0)
def sayHello(self):
self.chat('hello to you too!')
def startActivity(self, name):
t_str = botlib.myTime()
self.pdebug(60*'-',1)
self.pdebug(f'{name:47} {t_str}',1)
self.pdebug(60*'-',1)
self.activity_start = time.time()
self.activity_name = name
self.stopActivity = False
self.activity_major = True
self.dangerType = None
self.speedMode = False
def endActivity(self):
if self.activity_major:
t_str = botlib.myTime()
d_str = str(datetime.timedelta(seconds=int(time.time()-self.activity_start)))
self.pdebug(f'Activity {self.activity_name} ended at {t_str} (duration: {d_str})',1)
self.bot.clearControlStates('sneak', False)
self.eatFood()
self.activity_last_duration = d_str
self.bot.stopActivity = True
self.activity_major = False
def safeSleep(self,t):
for i in range(0,t):
time.sleep(1)
if self.stopActivity:
return False
return True
def stopThis(self):
self.stopActivity = True
def sleepInBed(self):
bed = self.findClosestBlock("White Bed",xz_radius=3,y_radius=1)
if not bed:
self.chat('cant find a White Bed nearby (I only use those)')
else:
self.bot.sleep(bed)
self.chat('good night!')
def wakeUp(self):
self.bot.wake()
self.chat('i woke up!')
def exitGame(self):
# exit the game
off(self.bot, 'chat', onChat)
def handleChat(self,sender, message, this, *rest):
# check if order is incorrect to fix a bug we are seeing between Guido and Daniel
if type(sender) != type(""):
# reorder
t = sender
sender = message
message = this
this = t
message = message.strip()
# Is this for me, or for someone else?
if message.startswith(self.callsign):
print(f'{sender} messaged me "{message}"')
message = message[len(self.callsign):]
elif sender != self.bossPlayer():
return
self.handleCommand(message,sender)
def handleCommand(self, message, sender):
# Handle standard commands
message = message.lower()
cmd = message.split()[0]
args = message.split()[1:]
if cmd in self.commandList:
c = self.commandList[cmd]
call_function = c[0]
if c[2]:
# Major activity
if self.activity_major:
self.pdebug(f'*** error: major activity in progress, stop it first {self.activity_name}.')
return
self.startActivity(c[1])
@AsyncTask(start=True)
def asyncActivity(task):
if c[3] > 0:
call_function(args)
else:
call_function()
else:
if c[3] > 0:
call_function(args)
else:
call_function()
return
# Legacy commands, need to clean up
# come - try to get to the player
if 'come' in message or 'go' in message:
if message == 'come':
player = self.bot.players[sender]
elif 'go to' in message:
player = self.bot.players[message[6:]]
else:
self.chat("No Clear Target")
target = player.entity
if not target:
self.chat("I don't see you!")
return
pos = target.position
@AsyncTask(start=True)
def doCome(task):
self.walkTo(pos.x, pos.y, pos.z)
if 'follow' in message:
if message == 'follow':
player = self.bot.players[sender]
elif len(message) > 6:
player = self.bot.players[message[7:]]
else:
self.chat("No Clear Target")
target = player.entity
if not target:
self.chat("I don't see you!")
return
@AsyncTask(start=True)
def follow(task):
while self.stopActivity != True:
self.bot.pathfinder.setGoal(pathfinder.goals.GoalFollow(player.entity, 1))
time.sleep(2)
if message.startswith('moveto'):
args = message[6:].split()
if len(args) != 1:
self.chat('Need name of location to move to.')
return
@AsyncTask(start=True)
def doMoveTo(task):
gotoLocation(self.bot,args[0])
if message.startswith('transfer to'):
args = message[11:].split()
if len(args) != 1:
self.chat('Need name of target chest.')
return
@AsyncTask(start=True)
def doTransfer(task):
transferToChest(self.bot,args[0])