/* Copyright (c) 2008 TrueCrypt Developers Association. All rights reserved. Governed by the TrueCrypt License 3.0 the full text of which is contained in the file License.txt included in TrueCrypt binary and source code distribution packages. */ #include "MountOptions.h" #include "Platform/MemoryStream.h" #include "Platform/SerializerFactory.h" namespace TrueCrypt { void MountOptions::CopyFrom (const MountOptions &other) { #define TC_CLONE(NAME) NAME = other.NAME #define TC_CLONE_SHARED(TYPE,NAME) NAME = other.NAME ? make_shared (*other.NAME) : shared_ptr () TC_CLONE (CachePassword); TC_CLONE (FilesystemOptions); TC_CLONE (FilesystemType); TC_CLONE_SHARED (KeyfileList, Keyfiles); TC_CLONE_SHARED (DirectoryPath, MountPoint); TC_CLONE (NoFilesystem); TC_CLONE (NoHardwareCrypto); TC_CLONE (NoKernelCrypto); TC_CLONE_SHARED (VolumePassword, Password); TC_CLONE_SHARED (VolumePath, Path); TC_CLONE (PartitionInSystemEncryptionScope); TC_CLONE (PreserveTimestamps); TC_CLONE (Protection); TC_CLONE_SHARED (VolumePassword, ProtectionPassword); TC_CLONE_SHARED (KeyfileList, ProtectionKeyfiles); TC_CLONE (Removable); TC_CLONE (SharedAccessAllowed); TC_CLONE (SlotNumber); TC_CLONE (UseBackupHeaders); } void MountOptions::Deserialize (shared_ptr stream) { Serializer sr (stream); sr.Deserialize ("CachePassword", CachePassword); sr.Deserialize ("FilesystemOptions", FilesystemOptions); sr.Deserialize ("FilesystemType", FilesystemType); Keyfiles = Keyfile::DeserializeList (stream, "Keyfiles"); if (!sr.DeserializeBool ("MountPointNull")) MountPoint.reset (new DirectoryPath (sr.DeserializeWString ("MountPoint"))); else MountPoint.reset(); sr.Deserialize ("NoFilesystem", NoFilesystem); sr.Deserialize ("NoHardwareCrypto", NoHardwareCrypto); sr.Deserialize ("NoKernelCrypto", NoKernelCrypto); if (!sr.DeserializeBool ("PasswordNull")) Password = Serializable::DeserializeNew (stream); else Password.reset(); if (!sr.DeserializeBool ("PathNull")) Path.reset (new VolumePath (sr.DeserializeWString ("Path"))); else Path.reset(); sr.Deserialize ("PartitionInSystemEncryptionScope", PartitionInSystemEncryptionScope); sr.Deserialize ("PreserveTimestamps", PreserveTimestamps); Protection = static_cast (sr.DeserializeInt32 ("Protection")); if (!sr.DeserializeBool ("ProtectionPasswordNull")) ProtectionPassword = Serializable::DeserializeNew (stream); else ProtectionPassword.reset(); ProtectionKeyfiles = Keyfile::DeserializeList (stream, "ProtectionKeyfiles"); sr.Deserialize ("Removable", Removable); sr.Deserialize ("SharedAccessAllowed", SharedAccessAllowed); sr.Deserialize ("SlotNumber", SlotNumber); sr.Deserialize ("UseBackupHeaders", UseBackupHeaders); } void MountOptions::Serialize (shared_ptr stream) const { Serializable::Serialize (stream); Serializer sr (stream); sr.Serialize ("CachePassword", CachePassword); sr.Serialize ("FilesystemOptions", FilesystemOptions); sr.Serialize ("FilesystemType", FilesystemType); Keyfile::SerializeList (stream, "Keyfiles", Keyfiles); sr.Serialize ("MountPointNull", MountPoint == nullptr); if (MountPoint) sr.Serialize ("MountPoint", wstring (*MountPoint)); sr.Serialize ("NoFilesystem", NoFilesystem); sr.Serialize ("NoHardwareCrypto", NoHardwareCrypto); sr.Serialize ("NoKernelCrypto", NoKernelCrypto); sr.Serialize ("PasswordNull", Password == nullptr); if (Password) Password->Serialize (stream); sr.Serialize ("PathNull", Path == nullptr); if (Path) sr.Serialize ("Path", wstring (*Path)); sr.Serialize ("PartitionInSystemEncryptionScope", PartitionInSystemEncryptionScope); sr.Serialize ("PreserveTimestamps", PreserveTimestamps); sr.Serialize ("Protection", static_cast (Protection)); sr.Serialize ("ProtectionPasswordNull", ProtectionPassword == nullptr); if (ProtectionPassword) ProtectionPassword->Serialize (stream); Keyfile::SerializeList (stream, "ProtectionKeyfiles", ProtectionKeyfiles); sr.Serialize ("Removable", Removable); sr.Serialize ("SharedAccessAllowed", SharedAccessAllowed); sr.Serialize ("SlotNumber", SlotNumber); sr.Serialize ("UseBackupHeaders", UseBackupHeaders); } TC_SERIALIZER_FACTORY_ADD_CLASS (MountOptions); }