| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- #ifndef HTTP_API_TEST_H_
- #define HTTP_API_TEST_H_
- #include "HttpServer.h"
- // XXX(path, method, handler)
- #define HTTP_API_MAP(XXX) \
- XXX("/login", POST, http_api_login) \
- XXX("/hello", GET, http_api_hello) \
- XXX("/query", GET, http_api_query) \
- XXX("/echo", POST, http_api_echo) \
- XXX("/kv", POST, http_api_kv) \
- XXX("/json", POST, http_api_json) \
- XXX("/form", POST, http_api_form) \
- XXX("/upload", POST, http_api_upload) \
- XXX("/grpc", POST, http_api_grpc) \
- \
- XXX("/test", POST, http_api_test) \
- XXX("/group/:group_name/user/:user_id", DELETE, http_api_restful) \
- inline void response_status(HttpResponse* res, int code, const char* message) {
- res->Set("code", code);
- res->Set("message", message);
- }
- inline int http_api_preprocessor(HttpRequest* req, HttpResponse* res) {
- //printf("%s:%d\n", req->client_addr.ip.c_str(), req->client_addr.port);
- //printf("%s\n", req->Dump(true, true).c_str());
- req->ParseBody();
- res->content_type = APPLICATION_JSON;
- #if 0
- // authentication sample code
- if (strcmp(req->path.c_str(), DEFAULT_BASE_URL "/login") != 0) {
- string token = req->GetHeader("token");
- if (token.empty()) {
- response_status(res, 10011, "Miss token");
- res->DumpBody();
- return HTTP_STATUS_UNAUTHORIZED;
- }
- else if (strcmp(token.c_str(), "abcdefg") != 0) {
- response_status(res, 10012, "Token wrong");
- res->DumpBody();
- return HTTP_STATUS_UNAUTHORIZED;
- }
- return 0;
- }
- #endif
- return 0;
- }
- inline int http_api_postprocessor(HttpRequest* req, HttpResponse* res) {
- res->DumpBody();
- //printf("%s\n", res->Dump(true, true).c_str());
- return 0;
- }
- inline int http_api_login(HttpRequest* req, HttpResponse* res) {
- int ret = 0;
- string username = req->GetString("username");
- string password = req->GetString("password");
- if (username.empty() || password.empty()) {
- response_status(res, 10001, "Miss username or password");
- ret = HTTP_STATUS_BAD_REQUEST;
- }
- else if (strcmp(username.c_str(), "admin") != 0) {
- response_status(res, 10002, "Username not exist");
- ret = HTTP_STATUS_BAD_REQUEST;
- }
- else if (strcmp(password.c_str(), "123456") != 0) {
- response_status(res, 10003, "Password wrong");
- ret = HTTP_STATUS_BAD_REQUEST;
- }
- else {
- res->Set("token", "abcdefg");
- response_status(res, 0, "Login succeed.");
- ret = HTTP_STATUS_OK;
- }
- res->DumpBody();
- return ret;
- }
- inline int http_api_hello(HttpRequest* req, HttpResponse* res) {
- res->content_type = TEXT_PLAIN;
- res->body = "hello";
- return 0;
- }
- inline int http_api_query(HttpRequest* req, HttpResponse* res) {
- // scheme:[//[user[:password]@]host[:port]][/path][?query][#fragment]
- // ?query => HttpRequest::query_params
- for (auto& param : req->query_params) {
- res->Set(param.first.c_str(), param.second);
- }
- response_status(res, 0, "Query completed.");
- return 0;
- }
- inline int http_api_echo(HttpRequest* req, HttpResponse* res) {
- res->content_type = req->content_type;
- res->body = req->body;
- return 0;
- }
- inline int http_api_kv(HttpRequest*req, HttpResponse* res) {
- if (req->content_type != APPLICATION_URLENCODED) {
- return HTTP_STATUS_BAD_REQUEST;
- }
- res->content_type = APPLICATION_URLENCODED;
- res->kv = req->kv;
- return 0;
- }
- inline int http_api_json(HttpRequest* req, HttpResponse* res) {
- if (req->content_type != APPLICATION_JSON) {
- return HTTP_STATUS_BAD_REQUEST;
- }
- res->content_type = APPLICATION_JSON;
- res->json = req->json;
- return 0;
- }
- inline int http_api_form(HttpRequest* req, HttpResponse* res) {
- if (req->content_type != MULTIPART_FORM_DATA) {
- return HTTP_STATUS_BAD_REQUEST;
- }
- res->content_type = MULTIPART_FORM_DATA;
- res->form = req->form;
- return 0;
- }
- inline int http_api_upload(HttpRequest* req, HttpResponse* res) {
- if (req->content_type != MULTIPART_FORM_DATA) {
- return HTTP_STATUS_BAD_REQUEST;
- }
- FormData file = req->form["file"];
- string filepath("html/uploads/");
- filepath += file.filename;
- FILE* fp = fopen(filepath.c_str(), "w");
- if (fp) {
- hlogi("Save as %s", filepath.c_str());
- fwrite(file.content.data(), 1, file.content.size(), fp);
- fclose(fp);
- }
- response_status(res, 0, "OK");
- return 0;
- }
- inline int http_api_grpc(HttpRequest* req, HttpResponse* res) {
- if (req->content_type != APPLICATION_GRPC) {
- return HTTP_STATUS_BAD_REQUEST;
- }
- // parse protobuf: ParseFromString
- // req->body;
- // res->content_type = APPLICATION_GRPC;
- // serailize protobuf: SerializeAsString
- // res->body;
- return 0;
- }
- inline int http_api_test(HttpRequest* req, HttpResponse* res) {
- string str = req->GetString("string");
- //int64_t n = req->Get<int64_t>("int");
- //double f = req->Get<double>("float");
- //bool b = req->Get<bool>("bool");
- int64_t n = req->GetInt("int");
- double f = req->GetFloat("float");
- bool b = req->GetBool("bool");
- res->content_type = req->content_type;
- res->Set("string", str);
- res->Set("int", n);
- res->Set("float", f);
- res->Set("bool", b);
- response_status(res, 0, "OK");
- return 0;
- }
- inline int http_api_restful(HttpRequest* req, HttpResponse* res) {
- // RESTful /:field/ => HttpRequest::query_params
- // path=/group/:group_name/user/:user_id
- //string group_name = req->GetParam("group_name");
- //string user_id = req->GetParam("user_id");
- for (auto& param : req->query_params) {
- res->Set(param.first.c_str(), param.second);
- }
- response_status(res, 0, "Operation completed.");
- return 0;
- }
- #endif // HTTP_API_TEST_H_
|