2018-08-25 06:30:00 +08:00
|
|
|
/*
|
2018-12-14 13:50:51 +08:00
|
|
|
* JsonTraceLogFormatter.cpp
|
2018-08-25 06:30:00 +08:00
|
|
|
*
|
|
|
|
* This source file is part of the FoundationDB open source project
|
|
|
|
*
|
|
|
|
* Copyright 2018 Apple Inc. and the FoundationDB project authors
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "flow/flow.h"
|
2018-12-14 13:50:51 +08:00
|
|
|
#include "flow/JsonTraceLogFormatter.h"
|
2018-08-25 06:30:00 +08:00
|
|
|
|
|
|
|
#include <sstream>
|
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
void JsonTraceLogFormatter::addref() {
|
|
|
|
ReferenceCounted<JsonTraceLogFormatter>::addref();
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
void JsonTraceLogFormatter::delref() {
|
|
|
|
ReferenceCounted<JsonTraceLogFormatter>::delref();
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
const char* JsonTraceLogFormatter::getExtension() {
|
|
|
|
return "json";
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
const char* JsonTraceLogFormatter::getHeader() {
|
|
|
|
return "";
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
const char* JsonTraceLogFormatter::getFooter() {
|
|
|
|
return "";
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
2018-12-21 01:34:02 +08:00
|
|
|
void escapeString(std::stringstream& ss, const std::string& source) {
|
2018-08-25 06:36:42 +08:00
|
|
|
for (auto c : source) {
|
|
|
|
if (c == '"') {
|
2018-08-29 02:39:16 +08:00
|
|
|
ss << "\\\"";
|
2018-08-25 06:36:42 +08:00
|
|
|
} else if (c == '\\') {
|
|
|
|
ss << "\\\\";
|
2018-12-21 01:34:02 +08:00
|
|
|
} else if (c == '\n') {
|
|
|
|
ss << "\\n";
|
|
|
|
} else if (c == '\r') {
|
|
|
|
ss << "\\r";
|
|
|
|
} else if (isprint(c)) {
|
2018-08-25 06:36:42 +08:00
|
|
|
ss << c;
|
2018-12-21 01:34:02 +08:00
|
|
|
} else {
|
|
|
|
constexpr char hex[] = "0123456789abcdef";
|
|
|
|
int x = int{ static_cast<uint8_t>(c) };
|
|
|
|
ss << "\\x" << hex[x / 16] << hex[x % 16];
|
2018-08-25 06:36:42 +08:00
|
|
|
}
|
|
|
|
}
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
} // namespace
|
2018-08-25 06:30:00 +08:00
|
|
|
|
2018-08-25 06:36:42 +08:00
|
|
|
std::string JsonTraceLogFormatter::formatEvent(const TraceEventFields& fields) {
|
|
|
|
std::stringstream ss;
|
|
|
|
ss << "{ ";
|
|
|
|
for (auto iter = fields.begin(); iter != fields.end(); ++iter) {
|
|
|
|
if (iter != fields.begin()) {
|
|
|
|
ss << ", ";
|
|
|
|
}
|
|
|
|
ss << "\"";
|
|
|
|
escapeString(ss, iter->first);
|
|
|
|
ss << "\": \"";
|
|
|
|
escapeString(ss, iter->second);
|
|
|
|
ss << "\"";
|
|
|
|
}
|
|
|
|
ss << " }\r\n";
|
|
|
|
return ss.str();
|
2018-08-25 06:30:00 +08:00
|
|
|
}
|