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

L2J Sunrise manage to sell a 2 years outdated L2J server without shame. So ...

One of my customer's is Mobius itself :D 

cool isn't it?

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.

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now



  • Posts

    • A question: I’ve had two servers that were downgraded from C6 to C4, and both would lag for players when they changed subclass, and almost every time the L2 server would crash. They say it’s a problem with the C5 skills that were added. Has anyone experienced this issue? The server would run fine without errors until people started changing classes. Has anyone gone through this and knows the solution to the problem?
    • L2jBayev Chronicle 3: Rise of Darkness – AiEngine Edition In short: this is a C3 build with a full-fledged AI engine, live mercenaries, a built-in quiz, a “personal account” in the Community Board, and server logic neatly distributed across thread pools. The project is about a living world without lags : bots farm, communicate, gather parties, teleport along routes, and the server remains cold and stable.   What's inside (the most delicious) 1) Full-fledged AI engine for characters Behavior types: farming ( FarmAI ), combat ( CombatAI ), party logic ( PartyAI ), trading/walking ( TraderAI / WalkerAI ), support roles (healer, etc.). Class profiles: for mages/archers/daggers, etc., “smart” skill rotations, distance control, sleep/save skills, healing, loot pickup, etc. are implemented (see examples of classes like SpellSingerAI , NecromancerAI , etc.). Self-healing and teleports: when dying, the bot goes through a sequence of steps without sleep()- via AITaskSequence + AITeleportToLocTask , searches for the nearest gatekeeper and teleports via TeleportationManager with routes depending on the level. Auto-support: auto-nipples, arrows/bones, smart auto-proceduring of buffs and auto-banks CP/HP/MP with thresholds - all sewn into the auxiliary EtcPlayersAi . Chat context: ChatManagerAi processes mentions, makes responses with delays (anti-flood), supports party chat and “human” reaction. Understanding: ChatManagerAi system  processes the dialogue, bots remember your aggression and insults, they start to respond less often to modern users, stop accepting or inviting to a group (party) and when it goes beyond the peak they will simply merge you, and every time they see you on the PC, there is an opportunity to measure more often, communicate respectfully and beautifully, in general, a “human” reaction. Why a player/admin needs this: bots actually “live”, farm and interact, and don’t just stand on macros. This is a great background for online and PvE action.   2) Mercenaries (Mercenary system) Full-fledged companion character : L2MercenaryInstance with its own MercenaryAI (movement, attack, support, consumables, shots). Behavior modes: DEFENDER / SUPPORT / PASSIVE - switchable to suit your playing style. Progress and trust: the mercenary's trust/exp/level grows , skills are learned according to the MercenarySkillTree (conditions are based on the trust or level of the owner). Templates and equipment: via MercenaryTemplateTable and spawner - model/weapon/type are selected. Social: MercenarySpeechManager - a set of speeches; the mercenary "comes to life" in the chat. Premium Link: Premium account owners give the mercenary additional trust (faster progress). Why: This is not a dummy pet, but a playful companion with modes, training and “character”.   3) Quiz (event viktorina ) Rounds according to schedule: pre-launch with announcements (minutes/seconds before start), registration .reg, auto-opening of the window. Multiple choice questions: question + set of answer buttons; fair processing, timings, question change. Tops and history: results table, statistics, neat UI via HTML assembly. Flexible control: you can start immediately or set a delayed start (notification package 5/2/1 min, etc.). Why: regular activity for players, “social entertainment” module right in the build.   4) Personal account in Community Board KB managers: buff cabinet, teleports, clans/forums/mail/friends, tops (PK/PvP/wealth/players), character repair, viewing skill trees , etc. Premium logic: some services/mail are limited by premium; premium also affects the visual (nickname color) and bonuses (see effect on mercenary). Single sign-on: all in one place, no team chaos. Why: conveniently manage your character and services without going into the console or installing third-party mods.   Why is the system technically valuable? Minimum load and stability Separated thread pools: AI logic, hunting, teleports, chat - on separate onesScheduledExecutorService ( AI_THREAD_POOL , MONSTER_HUNT_POOL , TELEPORT_POOL , CHAT_POOL ). No "freezing": task sequencers (teleport/recovery) work through the scheduler, not Thread.sleep(). Bot limitation: protection against overload via thresholds/counters - “extra” bots do not start. One bot - one sequence: AITaskManager ensures that the character does not have parallel conflicting tasks. Smoothing out peaks: starting tasks with offsets so that there are no simultaneous “ticks” of hundreds of bots. Monitoring/logs: own loggers (separate files for info/errors/processes/chats), CPU load monitoring. Bottom line: the build is designed for “thick online” and mass activities without TPS failures .   Additional Features Auto-alliances for farming: party logic invites suitable players (checking level/equipment/clan flags), there are “human” responses to requests. Sub/class management: out of the box helpers for changing class/subclass, auto-learning of necessary skills and selection of equipment by level. Security/protection: secondary PIN/picture password support (used in KB/voiced commands; optional). Premium accounts: privileges in KB/mail/visual and synergy with mercenary progress. Ready-made services: tops, auctions/mail, teleports from KB, buff rooms, repairs, viewing skill trees, etc.   Who is this build for? Freeshare/project admins who want a living world “from the pack”: bots and mercenaries provide a constant background of activity. Players who value convenience: personal account, premium services, events and a mercenary companion. Developers who want a clean, predictable backend with thread pools and a neat task model without “magic”.   How it differs from standard assemblies Not macros - AI profiles with “brains”: rotations, positioning, healing, decision making. Not a decoration pet - a mercenary with his own modes, progress, skill tree and lines. Not a faceless gamemod - an event quiz with UI, schedule, tops. No chaos in flows - strict pools, planning and task managers designed for online and growth. No separate scripts - a single personal account in KB for most activities.   TL;DR (one paragraph for the project card) AiEngine C3 is a build with live AI, smart bots, mercenaries (modes/progress/skills), built-in quiz, premium logic and a convenient personal account in KB. Under the hood are distributed thread pools and task managers without sleep(), so even with a dense online the server remains stable and responsive.   Additionally add - there is still a lot of interesting things command .assassin or shift+target (order murder), shift+target for admins on AI characters for control, admin panel is completely rewritten, many additional functions, mercenaries change their appearance depending on trust, deepseek and chatGPT system is connected for communication of characters like real players, GPT - for newer java, there is still a very large list of fixes after the last versions, a lot has been fixed, including height coordinates (Z) geo-Squares, pathfinding, visibility through obstacles, fix pet summons, trade packages, shop packages, many effects, quests (including the original ones like nipples, etc.), Ai behavior of NPC and RB monsters, absolutely all epics have been transferred to AiLoader no longer in python scripts. Attention! The server is suitable for both classic mode and PvP format, as well as with various mods. Absolutely everything is configured in the configurations to suit your taste and purposes of use. It is recommended to launch the server through L2ServerControl (simplifies management and control of processes). Download Servers: Chronicle 3 Server Chronicle 4 Test Upgraded Server Full Desc & screens: Post & Screens c3 Post & Desc c4    
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock