FileDataSource.cpp 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. /*
  2. * Copyright (c) Contributors to the Open 3D Engine Project.
  3. * For complete copyright and license terms please see the LICENSE at the root of this distribution.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0 OR MIT
  6. *
  7. */
  8. #include <AzCore/IO/SystemFile.h>
  9. #include <AzCore/Memory/SystemAllocator.h>
  10. #include <AzCore/std/containers/vector.h>
  11. #include <AzCore/PlatformIncl.h>
  12. #include "Source/DataSource/FileDataSource.h"
  13. namespace CertificateManager
  14. {
  15. static bool ReadFileIntoString(const char* filename, AZStd::vector<char>& outBuffer)
  16. {
  17. AZStd::string certificatePath = "@products@/certificates/";
  18. certificatePath.append(filename);
  19. AZ::IO::FileIOBase* fileBase = AZ::IO::FileIOBase::GetInstance();
  20. if (!fileBase->Exists(certificatePath.c_str()))
  21. {
  22. AZ_Error("FileDataSource",false,"File(%s) does not exist.\n", certificatePath.c_str());
  23. return false;
  24. }
  25. AZ::IO::HandleType fileHandle;
  26. AZ::IO::Result fileResult = fileBase->Open(certificatePath.c_str(),AZ::IO::OpenMode::ModeRead,fileHandle);
  27. if (!fileResult)
  28. {
  29. AZ_Error("FileDataSource",false,"Failed to open file with result %i\n", fileResult.GetResultCode());
  30. return false;
  31. }
  32. AZ::u64 fileSize = 0;
  33. fileBase->Size(fileHandle,fileSize);
  34. if (fileSize == 0)
  35. {
  36. AZ_Error("FileDataSource",false,"Given empty file(%s) as certificate file.\n",certificatePath.c_str());
  37. return false;
  38. }
  39. outBuffer.resize(fileSize + 1);
  40. fileResult = fileBase->Read(fileHandle,outBuffer.data(),fileSize);
  41. if (!fileResult)
  42. {
  43. AZ_Error("FileDataSource",false,"Failed to read from file(%s) with result code(%i).\n",certificatePath.c_str(),fileResult.GetResultCode());
  44. return false;
  45. }
  46. return true;
  47. }
  48. FileDataSource::FileDataSource()
  49. : m_privateKeyPEM(nullptr)
  50. , m_certificatePEM(nullptr)
  51. , m_certificateAuthorityCertPEM(nullptr)
  52. {
  53. FileDataSourceConfigurationBus::Handler::BusConnect();
  54. }
  55. FileDataSource::~FileDataSource()
  56. {
  57. FileDataSourceConfigurationBus::Handler::BusDisconnect();
  58. azfree(m_privateKeyPEM);
  59. azfree(m_certificatePEM);
  60. azfree(m_certificateAuthorityCertPEM);
  61. }
  62. void FileDataSource::ConfigureDataSource(const char* keyPath, const char* certPath, const char* caPath)
  63. {
  64. ConfigurePrivateKey(keyPath);
  65. ConfigureCertificate(certPath);
  66. ConfigureCertificateAuthority(caPath);
  67. }
  68. void FileDataSource::ConfigurePrivateKey(const char* path)
  69. {
  70. if (m_privateKeyPEM != nullptr)
  71. {
  72. azfree(m_privateKeyPEM);
  73. m_privateKeyPEM = nullptr;
  74. }
  75. if (path != nullptr)
  76. {
  77. LoadGenericFile(path,m_privateKeyPEM);
  78. }
  79. }
  80. void FileDataSource::ConfigureCertificate(const char* path)
  81. {
  82. if (m_certificatePEM != nullptr)
  83. {
  84. azfree(m_certificatePEM);
  85. m_certificatePEM = nullptr;
  86. }
  87. if (path != nullptr)
  88. {
  89. LoadGenericFile(path,m_certificatePEM);
  90. }
  91. }
  92. void FileDataSource::ConfigureCertificateAuthority(const char* path)
  93. {
  94. if (m_certificateAuthorityCertPEM != nullptr)
  95. {
  96. azfree(m_certificateAuthorityCertPEM);
  97. m_certificateAuthorityCertPEM = nullptr;
  98. }
  99. if (path != nullptr)
  100. {
  101. LoadGenericFile(path,m_certificateAuthorityCertPEM);
  102. }
  103. }
  104. bool FileDataSource::HasCertificateAuthority() const
  105. {
  106. return m_certificateAuthorityCertPEM != nullptr;
  107. }
  108. char* FileDataSource::RetrieveCertificateAuthority()
  109. {
  110. return m_certificateAuthorityCertPEM;
  111. }
  112. bool FileDataSource::HasPublicKey() const
  113. {
  114. return m_certificatePEM != nullptr;
  115. }
  116. char* FileDataSource::RetrievePublicKey()
  117. {
  118. return m_certificatePEM;
  119. }
  120. bool FileDataSource::HasPrivateKey() const
  121. {
  122. return m_privateKeyPEM != nullptr;
  123. }
  124. char* FileDataSource::RetrievePrivateKey()
  125. {
  126. return m_privateKeyPEM;
  127. }
  128. void FileDataSource::LoadGenericFile(const char* filename, char* &destination)
  129. {
  130. if (filename)
  131. {
  132. AZStd::vector<char> contents;
  133. if (ReadFileIntoString(filename, contents))
  134. {
  135. if (destination != nullptr)
  136. {
  137. azfree(destination);
  138. destination = nullptr;
  139. }
  140. destination = reinterpret_cast<char*>(azmalloc(contents.size()));
  141. if (destination == nullptr)
  142. {
  143. AZ_Error("CertificateManager", false, "Invalid destination for file input");
  144. return;
  145. }
  146. memcpy(destination, contents.data(), contents.size());
  147. }
  148. else
  149. {
  150. AZ_Warning("CertificateManager", false, "Failed to read authentication file '%s'.", filename);
  151. }
  152. }
  153. }
  154. } //namespace CertificateManager