#pragma once #include #include #include #include #include namespace DB { /** Stream for output data in JSON format. */ class JSONRowOutputStream : public IRowOutputStream { public: JSONRowOutputStream(WriteBuffer & ostr_, const Block & sample_, bool write_statistics_, bool force_quoting_ = true); void writeField(const IColumn & column, const IDataType & type, size_t row_num) override; void writeFieldDelimiter() override; void writeRowStartDelimiter() override; void writeRowEndDelimiter() override; void writePrefix() override; void writeSuffix() override; void flush() override { ostr->next(); if (validating_ostr) dst_ostr.next(); } void setRowsBeforeLimit(size_t rows_before_limit_) override { applied_limit = true; rows_before_limit = rows_before_limit_; } void setTotals(const Block & totals_) override { totals = totals_; } void setExtremes(const Block & extremes_) override { extremes = extremes_; } void onProgress(const Progress & value) override; String getContentType() const override { return "application/json; charset=UTF-8"; } protected: void writeRowsBeforeLimitAtLeast(); virtual void writeTotals(); virtual void writeExtremes(); void writeStatistics(); WriteBuffer & dst_ostr; std::unique_ptr validating_ostr; /// Validates UTF-8 sequences, replaces bad sequences with replacement character. WriteBuffer * ostr; size_t field_number = 0; size_t row_count = 0; bool applied_limit = false; size_t rows_before_limit = 0; NamesAndTypes fields; Block totals; Block extremes; Progress progress; Stopwatch watch; bool write_statistics; bool force_quoting; }; }