mirror of
https://github.com/google/sandboxed-api.git
synced 2024-03-22 13:11:30 +08:00
Switch unnecessary templated functions to regular
PiperOrigin-RevId: 422764920 Change-Id: I44f487b2e114eb9e5ca68d29a7b21fa72917d6f1
This commit is contained in:
parent
baa1e570b4
commit
38a1cb707f
|
@ -127,6 +127,7 @@ cc_library(
|
|||
cc_library(
|
||||
name = "vars",
|
||||
srcs = [
|
||||
"proto_helper.cc",
|
||||
"rpcchannel.cc",
|
||||
"var_abstract.cc",
|
||||
"var_int.cc",
|
||||
|
|
|
@ -129,6 +129,7 @@ target_link_libraries(sapi_var_type PRIVATE
|
|||
|
||||
# sandboxed_api:vars
|
||||
add_library(sapi_vars ${SAPI_LIB_TYPE}
|
||||
proto_helper.cc
|
||||
proto_helper.h
|
||||
rpcchannel.cc
|
||||
rpcchannel.h
|
||||
|
|
55
sandboxed_api/proto_helper.cc
Normal file
55
sandboxed_api/proto_helper.cc
Normal file
|
@ -0,0 +1,55 @@
|
|||
// Copyright 2022 Google LLC
|
||||
//
|
||||
// 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 "sandboxed_api/proto_helper.h"
|
||||
|
||||
#include "absl/status/status.h"
|
||||
|
||||
namespace sapi {
|
||||
|
||||
namespace internal {
|
||||
|
||||
absl::Status DeserializeProto(const char* data, size_t len,
|
||||
google::protobuf::Message& output) {
|
||||
ProtoArg envelope;
|
||||
if (!envelope.ParseFromArray(data, len)) {
|
||||
return absl::InternalError("Unable to parse proto from array");
|
||||
}
|
||||
|
||||
auto pb_data = envelope.protobuf_data();
|
||||
if (!output.ParseFromArray(pb_data.data(), pb_data.size())) {
|
||||
return absl::InternalError("Unable to parse proto from envelope data");
|
||||
}
|
||||
return absl::OkStatus();
|
||||
}
|
||||
|
||||
} // namespace internal
|
||||
|
||||
absl::StatusOr<std::vector<uint8_t>> SerializeProto(
|
||||
const google::protobuf::Message& proto) {
|
||||
// Wrap protobuf in a envelope so that we know the name of the protobuf
|
||||
// structure when deserializing in the sandboxee.
|
||||
ProtoArg proto_arg;
|
||||
proto_arg.set_protobuf_data(proto.SerializeAsString());
|
||||
proto_arg.set_full_name(proto.GetDescriptor()->full_name());
|
||||
|
||||
std::vector<uint8_t> serialized_proto(proto_arg.ByteSizeLong());
|
||||
if (!proto_arg.SerializeToArray(serialized_proto.data(),
|
||||
serialized_proto.size())) {
|
||||
return absl::InternalError("Unable to serialize proto to array");
|
||||
}
|
||||
return serialized_proto;
|
||||
}
|
||||
|
||||
} // namespace sapi
|
|
@ -24,41 +24,27 @@
|
|||
#include "absl/status/status.h"
|
||||
#include "absl/status/statusor.h"
|
||||
#include "sandboxed_api/proto_arg.pb.h"
|
||||
#include "sandboxed_api/util/status_macros.h"
|
||||
|
||||
namespace sapi {
|
||||
|
||||
template <typename T>
|
||||
absl::StatusOr<std::vector<uint8_t>> SerializeProto(const T& proto) {
|
||||
static_assert(std::is_base_of<google::protobuf::Message, T>::value,
|
||||
"Template argument must be a proto message");
|
||||
// Wrap protobuf in a envelope so that we know the name of the protobuf
|
||||
// structure when deserializing in the sandboxee.
|
||||
ProtoArg proto_arg;
|
||||
proto_arg.set_protobuf_data(proto.SerializeAsString());
|
||||
proto_arg.set_full_name(proto.GetDescriptor()->full_name());
|
||||
namespace internal {
|
||||
|
||||
std::vector<uint8_t> serialized_proto(proto_arg.ByteSizeLong());
|
||||
if (!proto_arg.SerializeToArray(serialized_proto.data(),
|
||||
serialized_proto.size())) {
|
||||
return absl::InternalError("Unable to serialize proto to array");
|
||||
}
|
||||
return serialized_proto;
|
||||
}
|
||||
absl::Status DeserializeProto(const char* data, size_t len,
|
||||
google::protobuf::Message& output);
|
||||
|
||||
} // namespace internal
|
||||
|
||||
absl::StatusOr<std::vector<uint8_t>> SerializeProto(
|
||||
const google::protobuf::Message& proto);
|
||||
|
||||
template <typename T>
|
||||
absl::StatusOr<T> DeserializeProto(const char* data, size_t len) {
|
||||
static_assert(std::is_base_of<google::protobuf::Message, T>::value,
|
||||
"Template argument must be a proto message");
|
||||
ProtoArg envelope;
|
||||
if (!envelope.ParseFromArray(data, len)) {
|
||||
return absl::InternalError("Unable to parse proto from array");
|
||||
}
|
||||
|
||||
auto pb_data = envelope.protobuf_data();
|
||||
T result;
|
||||
if (!result.ParseFromArray(pb_data.data(), pb_data.size())) {
|
||||
return absl::InternalError("Unable to parse proto from envelope data");
|
||||
}
|
||||
SAPI_RETURN_IF_ERROR(
|
||||
internal::DeserializeProto(data, len, /*output=*/result));
|
||||
return result;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user