1
0
mirror of https://github.com/ohwgiles/laminar.git synced 2024-10-27 20:34:20 +00:00

server: use regular char array as buffer

This approach finally solves the crash under hardened gentoo
discussed in #19
This commit is contained in:
Oliver Giles 2017-12-07 18:28:12 +02:00
parent 4c63cef7ac
commit e371f8ca5a
2 changed files with 7 additions and 8 deletions

View File

@ -422,8 +422,8 @@ void Server::stop() {
void Server::addDescriptor(int fd, std::function<void(const char*,size_t)> cb) { void Server::addDescriptor(int fd, std::function<void(const char*,size_t)> cb) {
auto event = this->ioContext.lowLevelProvider->wrapInputFd(fd, kj::LowLevelAsyncIoProvider::TAKE_OWNERSHIP); auto event = this->ioContext.lowLevelProvider->wrapInputFd(fd, kj::LowLevelAsyncIoProvider::TAKE_OWNERSHIP);
std::vector<char> buffer(PROC_IO_BUFSIZE); auto buffer = kj::heapArrayBuilder<char>(PROC_IO_BUFSIZE);
tasks.add(handleFdRead(event, kj::mv(buffer), cb).attach(std::move(event))); tasks.add(handleFdRead(event, buffer.asPtr().begin(), cb).attach(std::move(event)).attach(std::move(buffer)));
} }
void Server::acceptHttpClient(kj::Own<kj::ConnectionReceiver>&& listener) { void Server::acceptHttpClient(kj::Own<kj::ConnectionReceiver>&& listener) {
@ -456,12 +456,12 @@ void Server::acceptRpcClient(kj::Own<kj::ConnectionReceiver>&& listener) {
// returns a promise which will read a chunk of data from the file descriptor // returns a promise which will read a chunk of data from the file descriptor
// wrapped by stream and invoke the provided callback with the read data. // wrapped by stream and invoke the provided callback with the read data.
// Repeats until ::read returns <= 0 // Repeats until ::read returns <= 0
kj::Promise<void> Server::handleFdRead(kj::AsyncInputStream* stream, std::vector<char>&& buffer, std::function<void(const char*,size_t)> cb) { kj::Promise<void> Server::handleFdRead(kj::AsyncInputStream* stream, char* buffer, std::function<void(const char*,size_t)> cb) {
return stream->tryRead((void*)buffer.data(), 1, PROC_IO_BUFSIZE).then(kj::mvCapture(kj::mv(buffer), [this,stream,cb](std::vector<char>&& buffer, size_t sz) { return stream->tryRead(buffer, 1, PROC_IO_BUFSIZE).then([this,stream,buffer,cb](size_t sz) {
if(sz > 0) { if(sz > 0) {
cb(buffer.data(), sz); cb(buffer, sz);
return handleFdRead(stream, kj::mv(buffer), cb); return handleFdRead(stream, kj::mv(buffer), cb);
} }
return kj::Promise<void>(kj::READY_NOW); return kj::Promise<void>(kj::READY_NOW);
})); });
} }

View File

@ -23,7 +23,6 @@
#include <capnp/message.h> #include <capnp/message.h>
#include <capnp/capability.h> #include <capnp/capability.h>
#include <functional> #include <functional>
#include <vector>
struct LaminarInterface; struct LaminarInterface;
@ -47,7 +46,7 @@ public:
private: private:
void acceptHttpClient(kj::Own<kj::ConnectionReceiver>&& listener); void acceptHttpClient(kj::Own<kj::ConnectionReceiver>&& listener);
void acceptRpcClient(kj::Own<kj::ConnectionReceiver>&& listener); void acceptRpcClient(kj::Own<kj::ConnectionReceiver>&& listener);
kj::Promise<void> handleFdRead(kj::AsyncInputStream* stream, std::vector<char>&& buffer, std::function<void(const char*,size_t)> cb); kj::Promise<void> handleFdRead(kj::AsyncInputStream* stream, char* buffer, std::function<void(const char*,size_t)> cb);
void taskFailed(kj::Exception&& exception) override { void taskFailed(kj::Exception&& exception) override {
kj::throwFatalException(kj::mv(exception)); kj::throwFatalException(kj::mv(exception));