/* * Copyright (C) 2015 The Android Open Source Project * * 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 SYSTEM_CORE_INCLUDE_BINDERWRAPPER_BINDER_WRAPPER_H_ #define SYSTEM_CORE_INCLUDE_BINDERWRAPPER_BINDER_WRAPPER_H_ #include <sys/types.h> #include <string> #include <base/callback.h> #include <utils/StrongPointer.h> namespace android { class BBinder; class IBinder; // Wraps libbinder to make it testable. // NOTE: Static methods of this class are not thread-safe. class BinderWrapper { public: virtual ~BinderWrapper() {} // Creates and initializes the singleton (using a wrapper that communicates // with the real binder system). static void Create(); // Initializes |wrapper| as the singleton, taking ownership of it. Tests that // want to inject their own wrappers should call this instead of Create(). static void InitForTesting(BinderWrapper* wrapper); // Destroys the singleton. Must be called before calling Create() or // InitForTesting() a second time. static void Destroy(); // Returns the singleton instance previously created by Create() or set by // InitForTesting(). static BinderWrapper* Get(); // Returns the singleton instance if it was previously created by Create() or // set by InitForTesting(), or creates a new one by calling Create(). static BinderWrapper* GetOrCreateInstance(); // Gets the binder for communicating with the service identified by // |service_name|, returning null immediately if it doesn't exist. virtual sp<IBinder> GetService(const std::string& service_name) = 0; // Registers |binder| as |service_name| with the service manager. virtual bool RegisterService(const std::string& service_name, const sp<IBinder>& binder) = 0; // Creates a local binder object. virtual sp<BBinder> CreateLocalBinder() = 0; // Registers |callback| to be invoked when |binder| dies. If another callback // is currently registered for |binder|, it will be replaced. virtual bool RegisterForDeathNotifications( const sp<IBinder>& binder, const ::base::Closure& callback) = 0; // Unregisters the callback, if any, for |binder|. virtual bool UnregisterForDeathNotifications(const sp<IBinder>& binder) = 0; // When called while in a transaction, returns the caller's UID or PID. virtual uid_t GetCallingUid() = 0; virtual pid_t GetCallingPid() = 0; private: static BinderWrapper* instance_; }; } // namespace android #endif // SYSTEM_CORE_INCLUDE_BINDERWRAPPER_BINDER_WRAPPER_H_