private void OnCS_Profile_GetData_Req(SecurePacketRequest reqPacket) { SecurePacketResponse resPacket = new SecurePacketResponse(reqPacket, ResultCode.Ok); resPacket.PutStringAsUtf16(_user.Profile.Nickname ?? ""); resPacket.PutInt16(_user.Profile.Level); resPacket.PutInt16(_user.Profile.Exp); resPacket.PutDouble(_user.LoginCounter.RegDate.ToOADate()); resPacket.PutDouble(_user.LoginCounter.LastLoginDate.ToOADate()); resPacket.PutByte(_user.LoginCounter.ContinuousCount); resPacket.PutByte(_user.LoginCounter.DailyCount); SendPacket(resPacket); }
private void OnCS_CloudSheet_GetRecords_Req(SecurePacketRequest reqPacket) { String filename = reqPacket.GetStringFromUtf16(); String sheetName = reqPacket.GetStringFromUtf16(); UInt32 startRowNo = reqPacket.GetUInt32(); SecurePacketResponse resPacket = new SecurePacketResponse(reqPacket, 65535); try { resPacket.ResultCodeNo = ResultCode.Ok; Workbook workbook = Workbooks.GetWorkbook(filename); SheetData sheet = workbook.GetSheetData(sheetName); Int32 hasMoreIdx = resPacket.PutByte(0); Int32 rowCountIdx = resPacket.PutInt32(0); Int32 rowCount = 0; UInt32 lastRowIndex = 0; foreach (Record data in sheet.Records) { if (data == null || data.RowNo < startRowNo) continue; ++rowCount; lastRowIndex = data.RowNo; resPacket.PutUInt32(data.RowNo); foreach (String value in data.DataList) { if (value == null) resPacket.PutStringAsUtf16(""); else resPacket.PutStringAsUtf16(value.ToString()); } // #! 대략 이쯤... 패킷 크기를 초과하지 않도록 적당이 끊어준다. if (resPacket.WrittenBytes > 50000) break; } resPacket.OverwriteByte(hasMoreIdx, (Byte)(lastRowIndex < sheet.MaxRowNo ? 1 : 0)); resPacket.OverwriteInt32(rowCountIdx, rowCount); } catch (AegisException e) { Logger.Write(LogType.Err, 2, e.ToString()); resPacket.Clear(); resPacket.ResultCodeNo = e.ResultCodeNo; } SendPacket(resPacket); }