|
07-27-2019, 05:05 AM
|
|
The Undefeated
|
|
Join Date: Jul 2019
Posts: 9
|
|
Broadcasting to plugins on other Clients
I'm working on a plugin at the moment. As part of it, it would be nice for it to be able to broadcast something to update a value on everyone's plugin server wide (only very occasionally and on a button click).
Would using a userChat channel for this be allowed?
Or would that be considered as spam?
Thanks
|
07-27-2019, 11:26 AM
|
|
The Undying
|
|
Join Date: Oct 2010
Posts: 346
|
|
I created a chat system for the multi-player Cards game (unpublished). This would not be spam as it would be broadcast to a channel that players have voluntarily chosen to accept. There are however a couple of issues that have to be considered. However, all other rules of chat such as harassment, etc. would still apply even if it is a user chat - I assume your plugin is not a Monty Pythonesque channel so this shouldn't be an issue.
First, you have to determine which chat channel number your channel is on each client. Since you can't really control which channels the user already has in use, you will have to determine that at run time. This isn't too complicated, it just requires a /listchannels command in a button on your interface, then you parse the response to see if your channel already exists, if not, you present a /joinchannel button that joins the channel. You could skip the /listchannels, but then if the user did already have your channel set the response to a join is just 'You are already in room 'whatever'' without telling you which channel number so your plugin wouldn't know which number to use without first dropping the channel and re-adding it - it is simpler to just use the /listchannels to see if it is already being used and determine the channel id from that.
Unfortunately, it would be possible for someone to maliciously lock you (and any users of your plugin) out of your chosen chat channel after a server restart. We had issues with this occurring with the old glff channel on occaision - a malicious user would get in shortly after the server came up and create the channel with a password, effectively locking all other users out. Unfortunately, creating your channel with a password does not protect against this as all user chat channels are wiped when the last user leaves and the next join command creates a new channel (with whatever optional password they specify).
The second issue I haven't tested lately, but it used to be that you have to make sure your users have the specific user chat channel selected in the chat channel filters for at least one chat tab or the user won't get the messages (and your plugin won't either). I believe this is still the current rule.
These buttons can simply be displayed in a Chat Settings window that is only opened as needed to configure the plugin initially. I also allowed users to specify their own channel name there so that they could hold private games with more than 24 players/spectators.
FWIW, the chat system worked fine, I suspended development of the game system because it was far too easy for players to cheat. I toyed with a number of solutions to the cheating issue but none of them were satisfactory so I scrapped it but the user chat subsystem was a sound idea for cross client plugin communication.
Last edited by Garan : 07-27-2019 at 11:48 AM.
Reason: clarification
|
07-27-2019, 11:44 AM
|
|
The Undefeated
|
|
Join Date: Jul 2019
Posts: 9
|
|
Quote:
Originally Posted by Garan
I created a chat system for the multi-player Cards game (unpublished). This would not be spam as it would be broadcast to a channel that players have voluntarily chosen to accept. There are however a couple of issues that have to be considered.
First, you have to determine which chat channel number your channel is on each client. Since you can't really control which channels the user already has in use, you will have to determine that at run time. This isn't too complicated, it just requires a /listchannels command in a button on your interface, then you parse the response to see if your channel already exists, if not, you present a /joinchannel button that joins the channel. You could skip the /listchannels, but then if the user did already have your channel set the response to a join is just 'You are already in room 'whatever'' without telling you which channel number so your plugin wouldn't know which number to use without first dropping the channel and re-adding it - it is simpler to just use the /listchannels to see if it is already being used and determine the channel id from that.
Unfortunately, it would be possible for someone to maliciously lock you (and any users of your plugin) out of your chosen chat channel after a server restart. We had issues with this occurring with the old glff channel on occaision - a malicious user would get in shortly after the server came up and create the channel with a password, effectively locking all other users out. Unfortunately, creating your channel with a password does not protect against this as all user chat channels are wiped when the last user leaves and the next join command creates a new channel (with whatever optional password they specify).
The second issue I haven't tested lately, but it used to be that you have to make sure your users have the specific user chat channel selected in the chat channel filters for at least one chat tab or the user won't get the messages (and your plugin won't either). I believe this is still the current rule.
These buttons can simply be displayed in a Chat Settings window that is only opened as needed to configure the plugin initially. I also allowed users to specify their own channel name there so that they could hold private games with more than 24 players/spectators.
FWIW, the chat system worked fine, I suspended development of the game system because it was far too easy for players to cheat. I toyed with a number of solutions to the cheating issue but none of them were satisfactory so I scrapped it but the user chat subsystem was a sound idea for cross client plugin communication.
|
Thank you for that, it would only form a tiny part of the project, so might add in a later update.
One other question, I've been struggling to recieve the message when I've sent a tell to someone else, but works fine the other way, do you know of a way to fix that? Thanks
Last edited by Agollas : 07-27-2019 at 11:44 AM.
Reason: Missing word
|
07-27-2019, 12:49 PM
|
|
The Undying
|
|
Join Date: Oct 2010
Posts: 346
|
|
Quote:
Originally Posted by Agollas
One other question, I've been struggling to recieve the message when I've sent a tell to someone else, but works fine the other way, do you know of a way to fix that? Thanks
|
This sounds like the issue I mentioned where an account doesn't have the specific user chat channel enabled in their chat filters on at least one chat tab.
For instance, if user1 has the custom channel in user chat 1 (uc1) and user2 had the custom channel in user chat 2 (uc2) then user 1 must have uc1 enabled in their chat filters and user 2 must have uc2 enabled in their chat filters. If user 2 has uc1 enabled but not uc2, they will not get the messages. I would recommend double checking the chat filters on the client that is not receiving the messages - if they display in the chat window but are still not received by the plugin then it is a different issue (are you sure your plugin is monitoring the correct user chat channel on each client?)
Last edited by Garan : 07-27-2019 at 12:51 PM.
|
07-27-2019, 01:44 PM
|
|
The Undefeated
|
|
Join Date: Jul 2019
Posts: 9
|
|
Quote:
Originally Posted by Garan
This sounds like the issue I mentioned where an account doesn't have the specific user chat channel enabled in their chat filters on at least one chat tab.
For instance, if user1 has the custom channel in user chat 1 (uc1) and user2 had the custom channel in user chat 2 (uc2) then user 1 must have uc1 enabled in their chat filters and user 2 must have uc2 enabled in their chat filters. If user 2 has uc1 enabled but not uc2, they will not get the messages. I would recommend double checking the chat filters on the client that is not receiving the messages - if they display in the chat window but are still not received by the plugin then it is a different issue (are you sure your plugin is monitoring the correct user chat channel on each client?)
|
Thanks again, yeah I was testing it and had it just repeating anything that was logged in chat.
If I typed /tell agorlas hi,
it would only repeat agorlas tells you: 'hi'
but wouldn't repeat you tell agorlas hi, even though that appears in the chat window.
Edit: Sorry, just realised I posted on the wrong section, it's meant to be for LoTRO, although I'm assuming it's similar for both?
Last edited by Agollas : 07-27-2019 at 02:05 PM.
|
07-27-2019, 02:08 PM
|
|
The Undying
|
|
Join Date: Oct 2010
Posts: 346
|
|
Quote:
Originally Posted by Agollas
Thanks again, yeah I was testing it and had it just repeating anything that was logged in chat.
If I typed /tell agorlas hi,
it would only repeat agorlas tells you: 'hi'
but wouldn't repeat you tell agorlas hi, even though that appears in the chat window.
|
ah. my mistake, I thought that you weren't receiving the tells from the other party. Is there a need to track your outgoing tells? You should still be able to, but it might require encoding the sender name in the message since the API reports the 'Sender' as the local player name (making Sender useless, or it was the last time I played with this about three years ago) for incoming messages. The actual sender is encoded in the beginning of the message in a <Select:IID> tag (which is handy if you want to create a control with a clickable link to the user). Note, that's only a problem with tells since with custom chats (or any channel other than tells), the message will be like "[To mychannel] some message" when you send the message.
Another thing I didn't mention, the response to /listchannels is a bit odd in that instead of just listing the user chats and their channels in Standard, it sends the user chat name to the actual channel for each channel that you have enabled in your filters - if you don't have a channel enabled, even if it has joined a custom chat, it will not generate a response since the chat server doesn't send messages on channels that aren't enabled in your filters. If you have a channel enabled in your filters but haven't actually joined any user chats on that channel it will respond with '<NOT CONNECTED>' on that channel.
Last edited by Garan : 07-27-2019 at 02:28 PM.
|
07-27-2019, 02:44 PM
|
|
The Undying
|
|
Join Date: Oct 2010
Posts: 346
|
|
Quote:
Originally Posted by Agollas
Edit: Sorry, just realised I posted on the wrong section, it's meant to be for LoTRO, although I'm assuming it's similar for both?
|
Heh. I hadn't noticed either. I actually don't know what if any APIs DDO supports (last I knew it only supported skins, no APIs, i.e. no actual Programming) even though I played DDO years ago, it didn't have any APIs at the time. You could send a PM to Dolby or Cairenn and ask them to move the thread but I kind of doubt if anyone will object.
Last edited by Garan : 07-27-2019 at 02:51 PM.
|
08-02-2019, 11:49 AM
|
|
The Undefeated
|
|
Join Date: Jul 2019
Posts: 9
|
|
Quote:
Originally Posted by Garan
I suspended development of the game system because it was far too easy for players to cheat. I toyed with a number of solutions to the cheating issue but none of them were satisfactory so I scrapped it but the user chat subsystem was a sound idea for cross client plugin communication.
|
With a plugin I'm working on, I may have found a solution to the cheating problem, that i just wanted to run by you, to see if you think it would work:
What if you enclosed instructions/data inside the <Select:IID:....> tags, with a randomly chosen user ID? That way it would stop people from cheating, unless they wrote their own plugin to send that data?
Thanks for your time again
|
08-02-2019, 12:38 PM
|
|
The Undying
|
|
Join Date: Oct 2010
Posts: 346
|
|
Quote:
Originally Posted by Agollas
With a plugin I'm working on, I may have found a solution to the cheating problem, that i just wanted to run by you, to see if you think it would work:
What if you enclosed instructions/data inside the <Select:IID:....> tags, with a randomly chosen user ID? That way it would stop people from cheating, unless they wrote their own plugin to send that data?
Thanks for your time again
|
Unfortunately, the "unless they wrote their own plugin" is the problem. Writing a basic Lua plugin is something anybody with even basic high school computer science knowledge can easily do. Heck, my 12 year old daughter is capable of far more complex programming. More sophisticated coding does exist but cheating would not require any sophistication. It is far too easy to display the raw chat. Additionally, it is far too easy to simply modify their own copy of the plugin - there's no way for the plugin to guarantee that the client is the unmodified client and for a card game that makes it just far too easy to cheat.
The best solution I came up with was for the dealer to control the game and broadcast only those cards that should be shown 'face up' and to send all other info via private message. It would work fairly well as long as the dealer wasn't cheating since if any of the other clients claimed to have a card that the dealer knew it hadn't dealt they could be called out and booted from the game. Unfortunately the handshaking of the private tells got excessive and just wasn't worth the hassle. I've occasionally looked at the interface to see if there was a way to streamline the communication but it always winds up being ugly and I always have far more important things on the ToDo list so it gets dropped for another year.
|
08-02-2019, 01:57 PM
|
|
The Undefeated
|
|
Join Date: Jul 2019
Posts: 9
|
|
Thanks for that.
That all makes a lot of sense, I'm thinking of working on a tag style game, that can be played anywhere instead of just the ruins in bree. I guess it would be self policing enough, that I would just need to make it harder to do rather than impossible, so I suppose if anyone wants to cheat enough to edit the code, good on them, and they will get identified as cheating anyway.
|
Thread Tools |
|
Display Modes |
Hybrid Mode
|
Posting Rules
|
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts
HTML code is Off
|
|
|
All times are GMT -5. The time now is 08:19 PM.
|
|