-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
FEAT(client): Introduced new mumble API #6425
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for haven taken so long to review this. The proposed changes look mostly fine to me. The review comments are mostly about some minor coding style detail, some rewording of documentation or some small generalization of the proposed API.
@mryamac could you please rebase your branch against current master? It seems like FreeBSD has bricked the Qt package again. However, we have recently switched to Qt 6 anyway so maybe that is enough to resolve the issue. |
433d04a
to
e80a6e1
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I just noticed two more things
- Linking channels and creating listeners in channels is subject to ACL restrictions. If the local user is lacking the respective permissions, the actions will (silently) fail. That's just what it is but one scenario that is not covered by this is the case in which the server admin explicitly grants certain permissions to the plugin that the user doesn't have. This is already possible for e.g. the
requestUserMove
function which accepts a password which can offer special ACLs for this specific call from the plugin. I think that the link- and listen-related API function should also allow for a password to be provided for such a purpose. - This PR introduces a function to send a text message to a group of users. I would propose to extend the function signature to also allow sending text messages to a given set of channels. Then the function can be used to either send to users or to channels or both at the same time allowing for maximum flexibility. Sending text messages to channels introduces ACL restrictions though so the same password parameter as proposed for the other functions would apply.
* @param message The message to send (UTF-8 encoded) | ||
* @param messageSize The size (in bytes) of the message | ||
* @returns The error code. If everything went well, STATUS_OK will be returned. | ||
*/ | ||
mumble_error_t(MUMBLE_PLUGIN_CALLING_CONVENTION *requestSendUserTextMessage)( | ||
mumble_plugin_id_t callerID, mumble_connection_t connection, mumble_userid_t *users, std::size_t userAmount, | ||
const char *message, std::size_t messageSize); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
* @param message The message to send (UTF-8 encoded) | |
* @param messageSize The size (in bytes) of the message | |
* @returns The error code. If everything went well, STATUS_OK will be returned. | |
*/ | |
mumble_error_t(MUMBLE_PLUGIN_CALLING_CONVENTION *requestSendUserTextMessage)( | |
mumble_plugin_id_t callerID, mumble_connection_t connection, mumble_userid_t *users, std::size_t userAmount, | |
const char *message, std::size_t messageSize); | |
* @param message The message to send (UTF-8 encoded as a C-string) | |
* @returns The error code. If everything went well, STATUS_OK will be returned. | |
*/ | |
mumble_error_t(MUMBLE_PLUGIN_CALLING_CONVENTION *requestSendUserTextMessage)( | |
mumble_plugin_id_t callerID, mumble_connection_t connection, mumble_userid_t *users, std::size_t userAmount, | |
const char *message); |
Sorry for reverting my own suggestion here. I noticed that we are using C-strings in other parts of the API already which inhibits null bytes from being part of it but since we use that for passwords, we can certainly use this for text messages which indeed can't contain null bytes.
@@ -47,12 +47,22 @@ | |||
EXIT_WITH(MUMBLE_EC_INVALID_PLUGIN_ID); \ | |||
} | |||
|
|||
#define VERIFY_CHANNEL_ID(id) \ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
please #undef
all macros at the end of the file
|
||
VERIFY_PLUGIN_ID(callerID); | ||
|
||
VERIFY_CONNECTION(connection); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All new implementations have to also check that the connection is synchronized.
#define VERIFY_USER_ID(id) \ | ||
if (!ClientUser::get(id)) { \ | ||
EXIT_WITH(MUMBLE_EC_USER_NOT_FOUND); \ | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
semantically it would make sense to keep the macros related to the connection together and then define this new macro either before both of them or after (but not in between)
For the first item, This function takes tempAccessToken, but in my cases, link/unlink vs. functions don't have any parameters like that. So, to be able to give permission, do I need to modify the ServerHandler class? Item two seems clear to me. I will implement this API, but first, I need to understand the ACL case. |
Temorary access tokens can be used to increase the permissions of the acting user while processing this specific message. These tokens won't be persisted on the server. Previously, only the UserState message supported temporary access tokens, but there is no reason why other messages shouldn't support them as well. Those messages that still don't support temporary access tokens are those that (typically) don't require any permission checks for processing on the server anyway.
This patch introduces a new API to link, unlink, start to listen, stop the listen the channels and send the messages to the plugins
Sorry, this got lost on my end.
Among other things. In order to support this, a protocol extension and server support is required. I have now implemented all of that for you. @mryamac do you have intentions to pick this PR back up or do you want me finish it for you? In case you want to pick it up again, make sure to do a hard reset of your local branch to the remote one as I force-pushed your branch as the protocol extension needs to come before your own commit (that uses it). |
This patch introduces a new API to link, unlink, start to listen, stop the listen the channels and send the messages to the plugins
Checks