1 /* 2 * Copyright (C) 2007 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 package android.content.pm; 18 19 import android.os.Parcel; 20 import android.os.Parcelable; 21 import android.util.Printer; 22 23 /** 24 * Information you can retrieve about a particular application 25 * service. This corresponds to information collected from the 26 * AndroidManifest.xml's <service> tags. 27 */ 28 public class ServiceInfo extends ComponentInfo 29 implements Parcelable { 30 /** 31 * Optional name of a permission required to be able to access this 32 * Service. From the "permission" attribute. 33 */ 34 public String permission; 35 36 /** 37 * Bit in {@link #flags}: If set, the service will automatically be 38 * stopped by the system if the user removes a task that is rooted 39 * in one of the application's activities. Set from the 40 * {@link android.R.attr#stopWithTask} attribute. 41 */ 42 public static final int FLAG_STOP_WITH_TASK = 0x0001; 43 44 /** 45 * Bit in {@link #flags}: If set, the service will run in its own 46 * isolated process. Set from the 47 * {@link android.R.attr#isolatedProcess} attribute. 48 */ 49 public static final int FLAG_ISOLATED_PROCESS = 0x0002; 50 51 /** 52 * Bit in {@link #flags}: If set, the service can be bound and run in the 53 * calling application's package, rather than the package in which it is 54 * declared. Set from {@link android.R.attr#externalService} attribute. 55 */ 56 public static final int FLAG_EXTERNAL_SERVICE = 0x0004; 57 58 /** 59 * Bit in {@link #flags} indicating if the service is visible to ephemeral applications. 60 * @hide 61 */ 62 public static final int FLAG_VISIBLE_TO_INSTANT_APP = 0x100000; 63 64 /** 65 * Bit in {@link #flags}: If set, a single instance of the service will 66 * run for all users on the device. Set from the 67 * {@link android.R.attr#singleUser} attribute. 68 */ 69 public static final int FLAG_SINGLE_USER = 0x40000000; 70 71 /** 72 * Options that have been set in the service declaration in the 73 * manifest. 74 * These include: 75 * {@link #FLAG_STOP_WITH_TASK}, {@link #FLAG_ISOLATED_PROCESS}, 76 * {@link #FLAG_SINGLE_USER}. 77 */ 78 public int flags; 79 ServiceInfo()80 public ServiceInfo() { 81 } 82 ServiceInfo(ServiceInfo orig)83 public ServiceInfo(ServiceInfo orig) { 84 super(orig); 85 permission = orig.permission; 86 flags = orig.flags; 87 } 88 dump(Printer pw, String prefix)89 public void dump(Printer pw, String prefix) { 90 dump(pw, prefix, DUMP_FLAG_ALL); 91 } 92 93 /** @hide */ dump(Printer pw, String prefix, int dumpFlags)94 void dump(Printer pw, String prefix, int dumpFlags) { 95 super.dumpFront(pw, prefix); 96 pw.println(prefix + "permission=" + permission); 97 pw.println(prefix + "flags=0x" + Integer.toHexString(flags)); 98 super.dumpBack(pw, prefix, dumpFlags); 99 } 100 toString()101 public String toString() { 102 return "ServiceInfo{" 103 + Integer.toHexString(System.identityHashCode(this)) 104 + " " + name + "}"; 105 } 106 describeContents()107 public int describeContents() { 108 return 0; 109 } 110 writeToParcel(Parcel dest, int parcelableFlags)111 public void writeToParcel(Parcel dest, int parcelableFlags) { 112 super.writeToParcel(dest, parcelableFlags); 113 dest.writeString(permission); 114 dest.writeInt(flags); 115 } 116 117 public static final Creator<ServiceInfo> CREATOR = 118 new Creator<ServiceInfo>() { 119 public ServiceInfo createFromParcel(Parcel source) { 120 return new ServiceInfo(source); 121 } 122 public ServiceInfo[] newArray(int size) { 123 return new ServiceInfo[size]; 124 } 125 }; 126 ServiceInfo(Parcel source)127 private ServiceInfo(Parcel source) { 128 super(source); 129 permission = source.readString(); 130 flags = source.readInt(); 131 } 132 } 133