diff --git a/modules/blazium_sdk/doc_classes/LobbyClient.xml b/modules/blazium_sdk/doc_classes/LobbyClient.xml index 89fa73adfb7e..be21f8da1d46 100644 --- a/modules/blazium_sdk/doc_classes/LobbyClient.xml +++ b/modules/blazium_sdk/doc_classes/LobbyClient.xml @@ -9,6 +9,31 @@ + + + + + Clears the lobby data. Only works if you are host. + Generates [signal received_lobby_data]. + + + + + + + + Clears the peer data. Only works if you are host. + Generates [signal received_peer_data]. + + + + + + + Clears the peers data. Only works if you are host. + Generates [signal received_peer_data]. + + @@ -27,6 +52,34 @@ Generates [signal lobby_created] signal. + + + + + + Delete one key from the lobby data. Only works if you are host. + Generates [signal received_lobby_data]. + + + + + + + + + Delete one key from the peer data. Only works if you are host. + Generates [signal received_peer_data]. + + + + + + + + Delete one key from the peers data. Only works if you are host. + Generates [signal received_peer_data]. + + @@ -135,7 +188,7 @@ - + Set data on the peer. Only works if you are host. Generates [signal received_peer_data] signal if you are in lobby. @@ -152,7 +205,7 @@ - + Set data on the peers. Only works if you are host. Generates [signal received_peer_data] signal if you are in lobby. diff --git a/modules/blazium_sdk/lobby/lobby_client.cpp b/modules/blazium_sdk/lobby/lobby_client.cpp index 02dce01302ad..8aa348a473a9 100644 --- a/modules/blazium_sdk/lobby/lobby_client.cpp +++ b/modules/blazium_sdk/lobby/lobby_client.cpp @@ -88,9 +88,18 @@ void LobbyClient::_bind_methods() { ClassDB::bind_method(D_METHOD("set_lobby_sealed", "seal"), &LobbyClient::seal_lobby); ClassDB::bind_method(D_METHOD("notify_lobby", "data"), &LobbyClient::lobby_notify); ClassDB::bind_method(D_METHOD("notify_peer", "data", "target_peer"), &LobbyClient::peer_notify); + ClassDB::bind_method(D_METHOD("set_lobby_data", "data", "is_private"), &LobbyClient::lobby_data, DEFVAL(false)); - ClassDB::bind_method(D_METHOD("set_peer_data", "data", "target_peer", "is_private"), &LobbyClient::set_peer_data); - ClassDB::bind_method(D_METHOD("set_peers_data", "data", "is_private"), &LobbyClient::set_peers_data); + ClassDB::bind_method(D_METHOD("del_lobby_data", "key", "is_private"), &LobbyClient::del_lobby_data, DEFVAL(false)); + ClassDB::bind_method(D_METHOD("clear_lobby_data", "is_private"), &LobbyClient::clear_lobby_data, DEFVAL(false)); + + ClassDB::bind_method(D_METHOD("set_peer_data", "data", "target_peer", "is_private"), &LobbyClient::set_peer_data, DEFVAL(false)); + ClassDB::bind_method(D_METHOD("del_peer_data", "key", "target_peer", "is_private"), &LobbyClient::del_peer_data, DEFVAL(false)); + ClassDB::bind_method(D_METHOD("clear_peer_data", "target_peer", "is_private"), &LobbyClient::clear_peer_data, DEFVAL(false)); + + ClassDB::bind_method(D_METHOD("set_peers_data", "data", "is_private"), &LobbyClient::set_peers_data, DEFVAL(false)); + ClassDB::bind_method(D_METHOD("del_peers_data", "key", "is_private"), &LobbyClient::del_peers_data, DEFVAL(false)); + ClassDB::bind_method(D_METHOD("clear_peers_data", "is_private"), &LobbyClient::clear_peers_data, DEFVAL(false)); // Register signals ADD_SIGNAL(MethodInfo("connected_to_lobby", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer"), PropertyInfo(Variant::STRING, "reconnection_token"))); @@ -432,6 +441,53 @@ Ref LobbyClient::lobby_data(const Dictionary &p_lobb return response; } +Ref LobbyClient::del_lobby_data(const String &p_key, bool p_is_private) { + String id = _increment_counter(); + Dictionary command; + command["command"] = "lobby_data"; + Dictionary data_dict; + Dictionary data_object_dict; + data_dict["lobby_data"] = data_object_dict; + // set null value + data_object_dict[p_key] = Variant(); + data_dict["is_private"] = p_is_private; + data_dict["id"] = id; + command["data"] = data_dict; + Array command_array; + Ref response; + response.instantiate(); + command_array.push_back(LOBBY_REQUEST); + command_array.push_back(response); + _commands[id] = command_array; + _send_data(command); + return response; +} + +Ref LobbyClient::clear_lobby_data(bool p_is_private) { + String id = _increment_counter(); + Dictionary command; + command["command"] = "lobby_data"; + Dictionary data_dict; + Dictionary data_object_dict; + data_dict["lobby_data"] = data_object_dict; + Array keys = data_object_dict.keys(); + // set null values + for (int i = 0; i < keys.size(); i++) { + data_object_dict[keys[i]] = Variant(); + } + data_dict["is_private"] = p_is_private; + data_dict["id"] = id; + command["data"] = data_dict; + Array command_array; + Ref response; + response.instantiate(); + command_array.push_back(LOBBY_REQUEST); + command_array.push_back(response); + _commands[id] = command_array; + _send_data(command); + return response; +} + Ref LobbyClient::set_peer_data(const Dictionary &p_peer_data, const String &p_target_peer, bool p_is_private) { String id = _increment_counter(); Dictionary command; @@ -452,6 +508,55 @@ Ref LobbyClient::set_peer_data(const Dictionary &p_p return response; } +Ref LobbyClient::del_peer_data(const String &p_key, const String &p_target_peer, bool p_is_private) { + String id = _increment_counter(); + Dictionary command; + command["command"] = "data_to"; + Dictionary data_dict; + Dictionary data_object_dict; + data_dict["peer_data"] = data_object_dict; + // set null value + data_object_dict[p_key] = Variant(); + data_dict["target_peer"] = p_target_peer; + data_dict["is_private"] = p_is_private; + data_dict["id"] = id; + command["data"] = data_dict; + Array command_array; + Ref response; + response.instantiate(); + command_array.push_back(LOBBY_REQUEST); + command_array.push_back(response); + _commands[id] = command_array; + _send_data(command); + return response; +} + +Ref LobbyClient::clear_peer_data(const String &p_target_peer, bool p_is_private) { + String id = _increment_counter(); + Dictionary command; + command["command"] = "data_to"; + Dictionary data_dict; + Dictionary data_object_dict; + data_dict["peer_data"] = data_object_dict; + // set null values + Array keys = data_object_dict.keys(); + for (int i = 0; i < keys.size(); i++) { + data_object_dict[keys[i]] = Variant(); + } + data_dict["target_peer"] = p_target_peer; + data_dict["is_private"] = p_is_private; + data_dict["id"] = id; + command["data"] = data_dict; + Array command_array; + Ref response; + response.instantiate(); + command_array.push_back(LOBBY_REQUEST); + command_array.push_back(response); + _commands[id] = command_array; + _send_data(command); + return response; +} + Ref LobbyClient::set_peers_data(const Dictionary &p_peer_data, bool p_is_private) { String id = _increment_counter(); Dictionary command; @@ -471,6 +576,53 @@ Ref LobbyClient::set_peers_data(const Dictionary &p_ return response; } +Ref LobbyClient::del_peers_data(const String &p_key, bool p_is_private) { + String id = _increment_counter(); + Dictionary command; + command["command"] = "data_to_all"; + Dictionary data_dict; + Dictionary data_object_dict; + data_dict["peer_data"] = data_object_dict; + // set null value + data_object_dict[p_key] = Variant(); + data_dict["is_private"] = p_is_private; + data_dict["id"] = id; + command["data"] = data_dict; + Array command_array; + Ref response; + response.instantiate(); + command_array.push_back(LOBBY_REQUEST); + command_array.push_back(response); + _commands[id] = command_array; + _send_data(command); + return response; +} + +Ref LobbyClient::clear_peers_data(bool p_is_private) { + String id = _increment_counter(); + Dictionary command; + command["command"] = "data_to_all"; + Dictionary data_dict; + Dictionary data_object_dict; + data_dict["peer_data"] = data_object_dict; + // set null values + Array keys = data_object_dict.keys(); + for (int i = 0; i < keys.size(); i++) { + data_object_dict[keys[i]] = Variant(); + } + data_dict["is_private"] = p_is_private; + data_dict["id"] = id; + command["data"] = data_dict; + Array command_array; + Ref response; + response.instantiate(); + command_array.push_back(LOBBY_REQUEST); + command_array.push_back(response); + _commands[id] = command_array; + _send_data(command); + return response; +} + void LobbyClient::_notification(int p_what) { switch (p_what) { case NOTIFICATION_INTERNAL_PROCESS: { @@ -510,13 +662,17 @@ void LobbyClient::_send_data(const Dictionary &p_data_dict) { } } -void update_peers(Dictionary p_data_dict, TypedArray &peers) { +void LobbyClient::_update_peers(Dictionary p_data_dict, TypedArray &peers) { Array peers_array = p_data_dict.get("peers", Array()); TypedArray peers_info; peers.clear(); for (int i = 0; i < peers_array.size(); ++i) { Ref peer = Ref(memnew(LobbyPeer)); - peer->set_dict(peers_array[i]); + Dictionary peer_dict = peers_array[i]; + peer->set_dict(peer_dict); + if (peer_dict.has("private_data")) { + peer_data = peer_dict.get("private_data", Dictionary()); + } peers.push_back(peer); } } @@ -536,6 +692,14 @@ void sort_peers_by_id(TypedArray &peers) { } } +void LobbyClient::_clear_lobby() { + lobby->set_dict(Dictionary()); + peers.clear(); + host_data = Dictionary(); + peer_data = Dictionary(); + peer->set_data(Dictionary()); +} + void LobbyClient::_receive_data(const Dictionary &p_dict) { String command = p_dict.get("command", "error"); String message = p_dict.get("message", ""); @@ -543,59 +707,42 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) { String message_id = data_dict.get("id", ""); Array command_array = _commands.get(message_id, Array()); _commands.erase(message_id); - if (command_array.size() == 2 && command != "error") { - int command_type = command_array[0]; - switch (command_type) { - case LOBBY_REQUEST: { - // nothing to update, will notify at the end - } break; - case LOBBY_VIEW: { - Dictionary lobby_dict = data_dict.get("lobby", Dictionary()); - - // Iterate through peers and populate arrays - TypedArray peers_info; - update_peers(data_dict, peers_info); - sort_peers_by_id(peers_info); - Ref lobby_info = Ref(memnew(LobbyInfo)); - lobby_info->set_dict(lobby_dict); - if (lobby_info->get_id() == lobby->get_id()) { - // Update lobby info because we viewed our own lobby - lobby->set_dict(lobby_info->get_dict()); - if (lobby_dict.has("private_data")) { - host_data = lobby_dict.get("private_data", Dictionary()); - } - peers = peers_info; + // update lobby and peers + { + TypedArray peers_info; + if (data_dict.has("peers")) { + // Iterate through peers and populate arrays + _update_peers(data_dict, peers_info); + sort_peers_by_id(peers_info); + } + if (data_dict.has("lobby")) { + Dictionary lobby_dict = data_dict.get("lobby", Dictionary()); + Ref lobby_info = Ref(memnew(LobbyInfo)); + lobby_info->set_dict(lobby_dict); + if (lobby_info->get_id() == lobby->get_id() || command == "lobby_created" || command == "joined_lobby") { + // Update lobby info because we viewed our own lobby + lobby->set_dict(lobby_info->get_dict()); + if (lobby_dict.has("private_data")) { + host_data = lobby_dict.get("private_data", Dictionary()); } - } break; + peers = peers_info; + } } } if (command == "peer_state") { Dictionary peer_dict = data_dict.get("peer", Dictionary()); peer->set_dict(peer_dict); reconnection_token = peer_dict.get("reconnection_token", ""); - peer_data = peer_dict.get("private_data", Dictionary()); emit_signal("connected_to_lobby", peer, reconnection_token); } else if (command == "lobby_created") { - lobby->set_dict(data_dict.get("lobby", Dictionary())); - update_peers(data_dict, peers); - sort_peers_by_id(peers); emit_signal("lobby_created", lobby, peers); } else if (command == "joined_lobby") { - lobby->set_dict(data_dict.get("lobby", Dictionary())); - update_peers(data_dict, peers); - sort_peers_by_id(peers); emit_signal("lobby_joined", lobby, peers); } else if (command == "lobby_left") { - lobby->set_dict(Dictionary()); - peers.clear(); - host_data = Dictionary(); - peer_data = Dictionary(); + _clear_lobby(); emit_signal("lobby_left", false); } else if (command == "lobby_kicked") { - lobby->set_dict(Dictionary()); - peers.clear(); - host_data = Dictionary(); - peer_data = Dictionary(); + _clear_lobby(); emit_signal("lobby_left", true); } else if (command == "lobby_sealed") { Dictionary lobby_dict = data_dict.get("lobby", Dictionary()); @@ -849,7 +996,7 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) { // Iterate through peers and populate arrays TypedArray peers_info; - update_peers(data_dict, peers_info); + _update_peers(data_dict, peers_info); sort_peers_by_id(peers_info); Ref lobby_info = Ref(memnew(LobbyInfo)); lobby_info->set_dict(lobby_dict); diff --git a/modules/blazium_sdk/lobby/lobby_client.h b/modules/blazium_sdk/lobby/lobby_client.h index c3eae420b0d5..8a7cb89b141d 100644 --- a/modules/blazium_sdk/lobby/lobby_client.h +++ b/modules/blazium_sdk/lobby/lobby_client.h @@ -261,7 +261,7 @@ class LobbyClient : public BlaziumClient { class ViewLobbyResult : public RefCounted { GDCLASS(ViewLobbyResult, RefCounted); String error; - TypedArray peers; + TypedArray peers_info; Ref lobby_info; protected: @@ -279,12 +279,12 @@ class LobbyClient : public BlaziumClient { public: void set_error(const String &p_error) { this->error = p_error; } - void set_peers(const TypedArray &p_peers) { this->peers = p_peers; } + void set_peers(const TypedArray &p_peers) { this->peers_info = p_peers; } void set_lobby(const Ref &p_lobby_info) { this->lobby_info = p_lobby_info; } bool has_error() const { return !error.is_empty(); } String get_error() const { return error; } - TypedArray get_peers() const { return peers; } + TypedArray get_peers() const { return peers_info; } Ref get_lobby() const { return lobby_info; } ViewLobbyResult() { lobby_info.instantiate(); @@ -300,8 +300,10 @@ class LobbyClient : public BlaziumClient { bool connected = false; Dictionary _commands; + void _clear_lobby(); void _receive_data(const Dictionary &p_data); void _send_data(const Dictionary &p_data); + void _update_peers(Dictionary p_data_dict, TypedArray &peers); String _increment_counter(); enum CommandType { @@ -347,9 +349,18 @@ class LobbyClient : public BlaziumClient { Ref lobby_call(const String &p_method, const Array &p_args); Ref lobby_notify(const Variant &p_peer_data); Ref peer_notify(const Variant &p_peer_data, const String &p_target_peer); + Ref lobby_data(const Dictionary &p_lobby_data, bool p_is_private); + Ref del_lobby_data(const String &p_key, bool p_is_private); + Ref clear_lobby_data(bool p_is_private); + Ref set_peer_data(const Dictionary &p_peer_data, const String &p_target_peer, bool p_is_private); + Ref del_peer_data(const String &p_key, const String &p_target_peer, bool p_is_private); + Ref clear_peer_data(const String &p_target_peer, bool p_is_private); + Ref set_peers_data(const Dictionary &p_peer_data, bool p_is_private); + Ref del_peers_data(const String &p_key, bool p_is_private); + Ref clear_peers_data(bool p_is_private); LobbyClient(); ~LobbyClient();