HttpContext.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. #ifndef HV_HTTP_CONTEXT_H_
  2. #define HV_HTTP_CONTEXT_H_
  3. #include "hexport.h"
  4. #include "HttpMessage.h"
  5. #include "HttpResponseWriter.h"
  6. struct HttpService;
  7. namespace hv {
  8. struct HV_EXPORT HttpContext {
  9. HttpService* service;
  10. HttpRequestPtr request;
  11. HttpResponsePtr response;
  12. HttpResponseWriterPtr writer;
  13. // HttpRequest aliases
  14. // return request->xxx
  15. std::string ip() {
  16. return request->client_addr.ip;
  17. }
  18. http_method method() {
  19. return request->method;
  20. }
  21. std::string url() {
  22. return request->url;
  23. }
  24. std::string path() {
  25. return request->Path();
  26. }
  27. std::string host() {
  28. return request->Host();
  29. }
  30. const http_headers& headers() {
  31. return request->headers;
  32. }
  33. std::string header(const char* key, const std::string& defvalue = "") {
  34. return request->GetHeader(key, defvalue);
  35. }
  36. const QueryParams& params() {
  37. return request->query_params;
  38. }
  39. std::string param(const char* key, const std::string& defvalue = "") {
  40. return request->GetParam(key, defvalue);
  41. }
  42. int length() {
  43. return request->ContentLength();
  44. }
  45. http_content_type type() {
  46. return request->ContentType();
  47. }
  48. bool is(http_content_type content_type) {
  49. return request->content_type == content_type;
  50. }
  51. bool is(const char* content_type) {
  52. return request->content_type == http_content_type_enum(content_type);
  53. }
  54. std::string& body() {
  55. return response->body;
  56. }
  57. #ifndef WITHOUT_HTTP_CONTENT
  58. const hv::Json& json() {
  59. // Content-Type: application/json
  60. if (request->content_type == APPLICATION_JSON &&
  61. request->json.empty() &&
  62. !request->body.empty()) {
  63. request->ParseBody();
  64. }
  65. return request->json;
  66. }
  67. const MultiPart& form() {
  68. // Content-Type: multipart/form-data
  69. if (request->content_type == MULTIPART_FORM_DATA &&
  70. request->form.empty() &&
  71. !request->body.empty()) {
  72. request->ParseBody();
  73. }
  74. return request->form;
  75. }
  76. const hv::KeyValue& urlencoded() {
  77. // Content-Type: application/x-www-form-urlencoded
  78. if (request->content_type == X_WWW_FORM_URLENCODED &&
  79. request->kv.empty() &&
  80. !request->body.empty()) {
  81. request->ParseBody();
  82. }
  83. return request->kv;
  84. }
  85. // T=[bool, int, int64_t, float, double]
  86. template<typename T>
  87. T get(const char* key, T defvalue = 0) {
  88. return request->Get(key, defvalue);
  89. }
  90. std::string get(const char* key, const std::string& defvalue = "") {
  91. return request->GetString(key, defvalue);
  92. }
  93. #endif
  94. // HttpResponse aliases
  95. // response->xxx = xxx
  96. void setStatus(http_status status) {
  97. response->status_code = status;
  98. }
  99. void setContentType(http_content_type type) {
  100. response->content_type = type;
  101. }
  102. void setContentType(const char* type) {
  103. response->content_type = http_content_type_enum(type);
  104. }
  105. void setHeader(const char* key, const std::string& value) {
  106. response->headers[key] = value;
  107. if (stricmp(key, "Content-Type") == 0) {
  108. setContentType(value.c_str());
  109. }
  110. }
  111. void setBody(const std::string& body) {
  112. response->body = body;
  113. }
  114. // response->sendXxx
  115. int send() {
  116. writer->End();
  117. return response->status_code;
  118. }
  119. int send(const std::string& str, http_content_type type = APPLICATION_JSON) {
  120. response->content_type = type;
  121. response->body = str;
  122. return send();
  123. }
  124. int sendString(const std::string& str) {
  125. response->String(str);
  126. return send();
  127. }
  128. int sendData(void* data, int len, bool nocopy = true) {
  129. response->Data(data, len, nocopy);
  130. return send();
  131. }
  132. int sendFile(const char* filepath) {
  133. response->File(filepath);
  134. return send();
  135. }
  136. #ifndef WITHOUT_HTTP_CONTENT
  137. // T=[bool, int, int64_t, float, double, string]
  138. template<typename T>
  139. void set(const char* key, const T& value) {
  140. response->Set(key, value);
  141. }
  142. // @see HttpMessage::Json
  143. // @usage https://github.com/nlohmann/json
  144. template<typename T>
  145. int sendJson(const T& t) {
  146. response->Json(t);
  147. return send();
  148. }
  149. #endif
  150. };
  151. } // end namespace hv
  152. typedef std::shared_ptr<hv::HttpContext> HttpContextPtr;
  153. #endif // HV_HTTP_CONTEXT_H_