Jonne Posted January 1, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Share Posted January 1, 2012 (edited) Well, I would find it to be time to change the atcommand or GM system. So you actually group Users and not give them levels and like this you can better handle giving out atcommands and create a hierarchie which is not just drop-down. So the admin for example has all rights. He then creates a group called EventGM. Those have certain commands. Then he created a group called SupportGM. They have completly different commands, but they are not considered 'lower'. Also, EventGMs don't automatically have the commands of SupportGMs and so on. This system was once introduced on eAthena as MOD and I think if someone could provide a fully working system for rAthena it should replace the old system officially. Who's in? Edited January 2, 2012 by Jonne 7 Link to comment Share on other sites More sharing options...
Gepard Posted January 2, 2012 Group: Members Topic Count: 22 Topics Per Day: 0.00 Content Count: 392 Reputation: 285 Joined: 12/19/11 Last Seen: January 23, 2022 Share Posted January 2, 2012 Sounds like one of a few features that are actually worth working on. Link to comment Share on other sites More sharing options...
Jonne Posted January 2, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 2, 2012 Sounds like one of a few features that are actually worth working on. I found the snippet, but it is in German Athena (http://www.eathena.ws/board/index.php?showtopic=193551). Anyway, the idea was to use the "GM Level" as bit-flag and every bit has certain commands with them. And the admin has for example all bits set and so on. I hope you get the idea. Link to comment Share on other sites More sharing options...
saithis Posted January 2, 2012 Group: Members Topic Count: 2 Topics Per Day: 0.00 Content Count: 40 Reputation: 20 Joined: 12/31/11 Last Seen: May 10, 2013 Share Posted January 2, 2012 +1 for a new GM system, but please don't use that snippet xD That was one of the first things i coded in C and it is really ugly code. And I would prefer something without bitflags, as they aren't beginner friendly at all... Link to comment Share on other sites More sharing options...
Jonne Posted January 2, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 2, 2012 (edited) +1 for a new GM system, but please don't use that snippet xD That was one of the first things i coded in C and it is really ugly code. And I would prefer something without bitflags, as they aren't beginner friendly at all... I wouldn't recommend it either, I just thought it would be good to understand the system for those with knowledge in C. And for the thing whether to use bitflags or not: That's what this discussion is for, isn't it? I think we could use a system like Bukkit(the minecraft server emulator) where they create groups and they can inherit rights of others groups and you can assigm rights to every group and so on. P.S. If we don't use bitflags, then it will get pretty messy. You would need one file for each group that coups any command or at least every command they have access to. But that might be more user-friendly in the end. Edited January 2, 2012 by Jonne Link to comment Share on other sites More sharing options...
xazax Posted January 3, 2012 Group: Members Topic Count: 11 Topics Per Day: 0.00 Content Count: 427 Reputation: 123 Joined: 11/17/11 Last Seen: December 31, 2022 Share Posted January 3, 2012 Well, grouping command would not be that hard however.. There are configs like from which level can a gm trade etc. We also need those configs to be set on each group. I think it would increase the complexity of the GM system greatly, unless you have a good idea how to handle this. Link to comment Share on other sites More sharing options...
Jonne Posted January 3, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 3, 2012 (edited) Well, grouping command would not be that hard however.. There are configs like from which level can a gm trade etc. We also need those configs to be set on each group. I think it would increase the complexity of the GM system greatly, unless you have a good idea how to handle this. I don't have quite a good solution. It's a complex topic. Maybe having one root GM group which can be inherited and which says that this group can't trade. If somebody were to want changes, they could just copy&paste the group and alter it or just alter the original. Not sure if it is possible to add this system with all our GM configs without adding this much complexity. Edit: Or just forbidding it by default and having a "root" GM group which allows GMs to do it if they are in. I also think we need to discuss the GM titles, if they can be in more than one group. Edited January 3, 2012 by Jonne Link to comment Share on other sites More sharing options...
Gepard Posted January 3, 2012 Group: Members Topic Count: 22 Topics Per Day: 0.00 Content Count: 392 Reputation: 285 Joined: 12/19/11 Last Seen: January 23, 2022 Share Posted January 3, 2012 Proposal: config file to define groups <group_id>:<group_name>{:<inherit_from_another_group_id>} atcommand_conf - use group names instead of levels gm_conf - use group names instead of levels login table - `group_id` instead of `level` 4 Link to comment Share on other sites More sharing options...
Jonne Posted January 3, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 3, 2012 Proposal: config file to define groups <group_id>:<group_name>{:<inherit_from_another_group_id>} atcommand_conf - use group names instead of levels gm_conf - use group names instead of levels login table - `group_id` instead of `level` About that, yes. Also inherit what they inherit and multi inheritance. <group_id>:<group_name>{;<inherit_from_group_id>,<inherit_from_group_id>,...} Link to comment Share on other sites More sharing options...
vBrenth Posted January 3, 2012 Group: Members Topic Count: 35 Topics Per Day: 0.01 Content Count: 311 Reputation: 46 Joined: 11/06/11 Last Seen: Wednesday at 08:29 PM Share Posted January 3, 2012 +1 to this! can't wait to see this Link to comment Share on other sites More sharing options...
Natsu Dragneel Posted January 4, 2012 Group: Members Topic Count: 46 Topics Per Day: 0.01 Content Count: 138 Reputation: 1 Joined: 12/27/11 Last Seen: September 7, 2016 Share Posted January 4, 2012 this will reduce the abuse in gm power! Link to comment Share on other sites More sharing options...
Hybrid Posted January 4, 2012 Group: Members Topic Count: 3 Topics Per Day: 0.00 Content Count: 8 Reputation: 0 Joined: 01/02/12 Last Seen: May 18, 2014 Share Posted January 4, 2012 Sounds like a plan For the GM configurations, such as "What level GM can trade", etc etc, then how about making it so the admin will define groups in which trading is allowed/disallowed. That way, there wouldn't really need to be a root GM group which is allowed to trade, and it might simplify coding, though I might just be sorely mistaken on the matter Link to comment Share on other sites More sharing options...
Maki Posted January 4, 2012 Group: Members Topic Count: 146 Topics Per Day: 0.03 Content Count: 1195 Reputation: 467 Joined: 11/15/11 Last Seen: April 11, 2023 Share Posted January 4, 2012 /me also thinks it would be nice to be able to add GM Commands to Guilds and characters; so it does not have to be account-specific giving you more control/freedom *-* Link to comment Share on other sites More sharing options...
Jonne Posted January 4, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 4, 2012 /me also thinks it would be nice to be able to add GM Commands to Guilds and characters; so it does not have to be account-specific giving you more control/freedom *-* This topic never intended to do this, but I think we are all in for this suggestion if anybody can provide a way to do this because at the momemt the GM levels are saved in login db which is account specific. Link to comment Share on other sites More sharing options...
Toshiro Posted January 4, 2012 Group: Members Topic Count: 2 Topics Per Day: 0.00 Content Count: 106 Reputation: 29 Joined: 11/08/11 Last Seen: Wednesday at 05:06 PM Share Posted January 4, 2012 /me also thinks it would be nice to be able to add GM Commands to Guilds and characters; so it does not have to be account-specific giving you more control/freedom *-* This topic never intended to do this, but I think we are all in for this suggestion if anybody can provide a way to do this because at the momemt the GM levels are saved in login db which is account specific. For that purpose there would be another table needed to specify which account/character/guild should be aligned to which group. The only problem would be the compatibility to the Control Panels and stuff. Link to comment Share on other sites More sharing options...
Gepard Posted January 4, 2012 Group: Members Topic Count: 22 Topics Per Day: 0.00 Content Count: 392 Reputation: 285 Joined: 12/19/11 Last Seen: January 23, 2022 Share Posted January 4, 2012 /me also thinks it would be nice to be able to add GM Commands to Guilds and characters; so it does not have to be account-specific giving you more control/freedom *-* This topic never intended to do this, but I think we are all in for this suggestion if anybody can provide a way to do this because at the momemt the GM levels are saved in login db which is account specific. For that purpose there would be another table needed to specify which account/character/guild should be aligned to which group. The only problem would be the compatibility to the Control Panels and stuff. No, that's bad idea. Things like that should not be saved in config file, but in SQL database. Solution is to add `GM_level` (or `group`) field to `guild` / `char` table. However I don't really see a scenario where adding it to single characters is necessary. 3 Link to comment Share on other sites More sharing options...
CalciumKid Posted January 5, 2012 Group: Members Topic Count: 25 Topics Per Day: 0.01 Content Count: 257 Reputation: 253 Joined: 11/29/11 Last Seen: February 21, 2014 Share Posted January 5, 2012 ^ many servers only allow one character to retain GM powers. This could help to enforce that. Link to comment Share on other sites More sharing options...
Realusion Posted January 5, 2012 Group: Members Topic Count: 1 Topics Per Day: 0.00 Content Count: 57 Reputation: 15 Joined: 12/25/11 Last Seen: October 1, 2016 Share Posted January 5, 2012 Yep, I've also seen servers where only one character was given GM powers. A re-design of the system would provide a lot more flexibility in cases like that and perhaps grant various other possibilities as well. Link to comment Share on other sites More sharing options...
Jonne Posted January 5, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 5, 2012 (edited) Yep, I've also seen servers where only one character was given GM powers. A re-design of the system would provide a lot more flexibility in cases like that and perhaps grant various other possibilities as well. Give whole account rights and limit account to one player. Why should he have legit chars on the rest of his account, but this is not up to me to decide. Anyways, I think it might be time for the team to give a statement (yay or nay) and then start a poll or drop the topic, as I can see from this topic lots of agreement. Edited January 5, 2012 by Jonne Link to comment Share on other sites More sharing options...
Realusion Posted January 5, 2012 Group: Members Topic Count: 1 Topics Per Day: 0.00 Content Count: 57 Reputation: 15 Joined: 12/25/11 Last Seen: October 1, 2016 Share Posted January 5, 2012 None said that he would have legit characters on the other slots. I was just saying there would be an increase in flexibility, which is essentially true. Link to comment Share on other sites More sharing options...
SkzBR Posted January 5, 2012 Group: Members Topic Count: 1 Topics Per Day: 0.00 Content Count: 27 Reputation: 5 Joined: 11/19/11 Last Seen: July 30, 2012 Share Posted January 5, 2012 I vote for something more complex, but in my mind, give more controls to server owners. group <UNIQUE_ID> { <KEY>:<VALUE>, inherit: <GROUP_ID>{,<GROUP_ID>,<GROUP_ID>,<GROUP_ID>,<GROUP_ID>,...}, } example: group admin { can_drop_items: 1, can_do_something: 1, can_do_anything: 1, inherit: gamemasters, players } group supporters { can_do_anything_that_gm_not: 1, } command configuration: hide: gamemasters rates: players jumpto: supporters If we do rewrite the system, lets make a stable and consistent system. With this, you solve the problem with items and others configurations... and others will just need to edit 2 files (groups and commands), so permissions will go in the groups, and not around 1000 config files. Link to comment Share on other sites More sharing options...
Jonne Posted January 5, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 5, 2012 (edited) I vote for something more complex, but in my mind, give more controls to server owners. group <UNIQUE_ID> { <KEY>:<VALUE>, inherit: <GROUP_ID>{,<GROUP_ID>,<GROUP_ID>,<GROUP_ID>,<GROUP_ID>,...}, } example: group admin { can_drop_items: 1, can_do_something: 1, can_do_anything: 1, inherit: gamemasters, players } group supporters { can_do_anything_that_gm_not: 1, } command configuration: hide: gamemasters rates: players jumpto: supporters If we do rewrite the system, lets make a stable and consistent system. With this, you solve the problem with items and others configurations... and others will just need to edit 2 files (groups and commands), so permissions will go in the groups, and not around 1000 config files. Somehow for it. I do really want a more complex system. But you'd need some more info in each group: group <group_id> { name: <name> rights: <key>{,<key>{,...}} inherit: <group_id>{,<group_id>{,...}} } What I think of is, that group_id really is a number (the old GM level) and name is what is displayed as his "rank". All rights the group has will be after rights, like: rights: can_drop,can_bypass_statmax etc. I would also go along with SkzBR's suggestion. Like this we can create redundant groups that are just patterns to inherit for other groups. Edited January 5, 2012 by Jonne Link to comment Share on other sites More sharing options...
saithis Posted January 5, 2012 Group: Members Topic Count: 2 Topics Per Day: 0.00 Content Count: 40 Reputation: 20 Joined: 12/31/11 Last Seen: May 10, 2013 Share Posted January 5, 2012 I think it would be better to have the commands and configs with true or false setting in the groups. That way we could revoke a permission from a inherited group. Example: gamemaster { permissions { can_trade: true, // ... } //... } supporter { commands { autotrade: true, iteminfo: true, // ... } permissions { can_trade: false, // overwrites 'true' of the gamemaster group // ... } inherit: gamemaster } 2 Link to comment Share on other sites More sharing options...
Jonne Posted January 5, 2012 Group: Members Topic Count: 8 Topics Per Day: 0.00 Content Count: 153 Reputation: 33 Joined: 12/24/11 Last Seen: September 30, 2024 Author Share Posted January 5, 2012 I think it would be better to have the commands and configs with true or false setting in the groups. That way we could revoke a permission from a inherited group. Example: gamemaster { permissions { can_trade: true, // ... } //... } supporter { commands { autotrade: true, iteminfo: true, // ... } permissions { can_trade: false, // overwrites 'true' of the gamemaster group // ... } inherit: gamemaster } True. And all not mentioned commands and permissions are automatically true or false? Or true for group_id = 0(user?) and false for group_id != 0 (GM?)... Link to comment Share on other sites More sharing options...
Toshiro Posted January 5, 2012 Group: Members Topic Count: 2 Topics Per Day: 0.00 Content Count: 106 Reputation: 29 Joined: 11/08/11 Last Seen: Wednesday at 05:06 PM Share Posted January 5, 2012 True. And all not mentioned commands and permissions are automatically true or false? Or true for group_id = 0(user?) and false for group_id != 0 (GM?)... Group 0 would be the default group with predefined settings (as everything else has predefined settings as well). Link to comment Share on other sites More sharing options...
Recommended Posts