diff options
| author | yum <yum.food.vr@gmail.com> | 2023-07-03 18:44:43 -0700 |
|---|---|---|
| committer | yum <yum.food.vr@gmail.com> | 2023-07-03 19:36:13 -0700 |
| commit | 76ae7c28ea6224b2c919122d5dc71bcc00a0ecaa (patch) | |
| tree | 9723fd02715d747cfc439d1f66d36821a56069e9 /BrowserSource/Proxy/HTTPMapper.h | |
| parent | 7888ccc96d001512dd3bdc01f299856e86c876f5 (diff) | |
Begin work on proxy server
Create a simple server with 3 endpoints:
* /create_session: Create a session and return its identifier.
* /set_transcript: Update a session's transcript.
* /get_transcript: Fetch a session's transcript.
Right now the session ID provides authentication *and* authorization.
There is no public/private ID so you have to trust whoever you share
your ID with.
IDs are long and generated by the server, so it should be somewhat
secure against low-effort hacking.
Other updates:
* Drop whisper_requirements.txt - no longer needed.
* Vendor curl to make it easier to interact with the server.
TODO:
* Fuzz test the server.
Diffstat (limited to 'BrowserSource/Proxy/HTTPMapper.h')
| -rw-r--r-- | BrowserSource/Proxy/HTTPMapper.h | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/BrowserSource/Proxy/HTTPMapper.h b/BrowserSource/Proxy/HTTPMapper.h new file mode 100644 index 0000000..e349f6e --- /dev/null +++ b/BrowserSource/Proxy/HTTPMapper.h @@ -0,0 +1,35 @@ +#pragma once + +#include "WebCommon.h" + +#include <string> + +namespace WebServer { + + class HTTPMapper { + public: + HTTPMapper() {} + virtual ~HTTPMapper() {} + + std::string Map(int status_code, + const std::string& payload, ContentType type); + }; + + class HTTPMapperHTML : public HTTPMapper { + public: + HTTPMapperHTML() {} + virtual ~HTTPMapperHTML() {} + + std::string Map(int status_code, + const std::string& payload); + }; + + class HTTPMapperJSON : public HTTPMapper { + public: + HTTPMapperJSON() {} + virtual ~HTTPMapperJSON() {} + + std::string Map(int status_code, + const std::string& payload); + }; +} |
