Jump to content

Recommended Posts

Posted

Ok guys well L2click is program that automates monsters killing and AutoCP/GHP/QHP in Lineage 2.

It's able to obtain information from Lineage2 game client by reading colors

of specific pixels on the screen and according to this input it is able to

simulate pressing keys F1-F12.

 

L2click is invisible for server because it does not modify packets.

 

   * can read changes on the screen and according to them it presses keys

   * or do any other actions

   * can't be detected by server because L2click does not work with packets

   * can switch between two windows and in each window it is able to press keys

   * works only in window mode

 

9a1ef5d93660.jpg

 

Ok some useful information:

 

Create new action:

 

1. Press button Add  da70bd14bc85.jpg in L2click application.

2. Set the main parameters for the action:

 

Name - name of action.

Interval - the interval for the cyclical performance of action, in seconds

Count - count of actions. If this value equals to 0 then cycle will repeat forever

Event - type of action. You can select from those types:

(F1 - F12) - press button on keyboard

switch (F1 - F6) - switch to another Lineage window and press button F1

play sound

close Lineage client window

 

L2click is able to find out what's going on in Lineage2

game by monitoring colors of specific pixels on the screen.

User has to specify which pixels and colors will trigger actions.

If you wish to add new monitored pixel then click on the button

 

f8e76e7fff0f.jpg in L2click application.

 

- select the pixel which l2click will monitor

 

37bdd67927fd.jpg

 

- you can invert the action with checkbox.

 

9e65fcf8b3f0.jpg

 

toolsq.png

 

Credits by Sudeo

Posted

Why does it keep saying "You must first restart computer." Then L2click.exe has stopped working.

 

I did (don't rly know why, waiting for a wonder..) but it didnt solve the problem.

 

W7 x64 (i tried compatibility mode + admin rights)

Posted

Why does it keep saying "You must first restart computer." Then L2click.exe has stopped working.

 

I did (don't rly know why, waiting for a wonder..) but it didnt solve the problem.

 

W7 x64 (i tried compatibility mode + admin rights)

I have W7 32bits and get this probem too, but you can hide window and continue using program normaly :)
  • 6 months later...
  • 1 month later...

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • I open the l2j server and see 1. XOR->NewCrypt.encXORPass(raw, offset, size, Rnd.nextInt()); ---> xor everything is clear 2. _staticCrypt.crypt(raw, offset, size); -----> private void encryptBlock(byte[] src, int srcIndex, byte[] dst, int dstIndex) { int xl = bytesTo32bits(src, srcIndex); int xr = bytesTo32bits(src, srcIndex + 4); xl ^= P[0]; for (int i = 1; i < ROUNDS; i += 2) { xr ^= func(xl) ^ P[i]; xl ^= func(xr) ^ P[i + 1]; } xr ^= P[ROUNDS + 1]; bits32ToBytes(xr, dst, dstIndex); bits32ToBytes(xl, dst, dstIndex + 4); }   I scroll down the code and see this code   ----->>> /**      * Decrypt the given input starting at the given offset and place the result in the provided buffer starting at the given offset. The input will be an exact multiple of our blocksize.      * @param src      * @param srcIndex      * @param dst      * @param dstIndex      */     private void decryptBlock(byte[] src, int srcIndex, byte[] dst, int dstIndex)     {         int xl = bytesTo32bits(src, srcIndex);         int xr = bytesTo32bits(src, srcIndex + 4);         xl ^= P[ROUNDS + 1];         for (int i = ROUNDS; i > 0; i -= 2)         {             xr ^= func(xl) ^ P[i];             xl ^= func(xr) ^ P[i - 1];         }         xr ^= P[0];         bits32ToBytes(xr, dst, dstIndex);         bits32ToBytes(xl, dst, dstIndex + 4);     }   ===================================================   I'm transferring this code to C# private void decryptBlock(byte[] src, uint srcIndex, byte[] dst, uint dstIndex)    {        uint xl = BytesTo32bits(src, srcIndex);        uint xr = BytesTo32bits(src, srcIndex + 4);        xl ^= P[ROUNDS + 1];        for (int i = ROUNDS; i > 0; i -= 2)        {            xr ^= F(xl) ^ P[i];            xl ^= F(xr) ^ P[i - 1];        }        xr ^= P[0];        Bits32ToBytes(xr, dst, dstIndex);        Bits32ToBytes(xl, dst, dstIndex + 4);    }   And in c# I first do decryptBlock and then XOR and everything works, I get the package and the first 2 bytes have already been removed as far as I remember   This only works for the login server for the game server, I think it’s not much different  
    • Ask him what you know, and what I know hahaha.
    • https://prnt.sc/2G_hOHfUIGLM   not sure what you mean Teddy boi  
    • Hello first of all thank you for your prompt response and the time you are taking to read this and answer, I am aware that not everyone takes the time and for that I thank you. On the other hand the specific problem is when decrypting this package and being able to parse it,  In some places it says that it is only encrypted with xor, in others that only a static blowfish is used and in others that both are used in the order of xor and then blowfish, this is the problem in spite of being able to see the encryption mechanisms of the servers, I can not put together the function that reverses this encryption to obtain the keys sent by the init packet.   Thanks for your time, hopefully the rest can contribute something because it is a super useful module to extend any functionality to the client and I will publish it in an opensource way when it is finished.
  • Topics

×
×
  • Create New...