1 /* 2 * Copyright (C) 2005 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 // 18 #ifndef ANDROID_ISERVICE_MANAGER_H 19 #define ANDROID_ISERVICE_MANAGER_H 20 21 #include <binder/IInterface.h> 22 #include <utils/Vector.h> 23 #include <utils/String16.h> 24 25 namespace android { 26 27 // ---------------------------------------------------------------------- 28 29 class IServiceManager : public IInterface 30 { 31 public: 32 DECLARE_META_INTERFACE(ServiceManager) 33 /** 34 * Must match values in IServiceManager.java 35 */ 36 /* Allows services to dump sections according to priorities. */ 37 static const int DUMP_FLAG_PRIORITY_CRITICAL = 1 << 0; 38 static const int DUMP_FLAG_PRIORITY_HIGH = 1 << 1; 39 static const int DUMP_FLAG_PRIORITY_NORMAL = 1 << 2; 40 /** 41 * Services are by default registered with a DEFAULT dump priority. DEFAULT priority has the 42 * same priority as NORMAL priority but the services are not called with dump priority 43 * arguments. 44 */ 45 static const int DUMP_FLAG_PRIORITY_DEFAULT = 1 << 3; 46 static const int DUMP_FLAG_PRIORITY_ALL = DUMP_FLAG_PRIORITY_CRITICAL | 47 DUMP_FLAG_PRIORITY_HIGH | DUMP_FLAG_PRIORITY_NORMAL | DUMP_FLAG_PRIORITY_DEFAULT; 48 static const int DUMP_FLAG_PROTO = 1 << 4; 49 50 /** 51 * Retrieve an existing service, blocking for a few seconds 52 * if it doesn't yet exist. 53 */ 54 virtual sp<IBinder> getService( const String16& name) const = 0; 55 56 /** 57 * Retrieve an existing service, non-blocking. 58 */ 59 virtual sp<IBinder> checkService( const String16& name) const = 0; 60 61 /** 62 * Register a service. 63 */ 64 // NOLINTNEXTLINE(google-default-arguments) 65 virtual status_t addService(const String16& name, const sp<IBinder>& service, 66 bool allowIsolated = false, 67 int dumpsysFlags = DUMP_FLAG_PRIORITY_DEFAULT) = 0; 68 69 /** 70 * Return list of all existing services. 71 */ 72 // NOLINTNEXTLINE(google-default-arguments) 73 virtual Vector<String16> listServices(int dumpsysFlags = DUMP_FLAG_PRIORITY_ALL) = 0; 74 75 enum { 76 GET_SERVICE_TRANSACTION = IBinder::FIRST_CALL_TRANSACTION, 77 CHECK_SERVICE_TRANSACTION, 78 ADD_SERVICE_TRANSACTION, 79 LIST_SERVICES_TRANSACTION, 80 }; 81 }; 82 83 sp<IServiceManager> defaultServiceManager(); 84 85 template<typename INTERFACE> 86 status_t getService(const String16& name, sp<INTERFACE>* outService) 87 { 88 const sp<IServiceManager> sm = defaultServiceManager(); 89 if (sm != nullptr) { 90 *outService = interface_cast<INTERFACE>(sm->getService(name)); 91 if ((*outService) != nullptr) return NO_ERROR; 92 } 93 return NAME_NOT_FOUND; 94 } 95 96 bool checkCallingPermission(const String16& permission); 97 bool checkCallingPermission(const String16& permission, 98 int32_t* outPid, int32_t* outUid); 99 bool checkPermission(const String16& permission, pid_t pid, uid_t uid); 100 101 }; // namespace android 102 103 #endif // ANDROID_ISERVICE_MANAGER_H 104 105