src/json2pb/json_to_pb.h (44 lines of code) (raw):

// Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you 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. // protobuf-json: Conversions between protobuf and json. #ifndef BRPC_JSON2PB_JSON_TO_PB_H #define BRPC_JSON2PB_JSON_TO_PB_H #include "json2pb/zero_copy_stream_reader.h" #include <google/protobuf/message.h> #include <google/protobuf/io/zero_copy_stream.h> // ZeroCopyInputStream #include <google/protobuf/util/json_util.h> namespace json2pb { struct Json2PbOptions { Json2PbOptions(); // Decode string in json using base64 decoding if the type of // corresponding field is bytes when this option is turned on. // Default: false for baidu-interal, true otherwise. bool base64_to_bytes; // Allow decoding json array iff there is only one repeated field. // Default: false. bool array_to_single_repeated; // Allow more bytes remaining in the input after parsing the first json // object. Useful when the input contains more than one json object. bool allow_remaining_bytes_after_parsing; }; // Convert `json' to protobuf `message' according to `options'. // Returns true on success. `error' (if not NULL) will be set with error // message on failure. // // [When options.allow_remaining_bytes_after_parsing is true] // * `parse_offset' will be set with #bytes parsed // * the function still returns false on empty document but the `error' is set // to empty string instead of `The document is empty'. bool JsonToProtoMessage(const std::string& json, google::protobuf::Message* message, const Json2PbOptions& options, std::string* error = nullptr, size_t* parsed_offset = nullptr); // Use ZeroCopyInputStream as input instead of std::string. bool JsonToProtoMessage(google::protobuf::io::ZeroCopyInputStream* json, google::protobuf::Message* message, const Json2PbOptions& options, std::string* error = nullptr, size_t* parsed_offset = nullptr); // Use ZeroCopyStreamReader as input instead of std::string. // If you need to parse multiple jsons from IOBuf, you should use this // overload instead of the ZeroCopyInputStream one which bases on this // and recreates a ZeroCopyStreamReader internally that can't be reused // between continuous calls. bool JsonToProtoMessage(ZeroCopyStreamReader* json, google::protobuf::Message* message, const Json2PbOptions& options, std::string* error = nullptr, size_t* parsed_offset = nullptr); // Using default Json2PbOptions. bool JsonToProtoMessage(const std::string& json, google::protobuf::Message* message, std::string* error = nullptr); bool JsonToProtoMessage(google::protobuf::io::ZeroCopyInputStream* stream, google::protobuf::Message* message, std::string* error = nullptr); // See <google/protobuf/util/json_util.h> for details. using ProtoJson2PbOptions = google::protobuf::util::JsonParseOptions; // Convert ProtoJSON formatted `json' to protobuf `message' according to `options'. // See https://protobuf.dev/programming-guides/json/ for details. bool ProtoJsonToProtoMessage(google::protobuf::io::ZeroCopyInputStream* json, google::protobuf::Message* message, const ProtoJson2PbOptions& options = ProtoJson2PbOptions(), std::string* error = NULL); bool ProtoJsonToProtoMessage(const std::string& json, google::protobuf::Message* message, const ProtoJson2PbOptions& options = ProtoJson2PbOptions(), std::string* error = NULL); } // namespace json2pb #endif // BRPC_JSON2PB_JSON_TO_PB_H