-
Notifications
You must be signed in to change notification settings - Fork 54
v83‐Client‐Setup‐and‐Development‐Guide
Table of Contents
- Core setup
- End user safety
- Troubleshooting
- Server related things that might help you
- Disclosure before reading about the development process
- What you need to further develop the DLL client
- How to further develop the DLL client
- Tutorials for developing the DLL client
- Useful Resources
This setup guide is for an open source v83 DLL client designed to work with the most developed open source v83 server (currently cosmic)
This guide assumes you followed the server setup guide for your respective v83 server source up until the point you install the game. Instead of using the provided localhost nor deleting anything from the default installation, download the following:
- compiled ezorsia v2 DLL and
config.ini
from releases; follow the instructions in the readme to install it (source is also released for transparency and development) -
default v83 client with admin elevation request removed, and 4G flag enabled this is the only 2 edits that was made to the binary directly because i could not get it to work from the dll
- The 4g flag activates the "large address space aware" (LAA) flag in the PE header. This will allow the client to use up to 4 GB of memory instead of only 2.
- if you would rather do the edit yourself for verification purposes will need the client that came with the installation (reinstall if you deleted or just use the provided one here) you will also need the to use the hex editor from cosmic files here and make the following edits:
-
shown here(only do the first "asInvoker" part, my dll will handle the rest because you can't edit those actual offsets in a packed client).
- after you edit the admin part you may have to rename the executable to "MapleStory2" or some other name, i have been getting reports that it won't actually remove elevation if it is named the default name for some reason
- and shown here Note that for the 4g flag in header the default is "0f", you need to change it to "2f". the address is 0000013E if for some reason you cannot load the instructions
-
shown here(only do the first "asInvoker" part, my dll will handle the rest because you can't edit those actual offsets in a packed client).
- if you would rather do the edit yourself for verification purposes will need the client that came with the installation (reinstall if you deleted or just use the provided one here) you will also need the to use the hex editor from cosmic files here and make the following edits:
- The 4g flag activates the "large address space aware" (LAA) flag in the PE header. This will allow the client to use up to 4 GB of memory instead of only 2.
- a modified UI.wz file containing MapleEzorsiaV2 data to replace the existing UI.wz(remember to rename it as ui.wz exactly afterwards)
- Ezorsia V2 will automatically load the appropriate login frame based on your chosen resolution as well as other Ezorsia V2 wz edits to the appropriate location, no need for complicated wz edits!
- for the best experience i recommend 1280x720 along with using the borderless fullscreener provided later. This is the resolution i played and developed it on
- this UI.wz is a modified UI.wz from the cosmic release, and is up to date as of 2023/10/10. in the event that cosmic updates their UI.wz in release or if you are using a custom wz file, you will have to use a wz editor to update the UI.wz following these instructions:
- open both the UI.wz provided here and the UI.wz to be updated in a wz editor, select MapleEzorsiaV2wzfiles.img of UI.wz in the editor, copy and paste it to the UI.wz you are updating
- if you are loading from img files and not wz files. export MapleEzorsiaV2wzfiles.img as IMG file and place it with the other IMG files from UI.wz in the respective folder
- concerned about Ezorsia V2 wz edits conflicting with your own? see Troubleshooting Section for solution
- wz editor can be found in the Useful Resources section
- open both the UI.wz provided here and the UI.wz to be updated in a wz editor, select MapleEzorsiaV2wzfiles.img of UI.wz in the editor, copy and paste it to the UI.wz you are updating
- Note: the game is playable using just the DLL client, but you would have to toggle the setting in config.ini to EzorsiaV2WzIncluded=false
- in this case if the login frame in UI.wz is the original 800x600 login frame, also toggle CustomLoginFrame=false
- it works without Ezorsia V2 wz assets but will just look slightly uglier on the login screen (and medal will clip through the cash shop preview window)
- for compatibility with your own wz edits see the troubleshooting section
- download magpie from https://github.com/Blinue/Magpie open magpie while game is running, click new profile and select your client window, then go to the created profile and toggle on auto scale when in foreground. make sure that window mode is on in the ezorsia config when doing this.
- magpie is a borderless fullscreener that interacts with directx to re-draw pixels into hi-resolution to match your display resolution. this way you can match the aspect ratio of your screen without the normal fullscreen stretching, keep the classic maple look playing in 1280x720, and avoid the scaled down UI elements that occur when a higher resolution is selected in ezorsia config
This guide also aims to provide the safest possible setup for the end user so i think we should talk about this now.
-
use of a older released executable application localhost:
- i recommend just using the client that comes with the default game installation with this dll, but if you really want to use a older released executable application localhost please see the
End User Safety (outdated)
section below- i would not recommend using any other executable application localhost than hendi's if you must use one
- i recommend just using the client that comes with the default game installation with this dll, but if you really want to use a older released executable application localhost please see the
-
very risky use cases: loading themida'd/vmprotected DLLs ripped from other servers:
- Ezorsia v2 has the potential to force other "private" dlls to work for any server or player because my non-Windows API hooks/edits are applied after the additional dlls specified by the end-user are loaded, and my release overwrites a lot(maybe all but idk) of the initialization protections put in by NXXXON, so if the "private" dlls repurposed those same protections then those protections will be overwritten.
- however, other non-protection related useful stuff may also be overwritten so for specific use cases i recommend you adjust the function loading orders yourself to ensure maximum compatibility and recompile from my source
- however, i recommend caution when using my release to load sourceless dlls, it's easy to hide bitcoin miners in themida'd/vmprotected dlls so you could be infecting yourself(or your entire community(and you will be responsible in this case) if running a server) by doing it and re-distributing sourceless, packed, potentially malicious content)
- virtualization solutions may protect your system from permanent damage but it won't stop things like bitcoin miners from still using your CPU to mine coin because unfortunately you have to allow internet access for the program in order for it to work (if you aren't playing singleplayer like me)
- even if you "test" the "sourceless, packed, potentially malicious content" you likely won't be able to ensure it's safe unless you're a real security expert (trust me, i've tried). Miners and other malware can often be designed to detect a debug environment or virtualized setting, which many in the private server community are likely skilled enough to implement because verification and anti-cheat measures also do this kind of thing. Miners and other malware can also just long sleep, sometimes randomly, and don't deliver the payload until after a set amount of time, so a brief debug session or execution in a virtualized environment won't find anything.
- virtualization solutions may protect your system from permanent damage but it won't stop things like bitcoin miners from still using your CPU to mine coin because unfortunately you have to allow internet access for the program in order for it to work (if you aren't playing singleplayer like me)
- all in all, don't take the risk, don't use "sourceless, packed, potentially malicious content", this release is here for you so you don't have to bend over and take that risk
- Ezorsia v2 has the potential to force other "private" dlls to work for any server or player because my non-Windows API hooks/edits are applied after the additional dlls specified by the end-user are loaded, and my release overwrites a lot(maybe all but idk) of the initialization protections put in by NXXXON, so if the "private" dlls repurposed those same protections then those protections will be overwritten.
This guide also aims to provide the safest possible setup for the end user so i think we should talk about this now.
virustotal analysis for hendi's 4g v83 client: scary virustotal score here
- as you can see 25/71 (more than a third) of AVs detect it, but they are mostly generic/trojan detections which can trigger from modification of binaries as well as lack of official signing (this is still less than the detection ratio of commonly distributed v83 localhosts which range around 40-50/71 detection ratio)
- hendi has also been very transparent in their release, including releasing the source of the tool used to remove old school themida as well as instructions and methods on how to do so as seen from the initial ragezone release
- Therefore, i would say it is most likely safe however, i cannot guarantee the safety of cracked software, so it may be smart to consider virtualizating it
- There are various OS-level virtualization solutions (or even system level virtualization solutions) you can employ. one such solution is sandboxie https://sandboxie-plus.com/ (i won't name which one i use for personal security reasons but the client setup works like a charm within virtualization)
- Help! my client won't run. instead i get a blank window like here!
- this is caused by missing dependencies, download and install x86 and x64 versions of the vcredist files here. if it still doesn't work use this DLL dependency debugging tool or this DLL dependency debugging tool that has GUI to find out what else is missing and apply the respective fix
- beware, sometimes just installing vcredist won't actually put the files in the right folders where they should be, in this case you should find where vcredist installed the files to and manually move them to the right place in your systems folder. You could also search the web for the respective dependencies files, but that is not recommended because stray files from the web may contain viruses.
- Help! My client crashes to desktop help!
- this can be caused by having incorrect values in config.ini such as EzorsiaV2WzIncluded=true when your UI.wz doesn't actually contain MapleEzorsiaV2wzfiles.img (the wz modification that came with the DLL client). since i haven't re-written enough checking functions to make a working try-catch block and are relying on human intelligence to put in the right values. other invalid values there can also possibly cause it if the value is too big for the game to take
- Help! my settings in config.ini aren't working! / i get
config.ini
error- this can be caused if you interferre with the comments in the config.ini, like making them too long. at some point the program will automatically read it as a new line with the new line not commented which will cause a parse error and the ini to be unreadable. don't mess with comments there
- Help! the Ezorsia V2 wz edits are conflicting with my own wz edits!
- if you want the rest of the Ezorsia V2 edits but want to use your own login frame do ownLoginFrame=true; for using your own cash shop frames do ownCashShopFrame=true; both in optional section of config.ini
- Help! the Ezorsia V2 dll edits are conflicting with edits from my own dll!
- if you want the rest of the Ezorsia V2 dll edits but want to use your own dll by loading it with Ezorsia v2 you need to check for address and function hook conflicts in the Ezorsia v2 source if you aren't already using it as a base. Please refer to how to do that here(search conflicts).
- Help! i get hackshield error/operation completely successfully/other startup error (when using default installation client with the dll)
- this is because the packed client needs time for themida to unpack itself so the dll edits are applied after a very slight delay. sometimes the timing will be off and the game won't be able to open, if this happens simply try to launch the game again
- if the issue persists or happens often you will need to change sleepTime option # in
config.ini
because loading is time-sensitive and ppl may load the game at different rates. this number determines how long Ezorsia v2 waits before attempting to apply non-Windows API hooks/edits; it is necessary in the default packed client because interferring with the main thread there may result in themida killing the process, this option allows the user to wait until themida fully unpacks, but before the game actually runs, and then patch at the right time
- if the issue persists or happens often you will need to change sleepTime option # in
- this is because the packed client needs time for themida to unpack itself so the dll edits are applied after a very slight delay. sometimes the timing will be off and the game won't be able to open, if this happens simply try to launch the game again
- when trying to set up MySQL Workbench to attach to the database server make sure to enter the parameters like this (assuming you are using cosmic) (i got stuck on this part, so i recorded it and it might help others)
- if you are using docker like i am, this guide might also help you as it helped me (contains commands you need)
The following advice about how to use the tools and edit the client is just from what i've learned over the one month that i have joined the scene and have started working with the client. I have a bit of programming experience but had no experience with C++ prior, nor had any experience with asm or reverse engineering. There may very well be better ways to do things and even my own process is in a constant state of change. This is so far, just what i've managed to scrape together, been taught here and there when folks were feeling generous, and what i've found at the time of writing to have successfully worked. I hope it helps, but always be ready to learn more!
- To compile the dll yourself, you need visual studio 2019
- you need the source code of the ezorsia v2 dll
- you need memory dumps of the client to find addresses in and to inspect the client's mechanisms of operation:
- angel's v83 IDB release
- angel's v95 IDB release
- if it becomes unavailable you'll have to do your own v95 IDB using original v95 leak or original v95 leak
- IDA 7.0 to view the dumped memory: cracked IDA 7.0 (you dont need whole thing, just the version specific to your os. can also get 7.7 in useful links in maple development discord but newer versions of IDA may not be able to read older IDB files)
- note: i cannot guarantee the safety of cracked software, so it may be smart to consider virtualizating it
- There are various OS-level virtualization solutions (or even system level virtualization solutions) you can employ. one such solution is sandboxie https://sandboxie-plus.com/ (i won't name which one i use for personal security reasons but the IDA works like a charm within virtualization)
- note: i cannot guarantee the safety of cracked software, so it may be smart to consider virtualizating it
- A debugger to view the memory of an actively running client during testing, to see for example, if your codecaves are going to the places they should be going: x32dbg (use x32dbg version)
- data conversion tools online you should bookmark:
- dec/hex converter(i use this to verify hex values)
- x86 assembler/disassembler(i use this to convert groups of hexes in memory dump to accurate asm instructions; commented asm instructions from the dump aren't always appropriate to be copied directly to C++ inline)
- IEEE 754 floating point converter(i use this to convert 64 bit values for things like damage cap)
- you may need other tools along the way but this is the basics of what you will need
-
- find a lead to the area of the binary's memory you need to work with to affect the change. To do this you can:
- find relevant functions using functions area in the fully named v95 IDB
- you'll need to look for a area with similar functionality in v83 dump later if taking this approach but it can help verify a lot of things and the pseudocode generated in the leaked IDB is often easier to read
- or use stringpool(enums) to find a related area in memory dump (to find the related string you need to look through wz files)
- or use an existing address that affects what you're trying to change and looking in the same area
-
- look through the asm in the area you identified in step 1 and use F5 to turn it into pseudocode, can right click in IDA view or pseudocode to synchronize and go to the exact spot in the other one, or look at the bottom left bar that shows which address the cursor in pseudocode is at
- try to figure out how it works and what you may need to change
- knowledge and experience of procedural programming is very helpful here because it will determine your efficiency when doing this
- try to keep track of when things are being initialized and cleared, which value(s) are going where, and how the mechanisms are working together
- can also right click the function name of subroutines and click list cross-references to and from to see what other subroutines work with it; this sometimes works to find related areas but not all the time
- can also find more information with xrefs but i don't have much experience doing that
- try to find the constructor of the function (for example CUIScreenMsg::CUIScreenMsg(CUIScreenMsg *this), constructors are the one that call itself), a lot of stuff is initialized there
- most of the time, one specific subroutine won't have everything you need (for example your intial lead may lead you to CUIScreenMsg::CUIScreenMsg but CUIScreenMsg::LayoutScrMsg will be where you need to make your changes since the first one calls the second one)
- flowchart view of the IDA may help with this but i have not use the IDA much in that way
- you should conclude this part with the address of the start of the asm instructions(s) you want to change, and what you want to change it to. If you're changing a whole section of memory using code caving you also need the return address and the amount of bytes in between the initial address and return address for the NOP count (minimum 5)
- make sure the address you found does not already exist amongst the edits. to do this press Ctrl+F in visual studio, set the search scope to "current project" and enter the address you found.
- it would also be a good idea to search for related existing addresses just in case, for example for 00849E39, you would search 00849E3, 00849E, 00849, 0084, and so on. addresses tend to be related to the same areas of functionality when they are close to each other but not always
- try to make sure you aren't making redundant or conflicting edits if something else is already modifying the same thing. this sometimes requires looking at how the existing edits already work and how they would interact with the asm instructions at the address of the new edit if for example when editing closely related addresses
- make sure the order of the edits are right. if one edit depends on another to work, make sure the dependant is executed by the C++ code after the one it depends on
- make sure the address you found does not already exist amongst the edits. to do this press Ctrl+F in visual studio, set the search scope to "current project" and enter the address you found.
-
- test the changes using the appropriate "testing" memory editing functions at the bottom of client.cpp; if doing code caves make sure to fill out the relevant information in the testing code cave in codecaves.h
- when directly editing memory at an address, you need to make sure the value you enter is appropriate for that part of memory or the game will crash on executing it, pay attention to how many bytes of space you have to work with after the initial offset from the beginning of an asm instruction. a single byte can only be 255 max
- when code caving you need try to add or modify instructions without affecting the existing instructions taken from the original location of the code cave, nor interferring with variables on the stack, in such a way that the application deems unacceptable.
- if it is crashing, try to do it gradually, for example, by copying the original instructions in the code cave completely, without any edits, and getting that to work. then making modifications and trying to get those to work
- you could also use function replacement to use the client's own functions in your own way, or to modify how the original function works if you don't need to make edits in the middle of a function; but i don't have much experience making this working in practice (see notes in source)
-
- compile the dll, replace old one, run the game, and test the changes; if the changes are correct, migrate the information from the line(s) used for testing into their own uniquely named lines of codes
- remember to use these build settings for ezorsia v2 when compiling (if DLL from generated doesn't work try this setting)
- compile the dll, replace old one, run the game, and test the changes; if the changes are correct, migrate the information from the line(s) used for testing into their own uniquely named lines of codes
-
note: these instructions may not be easily understood at first, and that's normal. you need a degree of understanding of what is going on before you can do it. so here are some tutorials that helped me along the way:
These are not in any particular order, though i've tried to put the more advanced ones on the bottom. You will likely have to jump back and forth between tutorials and occasionally restudy them to get a handle of what is happening.
- IDA/IDB work and general guides:
- tutorial on how to use the v95 IDB with the v83 IDB to make edits (you can skip the strings part if using IDBs with existing enums ID'd): https://forum.ragezone.com/threads/getting-packet-structures-and-opcodes-with-ida-after-gms-new-update.872876/
- another one about IDA and the IDB: https://forum.ragezone.com/threads/how-to-use-ida-in-v83.1107216/
- another one (with example): https://forum.ragezone.com/threads/removing-a-check-in-the-maplestory-client-v83.1147791/
- C++ tutorial for updating the dll code: https://www.kindsonthegenius.com/cplusplus/c-conditional-statements/
- C++ tutorial on fundamental types (also useful for working with values): https://cplusplus.com/doc/tutorial/variables/
- tutorial for what code caving is: https://www.codeproject.com/Articles/20240/The-Beginners-Guide-to-Codecaves
- asm tutorials:
- teaches basics of how the stack works, the various registers, as well as instructions: https://www.cs.virginia.edu/~evans/cs216/guides/x86.html
- teaches instructions with examples: https://www.tutorialspoint.com/assembly_programming/assembly_logical_instructions.htm
- about movsd instruction: https://www.scs.stanford.edu/05au-cs240c/lab/i386/MOVS.htm
- another asm tutorial (havent enrolled in this one but it's been recommended before): https://p.ost2.fyi/courses/course-v1:OpenSecurityTraining2+Arch1001_x86-64_Asm+2021_v1/course/
- calling conventions for function replacement and asm: https://en.m.wikibooks.org/wiki/X86_Disassembly/Calling_Conventions (i searched this up when learning about call conventions for function replacement but it is also very useful for determining how the subroutine reads values from the stack) (it also explains some things like mangled names and how subroutines return values)
- example code for function replacement: https://forum.ragezone.com/threads/custom-string-pool.1148502/ and https://github.com/pokiuwu/AuthHook-v176-StringPool/blob/master/Client176/MapleHook.cpp
- eric's old tutorial videos that i haven't watched (but they are recommended): https://discord.com/channels/350831332609359875/939516633096015932/939517377136185374 and https://discord.com/channels/350831332609359875/939516633096015932/939525229359816786
- if you have no experience with programming at all and have extreme difficulty interpreting pseudocode and the C++ source to the point where it is unworkable then you should look up additional beginner's tutorials on procedural programming (if you have limited experience you can usually learn along the way like i did)
Below are links to other useful tools, resources, and guides i've collected from since i started improving my singleplayer maplestory experience
-
Frequently updated v83 open source server source(s) (as of 2023/10/10): https://github.com/P0nk/Cosmic
-
original ezorsia: https://github.com/izarooni/MapleEzorsia
-
Wz tools:
- wz diff tool https://github.com/Kagamia/WzComparerR2 (use this to check differences between .wz files and to help verify they are up to date) (have not used nor inspected)
- wz editor that i used: https://github.com/lastbattle/Harepacker-resurrected
- better wz edittor (i have not unzipped and scanned): https://discord.com/channels/350831332609359875/939516633096015932/1158733731411001375
-
map editor: https://www.mediafire.com/file/ez85hdtpvy601ym/MapEditor.rar/file (seems to be old, couldn't find original link so i re-uploaded it; have not used personally)
-
client string extractor (mostly unneeded if IDB already has defined enums): https://github.com/diamondo25/STREDIT
-
hendi's themida unpacker: https://github.com/Hendi48/Magicmida (seems to be okay but i couldnt get it to work fully myself)
-
mirror for clean, unedited hendi 4g client in case it ever becomes unavailable: clean client mirror
-
launcher in C# that would probably hook earlier enough to allow modification of IP address and admin privilege request, but which itself needs admin privileges: https://github.com/MapleStory-Archive/MapleClientEditTemplate#when-does-hooking-and-memory-editing-happen (looked through code but have not used)
-
another launcher in C by shavit: https://github.com/necronomicon/mushroom_redirector (have not used nor inspected)
-
ragezone resolution address release (i already picked through it and commented out problematic edits, and removed redundant ones though): https://forum.ragezone.com/threads/all-addresses-for-v83-resolution-change.1161938/
-
other editting guides(not related to resolution, but good quality): https://forum.ragezone.com/threads/v62-v83-for-wz-edits-hair-item-cap-client-fix.1125064/