Jump to content

Question

Posted
If you buy any item in any multisell shop, and the amount of required adena is higher than the adena limit of interlude, you get the items, and it cost you... not 0 adena, but -1444684684 adena, you get the items, and you gain adena.

 

Example:

 

You sell 1 potion for 500kk adena, and you have 1 adena in your inventory.

Try buy 1 or 2 or 3 or 4 potions, and you get the message "you don't have enough adena".

Now try buy 5...

You get 5 potions, and maybe 2kkk adena (from 1 adena).

 

There is any chance of support from someone to fix this?

 

PD: Tested and work on aCis 360

Recommended Posts

  • 0
Posted

Tested on 3 RU servers, don't work on any of them

They are gods, they know how to catch integer overflow! :D

  • 0
Posted

Da fak. How it come that you create English topic in GR section? Ffs.

 

Imma tell you one thing, it's current on all l2j packs. Also, gz for the topic. Now everyone will know about that issue, but from another side, shitty servers will go down :D

 

I posted it here because i sent a PM to Tryskell two weeks ago and he never answer me, then i sent you another PM and you just told me "a very nasty bug", but as you enjoy trolling noobs like me, i don't know if you was saying it seriously or just kidding.

  • 0
Posted

I posted it here because i sent a PM to Tryskell two weeks ago and he never answer me, then i sent you another PM and you just told me "a very nasty bug", but as you enjoy trolling noobs like me, i don't know if you was saying it seriously or just kidding.

He is just kidding always

  • 0
Posted

Meeee, nooo wai. I'm always serious  :you serious?:

 

 

:happyforever:  :you serious?:  :happyforever:  :you serious?:  :dat:  :happyforever:

  • 0
Posted

 

If you buy any item in any multisell shop, and the amount of required adena is higher than the adena limit of interlude, you get the items, and it cost you... not 0 adena, but -1444684684 adena, you get the items, and you gain adena.
 
Example:
 
You sell 1 potion for 500kk adena, and you have 1 adena in your inventory.
Try buy 1 or 2 or 3 or 4 potions, and you get the message "you don't have enough adena".
Now try buy 5...
You get 5 potions, and maybe 2kkk adena (from 1 adena).
 
There is any chance of support from someone to fix this?
 
PD: Tested and work on aCis 360

 

 

The fix is straight forward, cast the multiplication of count and price into an long and compare it with Integer.MAX_VALUE, I personally prefer masking it with 0xFF

  • 0
Posted

this one is even better

It's exactly what you suggest

/**
 * Returns the product of the arguments,
 * throwing an exception if the result overflows an {@code int}.
 *
 * @param x the first value
 * @param y the second value
 * @return the result
 * @throws ArithmeticException if the result overflows an int
 * @since 1.8
 */
public static int multiplyExact(int x, int y) {
    long r = (long)x * (long)y;
    if ((int)r != r) {
        throw new ArithmeticException("integer overflow");
    }
    return (int)r;
}
  • 0
Posted

 

It's exactly what you suggest

/**
 * Returns the product of the arguments,
 * throwing an exception if the result overflows an {@code int}.
 *
 * @param x the first value
 * @param y the second value
 * @return the result
 * @throws ArithmeticException if the result overflows an int
 * @since 1.8
 */
public static int multiplyExact(int x, int y) {
    long r = (long)x * (long)y;
    if ((int)r != r) {
        throw new ArithmeticException("integer overflow");
    }
    return (int)r;
}

 

ofc it is, I am veteran in OOP 

  • 0
Posted

Is this bug because of the overflow only, or there is something more? Because the overflow is easy to catch...

  • 0
Posted (edited)

Fix is simple... just throw InvalidArgumentException when reducing inventory item with negative count, after that just look from where all the errors come xD Problem isnt only multisell, also bug works everywhere, except russian packs, they have this

private static long mulAndCheck(long a, long b, String msg, boolean limit) {
		long ret;
		if (a > b)
			// use symmetry to reduce boundary cases
			ret = mulAndCheck(b, a, msg, limit);
		else if (a < 0) {
			if (b < 0) {
				// check for positive overflow with negative a, negative b
				if (a >= Long.MAX_VALUE / b)
					ret = a * b;
				else if(limit)
					ret = Long.MAX_VALUE;
				else
					throw new ArithmeticException(msg);
			} else if (b > 0) {
				// check for negative overflow with negative a, positive b
				if (Long.MIN_VALUE / b <= a)
					ret = a * b;
				else if(limit)
					ret = Long.MIN_VALUE;
				else
					throw new ArithmeticException(msg);
			}
			else
				ret = 0;
		} else if (a > 0) {
			// check for positive overflow with positive a, positive b
			if (a <= Long.MAX_VALUE / b)
				ret = a * b;
			else if(limit)
				ret = Long.MAX_VALUE;
			else
				throw new ArithmeticException(msg);
		}
		else
			ret = 0;
		return ret;
	}
:D:D:D:D:D:D:D:D

Its pure govnokod though. http://govnokod.ru/java

Edited by Nik
Guest
This topic is now closed to further replies.



  • Posts

    • https://web.archive.org/web/20260306183214/https://maxcheaters.com/topic/241828-l2j-l2damage/page/3/ https://l2topzone.com/forum/l2-server-support-problems/9/l2damage-stopped/30514 Also we will try to push longer seasons ever ! (1135-100)/9 = 115 online
    • ONE SIDE – AND EVERYTHING BREAKS ▪ Looks like a simple case: Florida DL, back side, barcode – “clean and minimal”. ▪ In reality, these are exactly the tasks that fail most often. – data provided as plain text – request only for the back side – focus on the barcode (PDF417) ▪ And here’s the key point: ▪ A barcode is not just a “picture on the back”. It’s compressed logic of the entire document. ▪ If it doesn’t match the front, format, and data structure – the system flags it instantly. ▪ Many create a “similar-looking” code. But systems don’t read “similar” – they read by specification. ▪ In cases like this, it’s not about design. It’s about correct data assembly and how it behaves inside the format. ▪ Today only – 15% off for verification cases. ▪ Want it to pass, not just look right? Describe your case – we’ll show where even clean files break. › TG: @mustang_service ( https:// t.me/ mustang_service ) › Channel: Mustang Service ( https:// t.me/ +JPpJCETg-xM1NjNl ) #editing #photoshop #documents #verification #case
    • Your anonymity is a corpse. Blockchain forgets nothing. Your transactions are direct footprints in the hands of anyone who takes an interest. [✘] Still believe in "mixing"? Forget it. Classic Bitcoin mixers are an illusion of security. For Chainalysis and Elliptic algorithms, any attempt to hide tracks in the ledger is transparent. Your "mixing" is an artifact that gets filtered out in seconds. Every transaction leaves a trail that leads to frozen assets or unwanted questions from exchanges.  We don't mix. We break the link. [-] Input: Your "dirty" coins (Dirty BTC/ETH) with all their history and digital markers stay with us. [+] Output: You receive absolutely clean assets (Clean Crypto) from our reserves, which have never intersected with your past. This isn't a game of hide and seek. This is the surgical removal of your financial history from the system.   ------------------------------------------------------------------- Technical indexing: Bitcoin Mixer, Crypto Mixer, Clean BTC, Clean ETH, Anti-Chainalysis, Best Bitcoin Mixer, Anonymous Crypto Exchange, NoLog Mixing Service.
    • Here you are: https://l2crypt.com/l2-tools/l2editor-source/
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..