using System; using System.Collections.Generic; using Utilities; namespace LobbyRooms.Auth { /// /// Each context will have its own identity needs, so we'll allow each to define whatever parameters it needs. /// Anything that accesses the contents should know what it's looking for. /// public class SubIdentity : Observed { protected Dictionary m_contents = new Dictionary(); public string GetContent(string key) { if (!m_contents.ContainsKey(key)) m_contents.Add(key, null); // Not alerting observers via OnChanged until the value is actually present (especially since this could be called by an observer, which would be cyclical). return m_contents[key]; } public void SetContent(string key, string value) { if (!m_contents.ContainsKey(key)) m_contents.Add(key, value); else m_contents[key] = value; OnChanged(this); } public override void CopyObserved(SubIdentity oldObserved) { m_contents = oldObserved.m_contents; } } public enum IIdentityType { Local = 0, Auth } public interface IIdentity : IProvidable { SubIdentity GetSubIdentity(IIdentityType identityType); } public class IdentityNoop : IIdentity { public SubIdentity GetSubIdentity(IIdentityType identityType) { return null; } public void OnReProvided(IIdentity other) { } } /// /// Our internal representation of a player, wrapping the data required for interfacing with the identities of that player in the services. /// One will be created for the local player, as well as for each other member of the room. /// (TODO: If that's the case, reevaluate the usage as a Located service.) /// public class Identity : IIdentity, IDisposable { private Dictionary m_subIdentities = new Dictionary(); public Identity() { m_subIdentities.Add(IIdentityType.Local, new SubIdentity()); m_subIdentities.Add(IIdentityType.Auth, new SubIdentity_Authentication()); } public Identity(Action callbackOnAuthLogin) { m_subIdentities.Add(IIdentityType.Local, new SubIdentity()); m_subIdentities.Add(IIdentityType.Auth, new SubIdentity_Authentication(callbackOnAuthLogin)); } public SubIdentity GetSubIdentity(IIdentityType identityType) { return m_subIdentities[identityType]; } public void OnReProvided(IIdentity prev) { if (prev is Identity) { Identity prevIdentity = prev as Identity; foreach (var entry in prevIdentity.m_subIdentities) m_subIdentities.Add(entry.Key, entry.Value); } } public void Dispose() { foreach (var sub in m_subIdentities) if (sub.Value is IDisposable) (sub.Value as IDisposable).Dispose(); } } }