Jump to content

Recommended Posts

Posted (edited)

One thing I hate with L2J is the integer based objectId, anyone with me?

 

It can be unlinked from objects, like retail is.

Edited by Mobius
Posted

It can be unlinked from objects, like retail is.

 

The point is, to have a server side hidden objectId and generate new for the clients side runtime. An even better idea is to wrap the hidden server side objectId into a Passport object that is unique and static for every player so you can do more stuff with it.

Posted (edited)

Erm, the point of objectId is to stay unique for the object, and released when object is really destroyed (and I speak of server destroy, like delete an item or delete a spawn entirely).

 

I find it useful personally, and it's transparent if you move the initialization into L2Object directly (another cleanup to do).

 

In what specific case you find it wrong ? With what could you replace such unique id with ?

Edited by Tryskell
Posted

So people can sell your work just because they add some shared shits? :D

I didnt said that, my point is, if it's easily accessible, it's pointless to buy another "pro/bugless" (shit) pack :D

Posted

One thing I hate with L2J is the integer based objectId, anyone with me?

Why is that, you still need something for packet

Posted (edited)

Why is that, you still need something for packet

 

I already explained before the flaws. I will do it again:

 

The current objectId is always static on the object and I can post these few flaws on the fly (obviously much more exist)

  • Very easy to create client hacks / scripts / edits / flood
  • Dumb primitive int data type that can only perform mathematical operations (I will explain later why I call it dumb)
  • L2Official objectIds are not final on the objects (even players)

 

So instead of having a single int as objectId we could make passport objects that ARE ALWAYS STATIC on the players at least (further optimization for any object?)

 

This Passport object can now

  • Have a hidden static server-sided UNIQUE objectId
  • Dynamically change / update the client transmitted objectId on demand (clientObjectId int type generated on the fly (bucket hashing so nothing strict here))
  • We can attach routines on it (event engines, quests will authenticate easier and more efficient)
  • Be Compare to other Passport objects as fast as comparing the two old objectIds

Im already experimenting this on my live server with minimal issues

 

L2J really needs something static between _objectId and L2PcInstance reference let me give a basic example why:

 

Check this scenario:

  • Player1 registers on the event / quest / whatever and the developer who created it stores him temporarly in ANY of the java Collection (may be List, Set or whatever)
  • Player 1 unregisters, he is removed
  • Player1 registers again
  • Player1 restarts, a new L2PcInstance reference is assigned to him
  • Player1 registers on the event again but the developer didn't handled his disconnection before so our Collection has 2 references for the same actual player
  • The event ends and the player is rewarded twice

The above is a very basic example scenario that proves that the current design of player authentication is non-existant. Now imagine a very complex scenario, the authentication part gets out of hand very easily and objectId alone can't help you with efficient and good OOP code.

Edited by xxdem
Posted

One of my customer's is Mobius itself :D

cool isn't it?

Yes it is, might the beginning of his pack

Posted

I already explained before the flaws. I will do it again:

 

The current objectId is always static on the object and I can post these few flaws on the fly (obviously much more exist)

  • Very easy to create client hacks / scripts / edits / flood
  • Dumb primitive int data type that can only perform mathematical operations (I will explain later why I call it dumb)
  • L2Official objectIds are not final on the objects (even players)

So instead of having a single int as objectId we could make passport objects that ARE ALWAYS STATIC on the players at least (further optimization for any object?)

 

This Passport object can now

  • Have a hidden static server-sided UNIQUE objectId
  • Dynamically change / update the client transmitted objectId on demand (clientObjectId int type generated on the fly (bucket hashing so nothing strict here))
  • We can attach routines on it (event engines, quests will authenticate easier and more efficient)
  • Be Compare to other Passport objects as fast as comparing the two old objectIds
Im already experimenting this on my live server with minimal issues

 

L2J really needs something static between _objectId and L2PcInstance reference let me give a basic example why:

 

Check this scenario:

  • Player1 registers on the event / quest / whatever and the developer who created it stores him temporarly in ANY of the java Collection (may be List, Set or whatever)
  • Player 1 unregisters, he is removed
  • Player1 registers again
  • Player1 restarts, a new L2PcInstance reference is assigned to him
  • Player1 registers on the event again but the developer didn't handled his disconnection before so our Collection has 2 references for the same actual player
  • The event ends and the player is rewarded twice
The above is a very basic example scenario that proves that the current design of player authentication is non-existant. Now imagine a very complex scenario, the authentication part gets out of hand very easily and objectId alone can't help you with efficient and good OOP code.

Well I see the point, but for your scenario the dev is to blame :D he could have used weakref

 

Anyway, I fail to see how much damage it would cause to replace the current object ID, since you did it, any insight? I'm busy enough to avoid some dumb crusade:D

Posted (edited)

Well I see the point, but for your scenario the dev is to blame :D he could have used weakref

 

Anyway, I fail to see how much damage it would cause to replace the current object ID, since you did it, any insight? I'm busy enough to avoid some dumb crusade:D

 

The weakref is not an optimal solution, and I blame the project for this reason, we are supposed to create weakrefs all the time that complicate things even more and usually are innefficient or slow and eventually the projects end up with thousand of different weakrefs or other ways to counter-measure this. All these originate from the weak objectId ofcourse.

Edited by xxdem
Posted

Well weak ref is not a solution for sure, we use another I'm lazy to describe but not optimal either for sure.

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

    • Yeah inside router i had to enable udnp services 
    • Hello cheaters, As a team of avid developers and enthusiasts of Lineage 2, we are excited to present the L2 Control Hub, a groundbreaking plugin designed by myself and my collaborator, StinkyMadness. This innovative tool equips server administrators with powerful automation capabilities directly within the game's community board. L2 Control Hub simplifies the creation and management of automations, enabling you to customize your server operations without the need to modify the source code.   Key Features of L2 Control Hub: Robust Automation Triggers: Select from a plethora of triggers currently available, with continuous additions in the works to enhance your control options. Dynamic Conditions and Actions: Tailor your server operations with an extensive range of conditions and actions, ensuring flexible and precise control over game events and player interactions. Customizable Variables: Easily integrate server-specific variables from your database to further personalize and streamline your automations. Utilize these variables across various automation scenarios to cater to your specific server requirements. JavaScript Integration: Execute custom JavaScript codes that interact seamlessly with Java classes, bringing advanced functionalities to your server's ecosystem.   Explore L2 Control Hub in Action: We've prepared a series of video tutorials to demonstrate the capabilities of L2 Control Hub: Control Hub - Create a Simple Flow with 1 Condition and 1 Action: Get started with basic automations. Control Hub - Multiple Conditions with Multiple Actions: Explore more complex automations for detailed server management. Control Hub - Using Variables: Discover how to implement and use custom variables for tailored automations. Control Hub - Using JavaScript: Experience the power of custom scripts in enhancing your server functionality.   L2 Control Hub is currently about 70% complete, and we are actively developing and refining features. We invite you to join our ➡️ Discord community ⬅️ to engage with the development process, provide feedback, and be the first to test new features. Additionally, any updates or changes to the plugin are seamlessly delivered to all customers directly from our web server, ensuring your system is always up-to-date without the need for manual downloads.   Your game, your rules, automated. Join us in redefining server management in Lineage 2 and elevate your gaming community with unmatched automation capabilities. For more details, contact us directly to get started with L2 Control Hub.   Currently, the plugin is developed using aCis sources. We will continue with these sources until we finalize all the necessary details before proceeding to integrate with the more prominent sources available.       The L2 Control Hub is designed to extend beyond mere functional additions to your server. We are in the process of implementing a suite of advanced mechanisms, such as a vote manager capable of interfacing with any Lineage 2 voting site without requiring configuration, live statistics to provide admins with real-time insights, and an event engine that can generate any desired event within seconds. All these features will be seamlessly integrated into the module, enhancing your server management experience significantly.     Please note that L2 Control Hub will be a premium tool, reflecting the extensive features and benefits it offers. While we are finalizing the pricing structure, rest assured that we aim to deliver great value for your investment. We will announce the cost details soon on our platforms to ensure everyone is well-informed and can plan accordingly. Join us to take your server management to the next level with L2 Control Hub.     
    • The link soucer and system are off, reup please, thanks very much @HypeH
    • DISCORD : utchiha_market telegram : https://t.me/utchiha_market SELLIX STORE : https://utchihamkt.mysellix.io/ Join our server for more products : https://discord.gg/hood-services https://campsite.bio/utchihaamkt  
    • Hola, Busco proveedores de adena en Reborn signature. Trabajo serio, Web de ventas Seria. Adena-Shop. Discord: susi007317   Hello, I am looking for adena suppliers in Reborn signature. Serious work, Serious sales Web. Adena-Shop. Discord: susi007317
  • Topics

×
×
  • Create New...