systemMain.cpp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. #include <phpcpp.h>
  2. #include <string.h>
  3. #include <string>
  4. #include <unistd.h>
  5. #include <errno.h>
  6. //#include <fcntl.h>
  7. //#include <sys/types.h>
  8. //#include <sys/stat.h>
  9. #include <stdio.h>
  10. //#include "crypto.h"
  11. #include "ProtobufLAInitiator.h"
  12. using namespace std;
  13. // #include <unistd.h>
  14. // based off the example functionreturnvalue.cpp in PHP-CPP
  15. /**
  16. * Namespace to use
  17. */
  18. //using namespace std;
  19. #define DECRYPTOR_PORT 3825
  20. int local_attestation_successful=0;
  21. int __ImageBase=0;
  22. class Mitigator : public Php::Base
  23. {
  24. private:
  25. static std::string mitigator_pubkey_header_value;
  26. static std::string mitigator_pubkey_header;
  27. public:
  28. // adding to extension throws an error if this method is not public
  29. static void local_attestation_initiator_wrapper()
  30. {
  31. printf("Hello.\n"); fflush(stdout);
  32. setbuf(stdout,NULL); uint32_t count;
  33. uint32_t return_sgx;
  34. unsigned char* base64_encoded_mitigator_header_and_value = (unsigned char*) malloc(mitigator_pubkey_header.length()+1+216);
  35. // unsigned char base64_encoded_mitigator_header[229] ; //216=(ceil(160/3) * 4) + 1 (for null character) + 21 for "Mitigator-Public-Key"
  36. memcpy(base64_encoded_mitigator_header_and_value, mitigator_pubkey_header.c_str(), mitigator_pubkey_header.length());
  37. return_sgx = local_attestation_initiator(DECRYPTOR_PORT, base64_encoded_mitigator_header_and_value+mitigator_pubkey_header.length());
  38. if(return_sgx != 0)
  39. {
  40. if(return_sgx== 0xFFFFFFFF)
  41. {
  42. perror("\nCould not set up the socket: had the following error: "); fflush(stderr);
  43. }
  44. else
  45. {
  46. printf("\nHad the following error in SGX local attestation: 0x%x", return_sgx);
  47. fflush(stdout);
  48. }
  49. }
  50. else {
  51. printf("\nSuccessful LA with port %d.\n", DECRYPTOR_PORT);
  52. fflush(stdout);
  53. local_attestation_successful=1;
  54. printf("length of string was %d\n", mitigator_pubkey_header.length()); fflush(stdout);
  55. mitigator_pubkey_header_value=std::string((char*)base64_encoded_mitigator_header_and_value,mitigator_pubkey_header.length()+216);
  56. }
  57. }
  58. Mitigator() = default;
  59. virtual ~Mitigator() = default;
  60. // call this function in PHP async or call add_header here.
  61. static Php::Value get_mitigator_header()
  62. {
  63. return mitigator_pubkey_header_value;
  64. }
  65. // call this func onRequest
  66. static Php::Value php_decrypt_wrapper(Php::Parameters &params )
  67. {
  68. /*
  69. int counter;
  70. unsigned char* plaintext_user_data;
  71. unsigned char* ciphertext_user_data;
  72. unsigned char* base64_encoded_pub_key;
  73. Php::Value ciphertext_user_data_obj=params[1];
  74. Php::Value base64_encoded_pub_key_obj=params[0];
  75. uint32_t ciphertext_length;
  76. uint32_t plaintext_length;
  77. ciphertext_length = params[1].size();
  78. plaintext_user_data = (unsigned char*) malloc(ciphertext_length);
  79. // TODO: The arrays returned by the const char* operator in PHP-CPP are highly likely to be null-terminated.
  80. ciphertext_user_data = (unsigned char*) static_cast<const char*>(ciphertext_user_data_obj);
  81. base64_encoded_pub_key = (unsigned char*) static_cast<const char*>(base64_encoded_pub_key_obj);
  82. printf("Base64 encoded key:\n");
  83. for(counter=0; counter < 88; counter++)
  84. printf("%c ", base64_encoded_pub_key[counter]);
  85. printf("\n"); fflush(stdout);
  86. printf("Ciphertext received:\n");
  87. for(counter=0 ; counter < ciphertext_length; counter++ )
  88. printf("0x%02x ", ciphertext_user_data[counter]);
  89. printf("\n"); fflush(stdout);
  90. uint32_t ret_status=decrypt_client_data_through_decryptor(base64_encoded_pub_key, ciphertext_user_data, ciphertext_length, (unsigned char*) plaintext_user_data, &plaintext_length);
  91. if(ret_status != 0)
  92. {
  93. printf("Received error code: 0x%02x\n", ret_status); fflush(stdout);
  94. }
  95. printf("Going to return this plaintext:\n");
  96. for(counter=0;counter<plaintext_length;counter++)
  97. printf("0x%02x ", plaintext_user_data[counter]);
  98. fflush(stdout);
  99. std::string plaintext_user_data_str = std::string((char*) plaintext_user_data, plaintext_length);
  100. // free(plaintext_user_data); // TODO: For some reason, this causes a crash.
  101. */
  102. return "Miti";//plaintext_user_data_str; plaintext_user_data_obj; // (ciphertext_user_data, ciphertext_length) ;
  103. }
  104. };
  105. std::string Mitigator::mitigator_pubkey_header_value=std::string("!");
  106. std::string Mitigator::mitigator_pubkey_header=std::string("Mitigator-Public-Key:");
  107. extern "C" {
  108. // export the "get_module" function that will be called by the Zend engine
  109. PHPCPP_EXPORT void *get_module()
  110. {
  111. // create extension
  112. static Php::Extension extension("decryptor_la_setup_and_decryption","1.0");
  113. Php::Class<Mitigator> mitigator("Mitigator");
  114. mitigator.method<&Mitigator::get_mitigator_header>("get_mitigator_header");
  115. // mitigator.property("mitigator_header", &Mitigator::get_mitigator_header);
  116. mitigator.method<&Mitigator::local_attestation_initiator_wrapper>("local_attestation_initiator_wrapper");
  117. mitigator.method<&Mitigator::php_decrypt_wrapper>("php_decrypt_wrapper", { Php::ByVal("string", Php::Type::String), Php::ByVal("string", Php::Type::String) } );
  118. extension.onStartup(&Mitigator::local_attestation_initiator_wrapper);
  119. // extension.onRequest(&Mitigator::php_decrypt_wrapper);
  120. // return the extension module
  121. extension.add(mitigator);
  122. return extension.module();
  123. }
  124. }