Adds some functions to the python API, and try to inject a script.py from the current directory.
- Packet Headers and structures
- Patterns of send, recv, GetEther, SendAttackPacket, SendStatePacket and network class pointer
- Structure of CMappedFile
- The executed script is resposible for making sure the following functions work properly:
- Module app
- Function OpenTextFile
- Function IsExistFile
- Module app
- Module net_packet
-
Get(<string> filePath) returns <bytearray>
Similar to old app.Get, allows to extract any file encrypted. -
IsPositionBlocked(<int>x,<int>y) returns <boolean>
Allows to check if a map position is walkable(mobs don't count), true if is walkable or false if is not walkable.
Note: For better pathfinding, unblocked points that are close(1 unit) to a blocked point, are considered blocked too.
There is a bug with objects, since i can't figure out how to load the objects. -
FindPath(<int>x_start,<int>y_start,<int>x_end,<int>y_end) returns <tuple>(x,y)
Finds a path between 2 points.
The path will not contain the current point.
It's possible to edit the maps, by changing the files in Resources/Maps, 0 represents a blocked location and the 1 represents a walkable position. The module will generate a new map if the same does not exist. -
SendPacket(<int>size,<bytearray>buffer) return None
Sends a packet to the server bypassing any encryption set. -
SendAttackPacket(<int>vid,<byte>type)
Sends an attack packet to the server, the type is usually 0. -
SendStatePacket(<float>x,<float>y,<float>rotation_angle,<byte>eFunc, <byte>uArgs)
Sends a packet containing the current state of the main player, can be used to change position,rotation and attack state on server side only. The value eFunc can take the fallowing values: CHAR_STATE_ATTACK,CHAR_STATE_STOP,CHAR_STATE_WALK
If eFunc == CHAR_STATE_ATTACK then the uArgs value can take one of the following values: -
CHAR_STATE_ARG_HORSE_ATTACK1
- CHAR_STATE_ARG_HORSE_ATTACK2
- CHAR_STATE_ARG_HORSE_ATTACK3
- CHAR_STATE_ARG_COMBO_ATTACK1
- CHAR_STATE_ARG_COMBO_ATTACK2
- CHAR_STATE_ARG_COMBO_ATTACK3
- CHAR_STATE_ARG_COMBO_ATTACK4
otherwise the value can be NULL or CHAR_STATE_ARG_NONE
All this constants are defined in the module.
-
<dict>InstancesList
-> Is a dictionary containing all vids currently in sight as keys and values
Note: Use the keys as vids, the values may be changed on a new version -
IsDead(<int>vid) returns 1 or 0
Returns 1 if the instance with the vid provided is dead or doesn't exist and returns 0 otherwise -
SendStartFishing(<word>direction)
Sends a packet to the server to start fishing, the direction parameter is a word only understandable by the server(will be converted in the future). -
SendStopFishing(<byte>type,<float>timeLeft)
Sends a packet to the server to stop fishing, the type can be any of the following parameters:- SUCCESS_FISHING -> The mini game was solve successfully.
- UNSUCCESS_FISHING -> The mini game was not solve.
The timeLeft represents the time left to fish.
-
SendAddFlyTarget(<int>vid,<float>x,<float>y)
Sends a packet to send an arrow at an enemy. -
SendShoot(<byte>uSkill)
Sends an attack packet to the current selected enemy (should be used after SendAddFlyTarget).
uSkill can be:- COMBO_SKILL_ARCH -> Normal attack.
-
BlockFishingPackets()
Blocks client from sending fishing packets (this module will still be able to send) -
UnblockFishingPackets()
Unblocks client from sending fishing packets. -
DisableCollisions()
Disable client colisions with objects and the terrain (Wallhack). -
EnableCollisions()
Enable client colisions. -
RegisterNewShopCallback(<callable_function>callback)
Sets a callback function, that will be called whenever a new private shop is created arround.
That callback will be called with the shop vid as the first argument. -
RegisterDigMotionCallback(<callable_function>callback)
Sets a callback function, that will be called whenever a dig motion(mining packet) is called.
The callback function will be called with the following arguments (player_vid,ore_vid,count) -
<string>PATH
Path of the location where the library was injected -
GetCloseItemGround(<int>x,<int>y) returns a tupple (<int>vid,<int>x,<int>y)
Returns the closest pickable item in the ground relative to the position given.
The items will be fitler acording to the pickup filter (see below).
Also, it will ignore items owned by other player. -
SendPickupItem(<int>itemVID)
Sends a packet to pickup an item from the ground -
SetMoveSpeedMultiplier(<float> speed)
Set the character movement boosting movement speed. -
SendUseSkillPacket(<int> skillIndex, <int> vid)
Uses a skill by providing a skillIndex and a target vid without doing the animation. -
SendUseSkillPacketBySlot(<int> skillSlotIndex, <int> vid)
The same as SendUseSkillPacket but the first argument is a slot index instead of the skill index
And also sets the cooldown of the skill on the client. -
IsPathBlocked(<int>x_start,<int>y_start,<int>x_end,<int>y_end)
Returns false if none of the points is blocked in a straight line other, if any of the points is blocked returns true. -
BlockAttackPackets()
Blocks all attack packets sent from the client, the only attack packets allowed are the ones sent by this module. -
UnblockAttackPackets()
Unblocks all attack packets. -
SkipRenderer()
Instruct the client to skip the drawing process, this can save CPU. -
UnskipRenderer()
Instruct the client to start drawing again. -
SyncPlayerPosition(<list>victims)
This is part of an exploit that allows to teleport other players.
The argument victims is a list of lists, each row containing vid victim, x coordinates and y coordinates.
As far as analyzed, for this to work, a special state packet need to be sent with the following argumentseXLib.SendStatePacket(mx,my,0,3,17)
where mx and my are the mob coordinates. -
SetRecvChatCallback(<function>callbackFunction)
Sets a callback function that will be called with the following arguments:int vid,int type,int empire,string msg,string locale
.
This function will be called whenever the client recives a chat message or command from the server. vid is the vid that send the message or 0 if is a command message. type is the type of message and can take the following valuesCHAT_TYPE_TALKING,CHAT_TYPE_INFO,CHAT_TYPE_NOTICE,CHAT_TYPE_PARTY,CHAT_TYPE_GUILD,CHAT_TYPE_COMMAND,CHAT_TYPE_SHOUT,CHAT_TYPE_WHISPER
that can be found on the chat module. msg is the message content. empire is the empire of the player. locale is the region from the player that send the message or empty if was not a player.
-
Communication with the outside world. All functions are asynchronous.
-
GetRequest(<string> url,<callable_function>callback) returns <int>
Sends a async GET request to the specified url. The callback is called when the response arrives from the server, it will be called with 2 arguments, the ID of the request and a string message respectively. If the request is successful it returns an ID of the request otherwise returns -1. -
OpenWebsocket(<string> url,<callable_function>callback) returns <int>
Opens a websocket to the specified url. The callback is responsible for handling the receive messages. It will be called every time a message is received, with 2 arguments, the ID of the socket and a string containing the message respectively . If the request is schedule successfully it returns an ID of the socket otherwise returns -1. -
SendWebsocket(<int> id,<string>message) returns <int>
Sends a message to the socket with the specified id. If the message is schedule successfully it returns 1 otherwise returns 0. -
CloseWebsocket(<int> id) returns <int>
Closes a socket with the specified id. If the message is schedule successfully it returns 1 otherwise returns 0.
A filter o be applied when calling GetCloseItemGround, by default the filter is set to pick items not present in filter.
-
ItemGrndDelFilter(<int> index)
Deletes an item id from the filter. -
ItemGrndAddFilter(<int> index)
Adds an item id to the filter. -
ItemGrndOnFilter()
Changes the filter mode, to only return items in the filter. -
ItemGrndNotOnFilter()
Changes the filter mode, to ignore all items present in the filter. -
ItemGrndFilterClear()
Deletes every item in the filter. -
GetItemGrndID(<int> VID)
Return the ID of an item in the ground with the specified VID -
ItemGrndSelectRange(<float> range)
Set's the maximum range to pick items -
ItemGrndItemFirst()
Makes the function GetCloseItemGround return the closest item if there is no item returns the closest yang -
ItemGrndNoItemFirst()
Makes the function GetCloseItemGround return the closest item or yang closest -
ItemGrndInBlockedPath()
Ignore items items that are in a blocked path -
ItemGrndNotInBlockedPath()
Allow to return items that are in a blocked path -
SetRecvAddGrndItemCallback(<function>callbackFunction)
Sets a callback function that will be called with the following arguments:int vid, int itemIndex, long x, long y, string owner
.
This function will be called whenever the server sends a new ground item. -
SetRecvChangeOwnershipGrndItemCallback(<function>callbackFunction)
Sets a callback function that will be called with the following arguments:int vid, string owner
.
This function will be called whenever the server sends a change in a ground item ownership (every item that is dropped with an owner will also recive this packet after the append) If the owner argument is an empty string then the item doesn't have an owner. -
SetRecvDelGrndItemCallback(<function>callbackFunction)
Sets a callback function that will be called with the following arguments:int vid
.
This function will be called whenever the server sends the command to delete a current item on the ground (this includes, the items being out of range and the item disappearement) WARNING: If you are trying are creating a list with items on the ground it might be needed to manually clear all items on phase change (Not tested)
These simulates the functions that were removed from the modules by Gameforge.
-
GetPixelPosition(<int>vid) returns a tupple (x,y,z)
Returns the position of the player by vid -
MoveToDestPosition(<float> x,<float> y)
Moves to a destination. -
SetMoveSpeed(<float> speed)
Set the character movement speed. The client might change the speed again need to be called constantly for now. If speed bigger then 2.0, the client will disconnect.
By default every packet will be shown.
-
LaunchPacketFilter()
Launches a console to print the packets. -
ClosePacketFilter()
Closes the console from packet filter. -
StartPacketFilter()
Start filtering packets. -
StopPacketFilter()
Stop filtering packets. -
SkipInHeader(<int>packet header)
Skips a packet coming from the server. -
SkipOutHeader(<int>packet header)
Skips a packet going to the server. -
DoNotSkipInHeader(<int>packet header)
Removes a packet coming from the server from the skipped packets. -
DoNotSkipInHeader(<int>packet header)
Removes a packet going to the server from the skipped packets. -
ClearOutput()
Clear what's in the console. -
ClearInFilter()
Clear all headers from the filter coming from the server. -
ClearOutFilter()
Clear all headers from the filter going to the server. -
SetOutFilterMode(<int>mode)
Changes filter mode for outgoing packets, if set to 1, it will shows all packets that correspond to the filter, if set to 0 it will show all packets that are not within the filter. -
SetInFilterMode(<int>mode)
Changes filter mode for incoming packets, if set to 1, it will shows all packets that correspond to the filter, if set to 0 it will show all packets that are not within the filter
Python 2.7 (32 bits) needs to be installed in the system (C:/Python27) by default.
- Dependencies using vcpkg:
cpprestsdk ->
vcpkg install --recurse cpprestsdk[default-features,websockets]:x86-windows-static
curl ->vcpkg install curl[core,openssl]:x86-windows-static
jsoncpp ->vcpkg install jsoncpp:x86-windows-static
websocketpp ->vcpkg install websocketpp:x86-windows-static
boost ->vcpkg install boost:x86-windows-static
Also the project is using SimpleIni to parse the .ini configuration file and Date to format date.
v1.1:
- Added SetMoveSpeedMultiplier
- Added SendUseSkillPacket
- Fixed some memory leaks
- Fixed a bug where the pickup was picking wrong items