public void Deserialize(byte[] data, Pointer p) { LastLogin = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); UserSince = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); LastPasswordChange = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); ID = new Guid(BitPacker.GetString(data, p)); Email = BitPacker.GetString(data, p); Username = BitPacker.GetString(data, p); IsLocked = BitPacker.GetBool(data, p); IsOnline = BitPacker.GetBool(data, p); IsApproved = BitPacker.GetBool(data, p); Roles = BitPacker.GetStringList(data, p); int notes = BitPacker.GetInt(data, p); for (int i = 0; i < notes; i++) { ServiceLogEntry sle = new ServiceLogEntry(); sle.Account = ID; sle.EntryBy = BitPacker.GetString(data, p); sle.Note = BitPacker.GetString(data, p); sle.EntryType = BitPacker.GetString(data, p); sle.CharacterId = BitPacker.GetInt(data, p); sle.TimeStampUTC = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); ServiceNotes.Add(sle); } AddedProperties = BitPacker.GetPropertyBag(data, p); int numSessions = BitPacker.GetInt(data, p); for (int i = 0; i < numSessions; i++) { DateTime login = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); DateTime logout = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); string ip = BitPacker.GetString(data, p); ip = ip.Substring(0, ip.LastIndexOf("]") + 1); AccountProfile.Session s = new AccountProfile.Session(login, logout, ip); LoginSessions.Add(s); } //LoginSessions = LoginSessions.OrderBy(session => session.LogoutUTC).ToList(); LoginSessions.Reverse(); CurrentLoginTime = new DateTime(BitPacker.GetLong(data, p), DateTimeKind.Utc); int characters = BitPacker.GetInt(data, p); for (int i = 0; i < characters; i++) { ICharacterInfo ci = BitPacker.GetComponent(data, p) as ICharacterInfo; Characters.Add(ci); } }
private void OnUserDetailRequest(INetworkConnection con, Packet r) { Log1.Logger("Zeus.Inbound.Client").Debug("User detail request from " + ServerUser.AccountName + "."); PacketGenericMessage msg = r as PacketGenericMessage; Guid user = msg.Parms.GetGuidProperty(2); WispUserDetail ud = new WispUserDetail(); r.ReplyPacket = CreateStandardReply(r, ReplyType.OK, ""); r.ReplyPacket.Parms.SetProperty(1, MyServer.ServerUserID); r.ReplyPacket.Parms.SetProperty(2, ud); MembershipUser usr = Membership.GetUser(user, false); if (usr == null) { r.ReplyPacket.ReplyCode = ReplyType.Failure; r.ReplyPacket.ReplyMessage = "User not found."; } else { ud.Email = usr.Email; ud.ID = user; ud.IsApproved = usr.IsApproved; ud.IsLocked = usr.IsLockedOut; ud.LastLogin = usr.LastLoginDate.ToUniversalTime(); ud.LastPasswordChange = usr.LastPasswordChangedDate.ToUniversalTime(); ud.Roles.AddRange(Roles.GetRolesForUser(usr.UserName)); ud.Username = usr.UserName; ud.UserSince = usr.CreationDate; ServerUser su = ConnectionManager.GetAuthorizedUser(usr.UserName, MyServer, PacketLoginRequest.ConnectionType.AssistedTransfer); ud.IsOnline = su != null; if (su != null) { ud.CurrentLoginTime = su.Profile.CurrentLoginTime; } AccountProfile prof = null; prof = new AccountProfile(usr.UserName); prof.Load(MyServer.RequireAuthentication); ud.AddedProperties = prof.AddedProperties; ud.LoginSessions = new List<AccountProfile.Session>(prof.AllSessions); if (!DB.Instance.User_GetServiceLogEntries(user, "", ud.ServiceNotes)) { ServiceLogEntry sle = new ServiceLogEntry(); sle.EntryBy = "System"; sle.Note = "Unable to retrieve service log entries from database."; ud.ServiceNotes.Add(sle); } ud.Characters = CharacterUtil.Instance.GetCharacterListing(user); } }