-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSimulate.txt
333 lines (290 loc) · 12.6 KB
/
Simulate.txt
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
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
#include "\sim\events.txt"
#include "\sim\flags.txt"
Option Explicit
Script("Name") = "Simulate"
Script("Author") = "Pyro"
Script("Major") = 0
Script("Minor") = 2
Const SIM_COMMAND = "sim" ' The base command for simulating events
Const SIM_EVENT = "event" ' The event to simuate
Const SIM_ARGS = "args" ' Event parameters
Private dicEventIDs
Private dicFlags
Sub Event_Load()
Call InitCommands ' Make sure our commands are registered
Set dicEventIDs = BuildEventDictionary()
Set dicFlags = BuildFlagDictionary()
End Sub
Sub Event_Close()
Set dicEventIDs = Nothing
Set dicFlags = Nothing
End Sub
Sub Event_Command(Command)
Dim s, i, arr
Dim args, msg
Dim oUsr
'We only care about our one command.
If StrComp(Command.Name, SIM_COMMAND, vbTextCompare) <> 0 Then Exit Sub
If Not Command.IsValid Then
Command.Respond StringFormat("Invalid simulation parameters. Syntax: {0} <event> [args]", Command.Name)
Exit Sub
End If
' Add padding so we get back empty indexes when arguments are omitted.
args = Command.Argument(SIM_ARGS) & Space(4)
Select Case LCase(Command.Argument(SIM_EVENT))
Case "leave": ' User leave: args => <username>
For Each oUsr In Channel.Users
If Match(oUsr.DisplayName, Command.Argument(SIM_ARGS), True) Then
SimulateLeave oUsr.Name
End If
Next
Case "load": ' Massload: args => <size> <base_name> [flags] [ping] [stats]
s = Split(args, " ", 5)
count = CLng(s(0))
For i = 1 To count
SimulateJoin IIf(i = 1, s(1), s(1) & "#" & i), s(2), s(4), s(3)
Next
Case "rejoin": ' User rejoin (leave + join): args => <username>
ReDim tUsers(0)
For Each oUsr In Channel.Users
If Match(oUsr.DisplayName, Command.Argument(SIM_ARGS), True) Then
If Not Match(oUsr.Name, Channel.Self.Name, False) Then
Set tUsers(UBound(tUsers)) = oUsr
ReDim Preserve tUsers(UBound(tUsers) + 1)
SimulateLeave oUsr.Name
End If
End If
Next
If UBound(tUsers) > 0 Then
For i = 0 To UBound(tUsers) - 1
SimulateJoin tUsers(i).Name, tUsers(i).Flags And (FLAG_SQUELCH Or FLAG_UDP), tUsers(i).Statstring, tUsers(i).Ping
If (tUsers(i).Flags And (Not FLAG_SQUELCH And Not FLAG_UDP)) <> 0 Then
SimulateFlagUpdate tUsers(i).Name, tUsers(i).Flags, tUsers(i).Statstring, tUsers(i).Ping
End If
Next
End If
Case "ban", "kick": ' Kick/ban: args => <target> <operator> [reason]
s = Split(args, " ", 3)
msg = StringFormat("{0} was {2} by {1}", s(0), s(1), _
IIf(LCase(Command.Argument(SIM_EVENT)) = "ban", "banned", "kicked out of the channel"))
msg = msg & IIf(Len(Trim(s(2))) > 0, " (" & Trim(s(2)) & ").", ".")
ForceBNCSPacketParse CreateChatEvent("info", s(1), 0, msg, 0).Data
Case "info", "error": ' ServerInfo/Error: args => <message>
DoParsePacket CreateChatEvent(LCase(Command.Argument(SIM_EVENT)), Channel.Self.Name, Channel.Self.Flags, Trim(args), Channel.Self.Ping)
Case "icontest" ' Tests icons: args => <icon_type>
Select Case Trim(LCase(args))
Case "flags"
For Each s In dicFlags.Keys()
SimulateJoin s, dicFlags(s), vbNullString, 0
Next
Case "products"
arr = Array("STAR", "SEXP", "SSHR", "JSTR", "DRTL", "DSHR", "W2BN", "D2DV", "D2XP", "WAR3", "W3XP", "CHAT")
For Each s In arr
SimulateJoin s, 0, StrReverse(s), 0
Next
Case "d1", "drtl", "dshr", "diablo", "diablo1"
Dim cc, dots
arr = Array("Warrior", "Rogue", "Sorcerer")
For cc = 0 To 2
For dots = 0 To 3
SimulateJoin arr(cc) & "_" & dots & "d", 0, StringFormat("LTRD 0 {0} {1} 0 0 0 0 0 0", cc, dots), 0
Next
Next
SimulateJoin "D1_Spawn", 0, "LTRD 0 0 0 0 0 0 0 0 1", 0
Case "sc", "star", "sexp", "starcraft"
For i = 0 To 10
SimulateJoin "STAR_" & i, 0, "RATS 0 0 " & i & " 0 0 0 0 0 RATS", 0
Next
SimulateJoin "STAR_Spawn", 0, "RATS 0 0 0 1 0 0 0 0 RATS", 0
SimulateJoin "JSTR_Spawn", 0, "RTSJ 0 0 0 1 0 0 0 0 RTSJ", 0
Case "w2", "war2", "w2bn", "warcraft2"
For i = 0 To 10
SimulateJoin "W2BN_ " & i, 0, "NB2W 0 0 " & i & " 0 0 0 0 0 NB2W", 0
Next
SimulateJoin "W2BN_Spawn", 0, "NB2W 0 0 0 1 0 0 0 0 NB2W", 0
Case "d2", "d2dv", "d2xp", "diablo2"
SimulateJoin "D2_Open", 0, "VD2D", 0 ' open character
arr = Array("Amazon", "Sorceress", "Necromancer", "Paladin", "Barbarian", "Druid", "Assassin")
For i = 1 To 7
s = "VD2DSomeRealm," & arr(i - 1) & "," & Chr(&H84) & Chr(&H80) & String(11, Chr(&HFF)) & Chr(i) & _
String(11, Chr(&HFF)) & Chr(&H1) & Chr(&H4) & Chr(&H80) & String(5, Chr(&HFF))
SimulateJoin arr(i - 1), 0, s, 0
Next
Case "w3", "war3", "w3xp", "warcraft3"
Dim w3cats, wcg, ico, j
w3cats = "HNUORD"
SimulateJoin "Peon", 0, "3RAW 1H3W 0", 0
For i = 1 To Len(w3cats)
If i < Len(w3cats) Then
For j = 2 To 5
ico = "3RAW " & CStr(j) & Mid(w3cats, i, 1) & "3W 0"
SimulateJoin Replace(StrReverse(ico), " ", "_"), 0, ico, 0
Next
End If
For j = 2 To 6
ico = "PX3W " & CStr(j) & Mid(w3cats, i, 1) & "3W 0"
SimulateJoin Replace(StrReverse(ico), " ", "_"), 0, ico, 0
Next
Next
wcg = Array("RF", "PL", "GO", "SI", "BR", "PG")
For Each ico In wcg
SimulateJoin "WC" & ico, 0, "3RAW " & StrReverse(ico) & "CW 0", 0
Next
End Select
Case Else: ' Misc chat events: args => [username] [flags] [ping] [message]
s = Split(args, " ", 4)
DoParsePacket CreateChatEvent(GetEventID(Command.Argument(SIM_EVENT)), s(0), s(1), s(3), s(2))
End Select
End Sub
Sub SimulateJoin(username, flags, message, ping)
DoParsePacket CreateChatEvent(EID_JOIN, username, flags, message, ping)
End Sub
Sub SimulateLeave(username)
DoParsePacket CreateChatEvent(EID_LEAVE, username, 0, vbNullString, 0)
End Sub
Sub SimulateFlagUpdate(username, flags, message, ping)
DoParsePacket CreateChatEvent(EID_USERFLAGS, username, flags, message, ping)
End Sub
' Creates a BNCS packet using the specified data buffer
' returns a data buffer object containing the entire packet including header
Function CreateBNCSPacket(id, buffer)
Dim tBuff
Set tBuff = DataBufferEx
tBuff.InsertByte &HFF ' Protocol header
tBuff.InsertByte id ' Packet ID
' Handle both data buffer objects and strings
If IsObject(buffer) Then
tBuff.InsertWord buffer.length + 4 ' packet length
tBuff.InsertNonNTString buffer.Data ' packet data
Else
tBuff.InsertWord Len(buffer) + 4 ' packet length
tBuff.InsertNonNTString buffer ' packet data
End If
Set CreateBNCSPacket = tBuff
End Function
' Creates a chat event packet using the specified parameters
Function CreateChatEvent(eventId, username, flags, message, ping)
Dim tBuff ' Temporary packet buffer
' Check for string-based event ID
If Not IsNumeric(eventId) Then eventId = GetEventID(eventId)
' If flags are omitted use the default
If Len(flags) = 0 Then
flags = 0
ElseIf Not IsNumeric(flags) Then
' Check for string-based flags (example: op|squelched)
flags = GetFlags(flags)
End If
' If ping is ommitted, use the default
If Len(ping) = 0 Then ping = -1
' Build the packet contents
Set tBuff = DataBufferEx
tBuff.InsertDWord CLng(eventId) ' Event ID
tBuff.InsertDWord CLng(flags) ' Flags
tBuff.InsertDWord CLng(ping) ' Ping
tBuff.InsertDWord 0 ' IP Address (defunct)
tBuff.InsertDWord 0 ' Account number (defunct)
tBuff.InsertDWord 0 ' Registration authority (defunct)
tBuff.InsertNTString CStr(username) ' Username
tBuff.InsertNTString Trim(CStr(message)) ' Text
' Create a full BNCS packet from the data
Set CreateChatEvent = CreateBNCSPacket(&HF, tBuff)
End Function
Function GetEventID(eventArg)
If dicEventIDs.Exists(eventArg) Then
GetEventID = dicEventIDs.Item(eventArg)
Else
GetEventID = 0
End If
End Function
Function GetFlags(flagArg)
Dim s, i, f
' Flags can be combined using pipes (example: op|squelch|udp)
s = Split(flagArg, "|")
If dicFlags.Exists(s(0)) Then
f = dicFlags.Item(s(0))
Else
f = 0
End If
If UBound(s) > 0 Then
For i = 1 To UBound(s)
f = f Or CLng(IIf(dicFlags.Exists(s(i)), dicFlags.Item(s(i)), 0))
Next
End If
GetFlags = f
End Function
Function BuildEventDictionary()
Set BuildEventDictionary = CreateObject("Scripting.Dictionary")
With BuildEventDictionary
.CompareMode = vbTextCompare
.Add "user", EID_SHOWUSER
.Add "join", EID_JOIN
.Add "leave", EID_LEAVE
.Add "whisper", EID_WHISPER
.Add "talk", EID_TALK
.Add "broadcast", EID_BROADCAST
.Add "channel", EID_CHANNEL
.Add "flags", EID_USERFLAGS
.Add "chanfull", EID_CHANNELFULL
.Add "channoexist", EID_CHANNELDOESNOTEXIST
.Add "chanrestrict", EID_CHANNELRESTRICTED
.Add "info", EID_INFO
.Add "error", EID_ERROR
.Add "emote", EID_EMOTE
End With
End Function
Function BuildFlagDictionary()
Set BuildFlagDictionary = CreateObject("Scripting.Dictionary")
With BuildFlagDictionary
.CompareMode = vbTextCompare
.Add "blizzard", FLAG_BLIZZARD
.Add "op", FLAG_OPERATOR
.Add "speaker", FLAG_SPEAKER
.Add "admin", FLAG_ADMIN
.Add "udp", FLAG_UDP
.Add "squelch", FLAG_SQUELCH
.Add "guest", FLAG_GUEST
.Add "reserved", FLAG_RESERVED
.Add "beep", FLAG_BEEP
.Add "pglplay", FLAG_PGLPLAYER
.Add "pgloff", FLAG_PGLOFFICIAL
.Add "kbkplay", FLAG_KBKPLAYER
.Add "wcgoff", FLAG_WCGOFFICIAL
.ADd "kbksingle", FLAG_KBKSINGLE
.Add "kbkbegin", FLAG_KBKBEGIN
.Add "kbkwhite", FLAG_KBKWHITE
.Add "gfoff", FLAG_GFOFFICIAL
.Add "gfplay", FLAG_GFPLAYER
.Add "pglplay2", FLAG_PGLPLAYER2
End With
End Function
' Returns t if exp is True, otherwise returns f
Function IIf(exp, t, f)
If exp Then IIf = t Else IIf = f
End Function
' Forces the parsing of the specified packet data
Sub DoParsePacket(pBuff)
' Handle both data buffer objects and strings
If IsObject(pBuff) Then
ForceBNCSPacketParse pBuff.Data
Else
ForceBNCSPacketParse pBuff
End If
End Sub
' Registers script commands
Sub InitCommands()
Dim objC, objP
If OpenCommand(SIM_COMMAND) Is Nothing Then
Set objC = CreateCommand(SIM_COMMAND)
With objC
Set objP = .NewParameter(SIM_EVENT, False, "word")
objP.Description = "The event to simulate."
.Parameters.Add objP
Set objP = .NewParameter(SIM_ARGS, True, "string")
objP.Description = "Additional event arguments."
.Parameters.Add objP
.Description = "Simulates server events"
.RequiredRank = -1
.Save
End With
End IF
End Sub