2020-01-17 21:05:03 +08:00
|
|
|
// Copyright 2019 Google LLC
|
2019-03-19 00:21:48 +08:00
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
|
|
|
#ifndef SANDBOXED_API_VAR_POINTABLE_H_
|
|
|
|
#define SANDBOXED_API_VAR_POINTABLE_H_
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
#include "sandboxed_api/var_reg.h"
|
|
|
|
|
2019-11-20 20:39:44 +08:00
|
|
|
namespace sapi::v {
|
2019-03-19 00:21:48 +08:00
|
|
|
|
|
|
|
class Ptr;
|
|
|
|
|
|
|
|
// Class that implements pointer support for different objects.
|
|
|
|
class Pointable {
|
|
|
|
public:
|
|
|
|
enum SyncType {
|
|
|
|
// Do not synchronize the underlying object after/before calls.
|
2020-07-20 22:05:24 +08:00
|
|
|
kSyncNone = 0x0,
|
2019-03-19 00:21:48 +08:00
|
|
|
// Synchronize the underlying object (send the data to the sandboxee)
|
|
|
|
// before the call takes place.
|
2020-07-20 22:05:24 +08:00
|
|
|
kSyncBefore = 0x1,
|
2019-03-19 00:21:48 +08:00
|
|
|
// Synchronize the underlying object (retrieve data from the sandboxee)
|
|
|
|
// after the call has finished.
|
2020-07-20 22:05:24 +08:00
|
|
|
kSyncAfter = 0x2,
|
2019-03-19 00:21:48 +08:00
|
|
|
// Synchronize the underlying object with the remote object, by sending the
|
|
|
|
// data to the sandboxee before the call, and retrieving it from the
|
|
|
|
// sandboxee after the call has finished.
|
2020-07-20 22:05:24 +08:00
|
|
|
kSyncBoth = kSyncBefore | kSyncAfter,
|
2019-03-19 00:21:48 +08:00
|
|
|
};
|
|
|
|
|
2021-10-11 20:37:34 +08:00
|
|
|
virtual ~Pointable() = default;
|
2019-03-19 00:21:48 +08:00
|
|
|
|
|
|
|
// Functions to get pointers with certain type of synchronization scheme.
|
|
|
|
Ptr* PtrNone() {
|
|
|
|
if (ptr_none_ == nullptr) {
|
2020-07-20 22:05:24 +08:00
|
|
|
ptr_none_.reset(CreatePtr(kSyncNone));
|
2019-03-19 00:21:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return ptr_none_.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
Ptr* PtrBoth() {
|
|
|
|
if (ptr_both_ == nullptr) {
|
2020-07-20 22:05:24 +08:00
|
|
|
ptr_both_.reset(CreatePtr(kSyncBoth));
|
2019-03-19 00:21:48 +08:00
|
|
|
}
|
|
|
|
return ptr_both_.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
Ptr* PtrBefore() {
|
|
|
|
if (ptr_before_ == nullptr) {
|
2020-07-20 22:05:24 +08:00
|
|
|
ptr_before_.reset(CreatePtr(kSyncBefore));
|
2019-03-19 00:21:48 +08:00
|
|
|
}
|
|
|
|
return ptr_before_.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
Ptr* PtrAfter() {
|
|
|
|
if (ptr_after_ == nullptr) {
|
2020-07-20 22:05:24 +08:00
|
|
|
ptr_after_.reset(CreatePtr(kSyncAfter));
|
2019-03-19 00:21:48 +08:00
|
|
|
}
|
|
|
|
return ptr_after_.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2021-10-11 20:37:34 +08:00
|
|
|
// Needed so that we can use unique_ptr with incomplete type.
|
|
|
|
struct PtrDeleter {
|
|
|
|
void operator()(Ptr* p);
|
|
|
|
};
|
|
|
|
|
|
|
|
// Necessary to implement creation of Ptr in inheriting class as it is
|
|
|
|
// incomplete type here.
|
|
|
|
virtual Ptr* CreatePtr(SyncType sync_type) = 0;
|
|
|
|
|
2019-03-19 00:21:48 +08:00
|
|
|
std::unique_ptr<Ptr, PtrDeleter> ptr_none_;
|
|
|
|
std::unique_ptr<Ptr, PtrDeleter> ptr_both_;
|
|
|
|
std::unique_ptr<Ptr, PtrDeleter> ptr_before_;
|
|
|
|
std::unique_ptr<Ptr, PtrDeleter> ptr_after_;
|
|
|
|
};
|
|
|
|
|
2019-11-20 20:39:44 +08:00
|
|
|
} // namespace sapi::v
|
2019-03-19 00:21:48 +08:00
|
|
|
|
|
|
|
#endif // SANDBOXED_API_VAR_POINTABLE_H_
|