Skip to content
This repository has been archived by the owner on Sep 5, 2022. It is now read-only.

Commit

Permalink
Mirror override fix
Browse files Browse the repository at this point in the history
  • Loading branch information
cxxpxr committed May 17, 2021
1 parent a329f8f commit 0067b50
Show file tree
Hide file tree
Showing 565 changed files with 1,904 additions and 3,343 deletions.
6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Authenticators.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

26 changes: 17 additions & 9 deletions UnityProject/Assets/Mirror/Authenticators/BasicAuthenticator.cs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,9 @@ public class BasicAuthenticator : NetworkAuthenticator
public string username;
public string password;

// this is set if authentication fails to prevent garbage AuthRequestMessage spam
bool ServerAuthFailed;

#region Messages

public struct AuthRequestMessage : NetworkMessage
Expand Down Expand Up @@ -101,7 +104,13 @@ public void OnAuthRequestMessage(NetworkConnection conn, AuthRequestMessage msg)
conn.isAuthenticated = false;

// disconnect the client after 1 second so that response message gets delivered
StartCoroutine(DelayedDisconnect(conn, 1));
if (!ServerAuthFailed)
{
// set this false so this coroutine can only be started once
ServerAuthFailed = true;

StartCoroutine(DelayedDisconnect(conn, 1));
}
}
}

Expand Down Expand Up @@ -141,21 +150,23 @@ public override void OnStopClient()
/// Called on client from OnClientAuthenticateInternal when a client needs to authenticate
/// </summary>
/// <param name="conn">Connection of the client.</param>
public override void OnClientAuthenticate(NetworkConnection conn)
public override void OnClientAuthenticate()
{
AuthRequestMessage authRequestMessage = new AuthRequestMessage
{
authUsername = username,
authPassword = password
};

conn.Send(authRequestMessage);
NetworkClient.connection.Send(authRequestMessage);
}

[Obsolete("Call OnAuthResponseMessage without the NetworkConnection parameter. It always points to NetworkClient.connection anyway.")]
public void OnAuthResponseMessage(NetworkConnection conn, AuthResponseMessage msg) => OnAuthResponseMessage(msg);

/// <summary>
/// Called on client when the server's AuthResponseMessage arrives
/// </summary>
/// <param name="conn">Connection to client.</param>
/// <param name="msg">The message payload</param>
public void OnAuthResponseMessage(AuthResponseMessage msg)
{
Expand All @@ -164,20 +175,17 @@ public void OnAuthResponseMessage(AuthResponseMessage msg)
// Debug.LogFormat(LogType.Log, "Authentication Response: {0}", msg.message);

// Authentication has been accepted
ClientAccept(NetworkClient.connection);
ClientAccept();
}
else
{
Debug.LogError($"Authentication Response: {msg.message}");

// Authentication has been rejected
ClientReject(NetworkClient.connection);
ClientReject();
}
}

[Obsolete("Call OnAuthResponseMessage without the NetworkConnection parameter. It always points to NetworkClient.connection anyway.")]
public void OnAuthResponseMessage(NetworkConnection conn, AuthResponseMessage msg) => OnAuthResponseMessage(msg);

#endregion
}
}

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -48,23 +48,21 @@ public override void OnServerAuthenticate(NetworkConnection conn)
StartCoroutine(BeginAuthentication(conn));
}

public override void OnClientAuthenticate(NetworkConnection conn)
public override void OnClientAuthenticate()
{
authenticator.OnClientAuthenticate(conn);
authenticator.OnClientAuthenticate();
if (timeout > 0)
StartCoroutine(BeginAuthentication(conn));
StartCoroutine(BeginAuthentication(NetworkClient.connection));
}

IEnumerator BeginAuthentication(NetworkConnection conn)
{
// Debug.Log($"Authentication countdown started {conn} {timeout}");

yield return new WaitForSecondsRealtime(timeout);

if (!conn.isAuthenticated)
{
// Debug.Log($"Authentication Timeout {conn}");

conn.Disconnect();
}
}
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Cloud.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

62 changes: 1 addition & 61 deletions UnityProject/Assets/Mirror/Cloud/ApiConnector.cs
Original file line number Diff line number Diff line change
@@ -1,61 +1 @@
using Mirror.Cloud.ListServerService;
using UnityEngine;

namespace Mirror.Cloud
{
/// <summary>
/// Used to requests and responses from the mirror api
/// </summary>
public interface IApiConnector
{
ListServer ListServer { get; }
}

/// <summary>
/// Used to requests and responses from the mirror api
/// </summary>
[DisallowMultipleComponent]
[AddComponentMenu("Network/CloudServices/ApiConnector")]
[HelpURL("https://mirror-networking.com/docs/api/Mirror.Cloud.ApiConnector.html")]
public class ApiConnector : MonoBehaviour, IApiConnector, ICoroutineRunner
{
#region Inspector
[Header("Settings")]

[Tooltip("Base URL of api, including https")]
[SerializeField] string ApiAddress = "";

[Tooltip("Api key required to access api")]
[SerializeField] string ApiKey = "";

[Header("Events")]

[Tooltip("Triggered when server list updates")]
[SerializeField] ServerListEvent _onServerListUpdated = new ServerListEvent();
#endregion

IRequestCreator requestCreator;

public ListServer ListServer { get; private set; }

void Awake()
{
requestCreator = new RequestCreator(ApiAddress, ApiKey, this);

InitListServer();
}

void InitListServer()
{
IListServerServerApi serverApi = new ListServerServerApi(this, requestCreator);
IListServerClientApi clientApi = new ListServerClientApi(this, requestCreator, _onServerListUpdated);
ListServer = new ListServer(serverApi, clientApi);
}

public void OnDestroy()
{
ListServer?.ServerApi.Shutdown();
ListServer?.ClientApi.Shutdown();
}
}
}
// removed 2021-05-13
6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Cloud/ApiConnector.cs.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

26 changes: 1 addition & 25 deletions UnityProject/Assets/Mirror/Cloud/Core/BaseApi.cs
Original file line number Diff line number Diff line change
@@ -1,25 +1 @@
using System;

namespace Mirror.Cloud
{
public interface IBaseApi
{
/// <summary>
/// Cleans up any data created by the instance
/// <para>For Example: removing server from list</para>
/// </summary>
void Shutdown();
}

public abstract class BaseApi
{
protected readonly ICoroutineRunner runner;
protected readonly IRequestCreator requestCreator;

protected BaseApi(ICoroutineRunner runner, IRequestCreator requestCreator)
{
this.runner = runner ?? throw new ArgumentNullException(nameof(runner));
this.requestCreator = requestCreator ?? throw new ArgumentNullException(nameof(requestCreator));
}
}
}
// removed 2021-05-13
6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Cloud/Core/BaseApi.cs.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 1 addition & 12 deletions UnityProject/Assets/Mirror/Cloud/Core/Events.cs
Original file line number Diff line number Diff line change
@@ -1,12 +1 @@
using System;
using Mirror.Cloud.ListServerService;
using UnityEngine.Events;

namespace Mirror.Cloud
{
[Serializable]
public class ServerListEvent : UnityEvent<ServerCollectionJson> {}

[Serializable]
public class MatchFoundEvent : UnityEvent<ServerJson> {}
}
// removed 2021-05-13
6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Cloud/Core/Events.cs.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 1 addition & 12 deletions UnityProject/Assets/Mirror/Cloud/Core/Extensions.cs
Original file line number Diff line number Diff line change
@@ -1,12 +1 @@
using UnityEngine.Networking;

namespace Mirror.Cloud
{
public static class Extensions
{
public static bool IsOk(this UnityWebRequest webRequest)
{
return 200 <= webRequest.responseCode && webRequest.responseCode <= 299;
}
}
}
// removed 2021-05-13
6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Cloud/Core/Extensions.cs.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 1 addition & 12 deletions UnityProject/Assets/Mirror/Cloud/Core/ICoroutineRunner.cs
Original file line number Diff line number Diff line change
@@ -1,12 +1 @@
using System.Collections;
using UnityEngine;

namespace Mirror.Cloud
{
public interface ICoroutineRunner : IUnityEqualCheck
{
Coroutine StartCoroutine(IEnumerator routine);
void StopCoroutine(IEnumerator routine);
void StopCoroutine(Coroutine routine);
}
}
// removed 2021-05-13

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

43 changes: 1 addition & 42 deletions UnityProject/Assets/Mirror/Cloud/Core/IRequestCreator.cs
Original file line number Diff line number Diff line change
@@ -1,42 +1 @@
using System.Collections;
using UnityEngine.Networking;

namespace Mirror.Cloud
{
public delegate void RequestSuccess(string responseBody);

public delegate void RequestFail(string responseBody);

/// <summary>
/// Objects that can be sent to the Api must have this interface
/// </summary>
public interface ICanBeJson {}

/// <summary>
/// Methods to create and send UnityWebRequest
/// </summary>
public interface IRequestCreator
{
UnityWebRequest Delete(string page);
UnityWebRequest Get(string page);
UnityWebRequest Patch<T>(string page, T json) where T : struct, ICanBeJson;
UnityWebRequest Post<T>(string page, T json) where T : struct, ICanBeJson;

/// <summary>
/// Sends Request to api and invokes callback when finished
/// <para>Starts Coroutine of SendRequestEnumerator</para>
/// </summary>
/// <param name="request"></param>
/// <param name="onSuccess"></param>
/// <param name="onFail"></param>
void SendRequest(UnityWebRequest request, RequestSuccess onSuccess = null, RequestFail onFail = null);
/// <summary>
/// Sends Request to api and invokes callback when finished
/// </summary>
/// <param name="request"></param>
/// <param name="onSuccess"></param>
/// <param name="onFail"></param>
/// <returns></returns>
IEnumerator SendRequestEnumerator(UnityWebRequest request, RequestSuccess onSuccess = null, RequestFail onFail = null);
}
}
// removed 2021-05-13
6 changes: 3 additions & 3 deletions UnityProject/Assets/Mirror/Cloud/Core/IRequestCreator.cs.meta

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit 0067b50

Please sign in to comment.