Skip to main content

class RoomManagementService

(Niantic.Lightship.SharedAR.Rooms.RoomManagementService)

Overview

The RoomManagementService provides interface to access Room Management Service backend to create, remove, find Rooms. A room is an entity to connect multiple peers through server relayed network.

class RoomManagementService {
public:

struct GetOrCreateRoomAsyncTaskResult;

// methods

static RoomManagementServiceStatus CreateRoom(
RoomParams roomParams,
out IRoom outRoom
);

static void TryReinitializeRoomManagementService();
static RoomManagementServiceStatus DeleteRoom(string roomId);
static RoomManagementServiceStatus GetRoom(string roomId, out IRoom outRoom);

static RoomManagementServiceStatus QueryRoomsByName(
string name,
out List<IRoom> rooms
);

static RoomManagementServiceStatus GetAllRooms(out List<IRoom> rooms);

static RoomManagementServiceStatus GetOrCreateRoomForName(
RoomParams roomParams,
out IRoom outRoom
);

static void GetOrCreateRoomAsync(
string roomName,
string roomDesc,
uint roomCapacity,
GetOrCreateRoomCallback doneCb
);

static async Task<GetOrCreateRoomAsyncTaskResult> GetOrCreateRoomAsync(
string roomName,
string roomDescription,
uint roomCapacity
);

delegate void GetOrCreateRoomCallback(
RoomManagementServiceStatus status,
string room_id
);
};

Detailed Documentation

The RoomManagementService provides interface to access Room Management Service backend to create, remove, find Rooms. A room is an entity to connect multiple peers through server relayed network.

Methods

CreateRoom

static RoomManagementServiceStatus CreateRoom(
RoomParams roomParams,
out IRoom outRoom
)

Create a new room on the server.

    Parameters:

    roomParams - Parameters of the room

    outRoom - Created room as IRoom object. null if failed to create.

    Returns:

    Status of the operation

DeleteRoom

static RoomManagementServiceStatus DeleteRoom(string roomId)

Delete a room on the server.

    Parameters:

    roomId - Room ID of the room to delete

    Returns:

    Status of the operation

GetRoom

static RoomManagementServiceStatus GetRoom(string roomId, out IRoom outRoom)

Get a room by Room ID on the server

    Parameters:

    roomId - Room ID as a string

    outRoom - Found Room object. Null if operation failed or room ID not found<//param>

    Returns:

    Status of the operation

QueryRoomsByName

static RoomManagementServiceStatus QueryRoomsByName(
string name,
out List<IRoom> rooms
)

Query room(s) by name on the server

    Parameters:

    name - Name of the room to find

    rooms - A List of rooms which has matching name

    Returns:

    Status of the operation

GetAllRooms

static RoomManagementServiceStatus GetAllRooms(out List<IRoom> rooms)

Get all rooms on the server, which was created by this app

    Parameters:

    rooms - List of rooms available for this app

    Returns:

    Status of the operation

GetOrCreateRoomForName

static RoomManagementServiceStatus GetOrCreateRoomForName(
RoomParams roomParams,
out IRoom outRoom
)

Get a IRoom object that has a given name on the server. If no room found with the name, create a new room using given room parameters

    Parameters:

    roomParams - Room parameters of the room to get or create

    outRoom - IRoom object. null if server operarion failed

    Returns:

    Status of the operation

GetOrCreateRoomAsync

static void GetOrCreateRoomAsync(
string roomName,
string roomDesc,
uint roomCapacity,
GetOrCreateRoomCallback doneCb
)

An async implementation of the GetOrCreateRoom request. This function checks to see if any rooms of the name "roomName" exist and if not, it creates the room. Once the function has a valid RoomID from either of these operations, it returns it via the "doneCb". The "doneCb" has two parameters. The first is a response code in case there are service issues, and the second parameter is the room id that was found/created.

    Parameters:

    roomName - Room name to check for

    roomDesc - Room description to use if a room needs to be made

    roomCapacity - Room capacity to use if a room needs to be made

    doneCb - Callback that the function calls after it errors or receives a valid room id.

GetOrCreateRoomAsync

static async Task<GetOrCreateRoomAsyncTaskResult> GetOrCreateRoomAsync(
string roomName,
string roomDescription,
uint roomCapacity
)

An async implementation of the GetOrCreateRoom request. This function checks to see if any rooms of the name "roomName" exist and if not, it creates the room. This variant returns a Task so it can be await -ed by C#'s async/await feature. The task is given two results, the status of the request and, if successful, the roomId for the request.

    Parameters:

    roomName - Room name to check for

    roomDescription - Room description to use if a room needs to be made

    roomCapacity - Room capacity to use if a room needs to be made

    Returns:

    Task with the request status and the roomId on successful requests