diff --git a/modules/blazium_sdk/doc_classes/LobbyClient.xml b/modules/blazium_sdk/doc_classes/LobbyClient.xml
index 8da1ef985166..27d0a2848c2d 100644
--- a/modules/blazium_sdk/doc_classes/LobbyClient.xml
+++ b/modules/blazium_sdk/doc_classes/LobbyClient.xml
@@ -26,6 +26,12 @@
Generates [signal lobby_created] signal.
+
+
+
+ Returns true if you are the host.
+
+
@@ -60,7 +66,7 @@
-
+
Send data either to the host, or if you are host send data to all peers.
Generates [signal received_data] signal.
@@ -68,7 +74,7 @@
-
+
Send data either to a peer, works only if you are host.
@@ -77,20 +83,15 @@
+
Ready up in the lobby. You need to be in a lobby and unready to run this.
Generates [signal peer_ready].
-
-
-
- Ready up in the lobby. You need to be in a lobby and ready to run this.
- Generates [signal peer_unready].
-
-
+
Seals the lobby. You need to be the host to do this and the lobby needs to be unsealed.
Generates [signal lobby_sealed].
@@ -104,13 +105,6 @@
Generates [signal peer_named] signal if you are in lobby.
-
-
-
- Unseals the lobby. You need to be the host to do this and the lobby needs to be sealed.
- Generates [signal lobby_unsealed].
-
-
@@ -125,13 +119,13 @@
True if the client is connected, else false.
- The current lobby.
+ The current lobby. Reflects changes to the lobby.
- The current peer.
+ The current peer. Reflects changes to the self peer.
- The lobby peers.
+ The lobby peers. Reflects changes to all peers.
Set to what url this lobby should connect to.
@@ -171,15 +165,11 @@
+
Signal generated after the host seals the lobby.
-
-
- Signal generated after the host unseals the lobby.
-
-
@@ -201,24 +191,21 @@
+
Signal generated after a peer is ready.
-
-
-
- Signal generated after a peer is unready.
-
-
-
+
+
Signal generated after a lobby_data call.
-
+
+
Signal generated after a data_to call.
diff --git a/modules/blazium_sdk/lobby/lobby_client.cpp b/modules/blazium_sdk/lobby/lobby_client.cpp
index 50b927915adc..358f7594de96 100644
--- a/modules/blazium_sdk/lobby/lobby_client.cpp
+++ b/modules/blazium_sdk/lobby/lobby_client.cpp
@@ -45,6 +45,7 @@ LobbyClient::~LobbyClient() {
void LobbyClient::_bind_methods() {
ClassDB::bind_method(D_METHOD("set_server_url", "server_url"), &LobbyClient::set_server_url);
ClassDB::bind_method(D_METHOD("get_server_url"), &LobbyClient::get_server_url);
+ ClassDB::bind_method(D_METHOD("is_host"), &LobbyClient::is_host);
ClassDB::bind_method(D_METHOD("get_connected"), &LobbyClient::get_connected);
ClassDB::bind_method(D_METHOD("get_lobby"), &LobbyClient::get_lobby);
ClassDB::bind_method(D_METHOD("get_peer"), &LobbyClient::get_peer);
@@ -67,27 +68,23 @@ void LobbyClient::_bind_methods() {
ClassDB::bind_method(D_METHOD("list_lobby", "start", "count"), &LobbyClient::list_lobby, DEFVAL(0), DEFVAL(10));
ClassDB::bind_method(D_METHOD("view_lobby", "lobby_id", "password"), &LobbyClient::view_lobby, DEFVAL(""), DEFVAL(""));
ClassDB::bind_method(D_METHOD("kick_peer", "peer_id"), &LobbyClient::kick_peer);
- ClassDB::bind_method(D_METHOD("lobby_ready"), &LobbyClient::lobby_ready);
- ClassDB::bind_method(D_METHOD("lobby_unready"), &LobbyClient::lobby_unready);
- ClassDB::bind_method(D_METHOD("seal_lobby"), &LobbyClient::seal_lobby);
- ClassDB::bind_method(D_METHOD("unseal_lobby"), &LobbyClient::unseal_lobby);
+ ClassDB::bind_method(D_METHOD("lobby_ready", "ready"), &LobbyClient::lobby_ready);
+ ClassDB::bind_method(D_METHOD("seal_lobby", "seal"), &LobbyClient::seal_lobby);
ClassDB::bind_method(D_METHOD("lobby_data", "data"), &LobbyClient::lobby_data);
ClassDB::bind_method(D_METHOD("lobby_data_to", "data", "target_peer"), &LobbyClient::lobby_data_to);
// Register signals
ADD_SIGNAL(MethodInfo("disconnected_from_lobby"));
ADD_SIGNAL(MethodInfo("peer_named", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer")));
- ADD_SIGNAL(MethodInfo("received_data", PropertyInfo(Variant::STRING, "data")));
- ADD_SIGNAL(MethodInfo("received_data_to", PropertyInfo(Variant::STRING, "data")));
+ ADD_SIGNAL(MethodInfo("received_data", PropertyInfo(Variant::OBJECT, "data"), PropertyInfo(Variant::STRING, "from_peer")));
+ ADD_SIGNAL(MethodInfo("received_data_to", PropertyInfo(Variant::OBJECT, "data"), PropertyInfo(Variant::STRING, "from_peer")));
ADD_SIGNAL(MethodInfo("lobby_created", PropertyInfo(Variant::OBJECT, "lobby", PROPERTY_HINT_RESOURCE_TYPE, "LobbyInfo"), PropertyInfo(Variant::ARRAY, "peers", PROPERTY_HINT_ARRAY_TYPE, "LobbyPeer")));
ADD_SIGNAL(MethodInfo("lobby_joined", PropertyInfo(Variant::OBJECT, "lobby", PROPERTY_HINT_RESOURCE_TYPE, "LobbyInfo"), PropertyInfo(Variant::ARRAY, "peers", PROPERTY_HINT_ARRAY_TYPE, "LobbyPeer")));
ADD_SIGNAL(MethodInfo("lobby_left"));
- ADD_SIGNAL(MethodInfo("lobby_sealed"));
- ADD_SIGNAL(MethodInfo("lobby_unsealed"));
+ ADD_SIGNAL(MethodInfo("lobby_sealed", PropertyInfo(Variant::BOOL, "sealed")));
ADD_SIGNAL(MethodInfo("peer_joined", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer")));
ADD_SIGNAL(MethodInfo("peer_left", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer"), PropertyInfo(Variant::BOOL, "kicked")));
- ADD_SIGNAL(MethodInfo("peer_ready", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer")));
- ADD_SIGNAL(MethodInfo("peer_unready", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer")));
+ ADD_SIGNAL(MethodInfo("peer_ready", PropertyInfo(Variant::OBJECT, "peer", PROPERTY_HINT_RESOURCE_TYPE, "LobbyPeer"), PropertyInfo(Variant::BOOL, "ready")));
ADD_SIGNAL(MethodInfo("append_log", PropertyInfo(Variant::STRING, "command"), PropertyInfo(Variant::STRING, "info"), PropertyInfo(Variant::STRING, "logs")));
}
@@ -230,27 +227,14 @@ Ref LobbyClient::kick_peer(const String &p_peer_id)
return response;
}
-Ref LobbyClient::lobby_ready() {
+Ref LobbyClient::lobby_ready(bool p_ready) {
String id = _increment_counter();
Dictionary command;
- command["command"] = "lobby_ready";
- Dictionary data_dict;
- command["data"] = data_dict;
- data_dict["id"] = id;
- 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::lobby_unready() {
- String id = _increment_counter();
- Dictionary command;
- command["command"] = "lobby_unready";
+ if (p_ready) {
+ command["command"] = "lobby_ready";
+ } else {
+ command["command"] = "lobby_unready";
+ }
Dictionary data_dict;
command["data"] = data_dict;
data_dict["id"] = id;
@@ -282,27 +266,14 @@ Ref LobbyClient::set_peer_name(const String &p_peer_
return response;
}
-Ref LobbyClient::seal_lobby() {
+Ref LobbyClient::seal_lobby(bool seal) {
String id = _increment_counter();
Dictionary command;
- command["command"] = "seal_lobby";
- Dictionary data_dict;
- command["data"] = data_dict;
- data_dict["id"] = id;
- 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::unseal_lobby() {
- String id = _increment_counter();
- Dictionary command;
- command["command"] = "unseal_lobby";
+ if (seal) {
+ command["command"] = "seal_lobby";
+ } else {
+ command["command"] = "unseal_lobby";
+ }
Dictionary data_dict;
command["data"] = data_dict;
data_dict["id"] = id;
@@ -316,7 +287,7 @@ Ref LobbyClient::unseal_lobby() {
return response;
}
-Ref LobbyClient::lobby_data(const String &p_peer_data) {
+Ref LobbyClient::lobby_data(const Variant &p_peer_data) {
String id = _increment_counter();
Dictionary command;
command["command"] = "lobby_data";
@@ -334,7 +305,7 @@ Ref LobbyClient::lobby_data(const String &p_peer_dat
return response;
}
-Ref LobbyClient::lobby_data_to(const String &p_peer_data, const String &p_target_peer) {
+Ref LobbyClient::lobby_data_to(const Variant &p_peer_data, const String &p_target_peer) {
String id = _increment_counter();
Dictionary command;
command["command"] = "data_to";
@@ -460,7 +431,8 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) {
}
}
if (command == "peer_state") {
- peer->set_id(data_dict.get("peer_id", ""));
+ Dictionary peer_dict = data_dict.get("peer", Dictionary());
+ peer->set_id(peer_dict.get("id", ""));
} else if (command == "lobby_created") {
lobby->set_dict(data_dict.get("lobby", Dictionary()));
update_peers(data_dict, peers);
@@ -478,10 +450,10 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) {
} else if (command == "lobby_sealed") {
Dictionary lobby_dict = data_dict.get("lobby", Dictionary());
lobby->set_sealed(true);
- emit_signal("lobby_sealed");
+ emit_signal("lobby_sealed", true);
} else if (command == "lobby_unsealed") {
lobby->set_sealed(false);
- emit_signal("lobby_unsealed");
+ emit_signal("lobby_sealed", false);
} else if (command == "lobby_list") {
Array arr = data_dict.get("lobbies", Array());
TypedArray lobbies_input = arr;
@@ -532,7 +504,7 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) {
Ref updated_peer = peers[i];
if (updated_peer->get_id() == String(peer_id)) {
updated_peer->set_ready(true);
- emit_signal("peer_ready", updated_peer);
+ emit_signal("peer_ready", updated_peer, true);
break;
}
}
@@ -545,7 +517,7 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) {
Ref updated_peer = peers[i];
if (updated_peer->get_id() == String(data_dict.get("peer_id", ""))) {
updated_peer->set_ready(false);
- emit_signal("peer_unready", updated_peer);
+ emit_signal("peer_ready", updated_peer, false);
break;
}
}
@@ -570,9 +542,9 @@ void LobbyClient::_receive_data(const Dictionary &p_dict) {
}
sort_peers_by_id(peers);
} else if (command == "lobby_data") {
- emit_signal("received_data", data_dict.get("peer_data", ""));
+ emit_signal("received_data", data_dict.get("peer_data", Variant()), data_dict.get("from_peer", ""));
} else if (command == "data_to") {
- emit_signal("received_data_to", data_dict.get("peer_data", ""));
+ emit_signal("received_data_to", data_dict.get("peer_data", Variant()), data_dict.get("from_peer", ""));
} else if (command == "lobby_data_sent") {
// nothing for now
} else if (command == "data_to_sent") {
diff --git a/modules/blazium_sdk/lobby/lobby_client.h b/modules/blazium_sdk/lobby/lobby_client.h
index 575d4f49d98f..0334e465785e 100644
--- a/modules/blazium_sdk/lobby/lobby_client.h
+++ b/modules/blazium_sdk/lobby/lobby_client.h
@@ -294,6 +294,7 @@ class LobbyClient : public BlaziumClient {
public:
void set_server_url(const String &p_server_url) { this->server_url = p_server_url; }
String get_server_url() { return server_url; }
+ bool is_host() { return lobby->get_host() == peer->get_id(); }
bool get_connected() { return connected; }
void set_lobby(const Ref &p_lobby) { this->lobby = p_lobby; }
Ref get_lobby() { return lobby; }
@@ -308,13 +309,11 @@ class LobbyClient : public BlaziumClient {
Ref list_lobby(int p_start, int p_count);
Ref view_lobby(const String &p_lobby_id, const String &p_password);
Ref kick_peer(const String &p_peer_id);
- Ref lobby_ready();
- Ref lobby_unready();
+ Ref lobby_ready(bool p_ready);
Ref set_peer_name(const String &p_peer_name);
- Ref seal_lobby();
- Ref unseal_lobby();
- Ref lobby_data(const String &p_peer_data);
- Ref lobby_data_to(const String &p_peer_data, const String &p_target_peer);
+ Ref seal_lobby(bool seal);
+ Ref lobby_data(const Variant &p_peer_data);
+ Ref lobby_data_to(const Variant &p_peer_data, const String &p_target_peer);
LobbyClient();
~LobbyClient();