/* * Copyright (C) 2021 Huawei Device Co., Ltd. * 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. */ /** * A data object used for remote procedure call (RPC). *
* During RPC, the sender can use the write methods provided by {@link MessageParcel} to * write the to-be-sent data into a {@link MessageParcel} object in a specific format, and the receiver can use the * read methods provided by {@link MessageParcel} to read data of the specific format from the {@link MessageParcel} object. *
*
* The default capacity of a {@link MessageParcel} instance is 200KB. If you want more or less, use {@link #setCapacity(int)} * to change it. *
* Note: Only data of the following data types can be written into or read from a {@link MessageParcel}: byte, * byteArray, short, shortArray, int, intArray, long, longArray, float, floatArray, double, doubleArray, boolean, * booleanArray, char, charArray, String, StringArray, {@link PlainBooleanArray}, {@link Serializable}, * {@link Sequenceable}, and SequenceableArray. * * @since 7 * @sysCap SystemCapability.RPC * @devices phone, tablet, tv, wearable, car * @import import rpc from '@ohos.rpc'; */ declare namespace rpc { class MessageParcel { /** * Creates an empty {@link MessageParcel} object with index 0. * @sysCap SystemCapability.RPC_MessageParcel * @devices phone, tablet, tv, wearable, car * @since 7 */ static create(): MessageParcel; /** * Clears data in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @devices phone, tablet, tv, wearable, car * @since 7 */ reclaim(): void; /** * Serializes a remote object and writes it to the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @devices phone, tablet, tv, wearable, car * @since 7 */ writeRemoteObject(object: IRemoteObject): boolean; /** * Reads a remote object from {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @devices phone, tablet, tv, wearable, car * @since 7 */ readRemoteObject(): IRemoteObject; /** * Writes an interface token into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns {@code true} if the interface token has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeInterfaceToken(token: string): boolean; /** * Reads an interface token from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a string value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readInterfaceToken(): string; /** * Obtains the size of data (in bytes) contained in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns the size of data contained in the {@link MessageParcel} object. * @devices phone, tablet, tv, wearable, car * @since 7 */ getSize(): number; /** * Obtains the storage capacity (in bytes) of the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns the storage capacity of the {@link MessageParcel} object. * @devices phone, tablet, tv, wearable, car * @since 7 */ getCapacity(): number; /** * Sets the size of data (in bytes) contained in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *{@code false} is returned if the data size set in this method is greater * than the storage capacity of the {@link MessageParcel}. * * @param size Indicates the data size of the {@link MessageParcel} object. * @return Returns {@code true} if the setting is successful; returns {@code false} otherwise. * @devices phone, tablet, tv, wearable, car * @since 7 */ setSize(size: number): boolean; /** * Sets the storage capacity (in bytes) of the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *
{@code false} is returned if the capacity set in this method is less than * the size of data contained in the {@link MessageParcel}. * * @param size Indicates the storage capacity of the {@link MessageParcel} object. * @return Returns {@code true} if the setting is successful; returns {@code false} otherwise. * @devices phone, tablet, tv, wearable, car * @since 7 */ setCapacity(size: number): boolean; /** * Obtains the writable data space (in bytes) in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *
Writable data space = Storage capacity of the {@link MessageParcel} - Size of data contained in the {@link MessageParcel}. * * @return Returns the writable data space of the {@link MessageParcel} object. * @devices phone, tablet, tv, wearable, car * @since 7 */ getWritableBytes(): number; /** * Obtains the readable data space (in bytes) in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *
Readable data space = Size of data contained in the {@link MessageParcel} - Size of data that has been read. * * @return Returns the readable data space of the {@link MessageParcel} object. * @devices phone, tablet, tv, wearable, car * @since 7 */ getReadableBytes(): number; /** * Obtains the current read position in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns the current read position in the {@link MessageParcel} object. * @devices phone, tablet, tv, wearable, car * @since 7 */ getReadPosition(): number; /** * Obtains the current write position in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns the current write position in the {@link MessageParcel} object. * @devices phone, tablet, tv, wearable, car * @since 7 */ getWritePosition(): number; /** * Changes the current read position in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *
Generally, you are advised not to change the current read position. If you must * change it, change it to an accurate position. Otherwise, the read data may be incorrect. * * @param pos Indicates the target position to start data reading. * @return Returns {@code true} if the read position is changed; returns {@code false} otherwise. * @devices phone, tablet, tv, wearable, car * @since 7 */ rewindRead(pos: number): boolean; /** * Changes the current write position in the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *
Generally, you are advised not to change the current write position. If you must * change it, change it to an accurate position. Otherwise, the data to be read may be incorrect. * * @param pos Indicates the target position to start data writing. * @return Returns {@code true} if the write position is changed; returns {@code false} otherwise. * @devices phone, tablet, tv, wearable, car * @since 7 */ rewindWrite(pos: number): boolean; /** * Writes a byte value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the byte value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeByte(val: number): boolean; /** * Writes a short integer value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the short integer value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeShort(val: number): boolean; /** * Writes an integer value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the integer value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeInt(val: number): boolean; /** * Writes a long integer value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the long integer value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeLong(val: number): boolean; /** * Writes a floating point value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the floating point value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeFloat(val: number): boolean; /** * Writes a double-precision floating point value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the double-precision floating point value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeDouble(val: number): boolean; /** * Writes a boolean value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the boolean value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeBoolean(val: boolean): boolean; /** * Writes a single character value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the single character value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeChar(val: number): boolean; /** * Writes a string value into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the string value to write. * @return Returns {@code true} if the value has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeString(val: string): boolean; /** * Writes a {@link Sequenceable} object into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param val Indicates the {@link Sequenceable} object to write. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeSequenceable(val: Sequenceable): boolean; /** * Writes a byte array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param byteArray Indicates the byte array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeByteArray(byteArray: number[]): boolean; /** * Writes a short integer array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param shortArray Indicates the short integer array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeShortArray(shortArray: number[]): boolean; /** * Writes an integer array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param intArray Indicates the integer array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeIntArray(intArray: number[]): boolean; /** * Writes a long integer array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param longArray Indicates the long integer array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeLongArray(longArray: number[]): boolean; /** * Writes a floating point array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param floatArray Indicates the floating point array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeFloatArray(floatArray: number[]): boolean; /** * Writes a double-precision floating point array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param doubleArray Indicates the double-precision floating point array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeDoubleArray(doubleArray: number[]): boolean; /** * Writes a boolean array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param booleanArray Indicates the boolean array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeBooleanArray(booleanArray: boolean[]): boolean; /** * Writes a single character array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param charArray Indicates the single character array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeCharArray(charArray: number[]): boolean; /** * Writes a string array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param stringArray Indicates the string array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeStringArray(stringArray: string[]): boolean; /** * Writes a {@link Sequenceable} object array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param sequenceableArray Indicates the {@link Sequenceable} object array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this parcel is insufficient, * exception message: {@link ParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ writeSequenceableArray(sequenceableArray: Sequenceable[]): boolean; /** * Reads a byte value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a byte value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readByte(): number; /** * Reads a short integer value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a short integer value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readShort(): number; /** * Reads an integer value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns an integer value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readInt(): number; /** * Reads a long integer value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a long integer value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readLong(): number; /** * Reads a floating point value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a floating point value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readFloat(): number; /** * Reads a double-precision floating point value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a double-precision floating point value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readDouble(): number; /** * Reads a boolean value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a boolean value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readBoolean(): boolean; /** * Reads a single character value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a single character value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readChar(): number; /** * Reads a string value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a string value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readString(): string; /** * Reads a short string value from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a short string value. * @devices phone, tablet, tv, wearable, car * @since 7 */ readSequenceable(dataIn: Sequenceable) : boolean; /** * Writes a byte array into the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the byte array to write. * @return Returns {@code true} if the array has been written into the {@link MessageParcel}; * returns {@code false} otherwise. * @throws ParcelException When capacity in this MessageParcel is insufficient, * exception message: {@link MessageParcelException#NO_CAPACITY_ERROR}. * @devices phone, tablet, tv, wearable, car * @since 7 */ readByteArray(dataIn: number[]) : void; /** * Reads a byte array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a byte array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readByteArray(): number[]; /** * Reads all bytes from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel *
This method is different from the {@code readByteArray} method. In this method, * the {@code MessageParcel} cannot call other methods to read data, and this method can only * read data written by using {@link #writeBytes}. * @return Returns the bytes. * @devices phone, tablet, tv, wearable, car * @since 7 */ readShortArray(dataIn: number[]) : void; /** * Reads a short integer array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a short integer array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readShortArray(): number[]; /** * Reads an integer array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the integer array to read. * @throws ParcelException Throws this exception if reading the integer array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readIntArray(dataIn: number[]) : void; /** * Reads an integer array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns an integer array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readIntArray(): number[]; /** * Reads a long integer array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the long integer array to read. * @throws ParcelException Throws this exception if reading the long array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readLongArray(dataIn: number[]) : void; /** * Reads a long integer array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a long integer array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readLongArray(): number[]; /** * Reads a floating point array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the floating point array to read. * @throws ParcelException Throws this exception if reading the float array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readFloatArray(dataIn: number[]) : void; /** * Reads a floating point array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a floating point array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readFloatArray(): number[]; /** * Reads a double-precision floating point array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the double-precision floating point array to read. * @throws ParcelException Throws this exception if reading the double array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readDoubleArray(dataIn: number[]) : void; /** * Reads a double-precision floating point array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a double-precision floating point array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readDoubleArray(): number[]; /** * Reads a boolean array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the boolean array to read. * @throws ParcelException Throws this exception if reading the boolean array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readBooleanArray(dataIn: boolean[]) : void; /** * Reads a boolean array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a boolean array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readBooleanArray(): boolean[]; /** * Reads a single character array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the single character array to read. * @throws ParcelException Throws this exception if reading the char array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readCharArray(dataIn: boolean[]) : void; /** * Reads a single character array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a single character array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readCharArray(): boolean[]; /** * Reads a string array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @param dataIn Indicates the string array to read. * @throws ParcelException Throws this exception if reading the string array fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ readStringArray(dataIn: string[]) : void; /** * Reads a string array from the {@link MessageParcel} object. * @sysCap SystemCapability.RPC_MessageParcel * @return Returns a string array. * @devices phone, tablet, tv, wearable, car * @since 7 */ readStringArray(): string[]; } interface Sequenceable { /** * Marshals this {@code Sequenceable} object into a {@link MessageParcel}. * * @sysCap SystemCapability.RPC_Sequenceable * @param dataOut Indicates the {@link MessageParcel} object to which the {@code Sequenceable} * object will be marshaled.. * @return Returns {@code true} if the marshalling is successful; returns {@code false} otherwise. * @throws ParcelException Throws this exception if the operation fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ marshalling(dataOut: MessageParcel): boolean; /** * Unmarshals this {@code Sequenceable} object from a {@link MessageParcel}. * * @sysCap SystemCapability.RPC_Sequenceable * @param dataIn Indicates the {@link MessageParcel} object into which the {@code Sequenceable} * object has been marshaled.. * @return Returns {@code true} if the unmarshalling is successful; returns {@code false} otherwise. * @throws ParcelException Throws this exception if the operation fails. * @devices phone, tablet, tv, wearable, car * @since 7 */ unmarshalling(dataIn: MessageParcel) : boolean; } interface IRemoteObject { /** * Queries the description of an interface. * *
A valid {@link IRemoteBroker} object is returned for an interface used by the service provider; * {@code null} is returned for an interface used by the service user, * indicating that the interface is not a local one. * * @param descriptor Indicates a string of the interface descriptor. * @return Returns the {@link IRemoteBroker} object bound to the specified interface descriptor. * @since 7 */ queryLocalInterface(descriptor: string): IRemoteBroker; /** * Sends a {@link MessageParcel} message to the peer process in synchronous or asynchronous mode. * *
If asynchronous mode is set for {@code option}, a response is returned immediately.
* If synchronous mode is set for {@code option}, the interface will wait for a response from the peer process
* until the request times out. The user must prepare {@code reply} for receiving the execution result
* given by the peer process.
*
* @param code Indicates the message code, which is determined by both sides of the communication.
* If the interface is generated by the IDL tool, the message code is automatically generated by IDL.
* @param data Indicates the {@link MessageParcel} object sent to the peer process.
* @param reply Indicates the {@link MessageParcel} object returned by the peer process.
* @param options Indicates the synchronous or asynchronous mode to send messages.
* @return Returns a promise.
* @throws RemoteException Throws this exception if the method fails to be called.
* @since 7
*/
sendRequest(code: number, data: MessageParcel, reply: MessageParcel, options: MessageOption): Promise This method is called if the remote object process matching the {@link RemoteProxy} object dies.
*
* @param recipient Indicates the callback to be registered.
* @param flags Indicates the flag of the death notification.
* @return Returns {@code true} if the callback is registered successfully; returns {@code false} otherwise.
* @since 7
*/
addDeathRecipient(recipient: DeathRecipient, flags: number): boolean;
/**
* Deregisters a callback used to receive notifications of the death of a remote object.
*
* @param recipient Indicates the callback to be deregistered.
* @param flags Indicates the flag of the death notification.
* @return Returns {@code true} if the callback is deregistered successfully; returns {@code false} otherwise.
* @since 7
*/
removeDeathRecipient(recipient: DeathRecipient, flags: number): boolean;
/**
* Obtains the interface descriptor of an object.
*
* The interface descriptor is a character string.
*
* @return Returns the interface descriptor.
* @since 7
*/
getInterfaceDescriptor(): string;
/**
* Checks whether an object is dead.
*
* @return Returns {@code true} if the object is dead; returns {@code false} otherwise.
* @since 7
*/
isObjectDead(): boolean;
}
interface IRemoteBroker {
/**
* Obtains a proxy or remote object. This method must be implemented by its derived classes.
*
* @return Returns the RemoteObject if the caller is a RemoteObject; returns the IRemoteObject,
* that is, the holder of this RemoteProxy object, if the caller is a RemoteProxy object.
* @since 7
*/
asObject(): IRemoteObject;
}
interface DeathRecipient {
/**
* Called to perform subsequent operations when a death notification of the remote object is received.
*
* @since 7
*/
onRemoteDied(): void;
}
class MessageOption {
/**
* Indicates synchronous call.
*/
TF_SYNC = 0,
/**
* Indicates asynchronous call.
*/
TF_ASYNC = 1,
/**
* Indicates the sendRequest API for returning the file descriptor.
*/
TF_ACCEPT_FDS = 0x10,
/**
* Indicates the wait time for RPC, in seconds.
*/
TF_WAIT_TIME = 8,
/**
* A constructor used to create a MessageOption instance.
*
* @param syncFlags Specifies whether the SendRequest is called synchronously (default) or asynchronously.
* @param waitTime Maximum wait time for a RPC call. The default value is TF_WAIT_TIME.
* @since 7
*/
constructor(syncFlags?: number, waitTime = TF_WAIT_TIME);
/**
* Obtains the SendRequest call flag, which can be synchronous or asynchronous.
*
* @return Returns whether the SendRequest is called synchronously or asynchronously.
* @since 7
*/
getFlags(): number;
/**
* Sets the SendRequest call flag, which can be synchronous or asynchronous.
*
* @param flags Indicates the call flag, which can be synchronous or asynchronous.
* @since 7
*/
setFlags(flags: number): void;
/**
* Obtains the maximum wait time for this RPC call.
*
* @return Returns maximum wait time obtained.
* @since 7
*/
getWaitTime(): number;
/**
* Sets the maximum wait time for this RPC call.
*
* @param waitTime Indicates maximum wait time to set.
* @since 7
*/
setWaitTime(waitTime: number): void;
}
class RemoteObject implements IRemoteObject {
/**
* A constructor to create a RemoteObject instance.
*
* @param descriptor Specifies interface descriptor.
* @since 7
*/
constructor(descriptor: string);
/**
* Queries a remote object using an interface descriptor.
*
* @param descriptor Indicates the interface descriptor used to query the remote object.
* @return Returns the remote object matching the interface descriptor; returns null
* if no such remote object is found.
* @since 7
*/
queryLocalInterface(interface: string): IRemoteObject;
/**
* Queries an interface descriptor.
*
* @return Returns the interface descriptor.
* @since 7
*/
getInterfaceDescriptor(): string;
/**
* Sets an entry for receiving requests.
*
* This method is implemented by the remote service provider. You need to override this method with
* your own service logic when you are using IPC.
*
* @param code Indicates the service request code sent from the peer end.
* @param data Indicates the {@link MessageParcel} object sent from the peer end.
* @param reply Indicates the response message object sent from the remote service.
* The local service writes the response data to the {@link MessageParcel} object.
* @param options Indicates whether the operation is synchronous or asynchronous.
* @return Returns {@code true} if the operation succeeds; returns {@code false} otherwise.
* @throws RemoteException Throws this exception if a remote service error occurs.
* @since 7
*/
onRemoteRequest(code: number, data: MessageParcel, reply: MessageParcel, options: MessageOption): boolean;
/**
* Sends a request to the peer object.
*
* If the peer object and {@code RemoteObject} are on the same device, the request is sent by the IPC driver.
* If they are on different devices, the request is sent by the socket driver.
*
* @param code Indicates the message code of the request.
* @param data Indicates the {@link MessageParcel} object storing the data to be sent.
* @param reply Indicates the {@link MessageParcel} object receiving the response data.
* @param options Indicates a synchronous (default) or asynchronous request.
* @return Returns a promise.
* @since 7
*/
sendRequest(code: number, data: MessageParcel, reply: MessageParcel, options: MessageOption): Promise This method is used to change the default descriptor specified during the creation of {@code RemoteObject}.
*
* @param localInterface Indicates the {@code RemoteObject} whose descriptor is to be changed.
* @param descriptor Indicates the new descriptor of the {@code RemoteObject}.
* @since 7
*/
attachLocalInterface(localInterface: IRemoteBroker, descriptor: string): void;
}
class RemoteProxy implements IRemoteObject {
/**
* Indicates the message code for a Ping operation.
*/
PING_TRANSACTION = ('_' << 24) | ('P' << 16) | ('N' << 8) | 'G',
/**
* Indicates the message code for a dump operation.
*/
DUMP_TRANSACTION = ('_' << 24) | ('D' << 16) | ('M' << 8) | 'P',
/**
* Indicates the message code for a transmission.
*/
INTERFACE_TRANSACTION = ('_' << 24) | ('N' << 16) | ('T' << 8) | 'F',
/**
* Indicates the minimum value of a valid message code.
*
* This constant is used to check the validity of an operation.
*/
MIN_TRANSACTION_ID = 0x1,
/**
* Indicates the maximum value of a valid message code.
*
* This constant is used to check the validity of an operation.
*/
MAX_TRANSACTION_ID = 0x00FFFFFF,
/**
* Queries a local interface with a specified descriptor.
*
* @param descriptor Indicates the descriptor of the interface to query.
* @return Returns null by default, indicating a proxy interface.
* @since 7
*/
queryLocalInterface(interface: string): IRemoteObject;
/**
* Registers a callback used to receive death notifications of a remote object.
*
* @param recipient Indicates the callback to be registered.
* @param flags Indicates the flag of the death notification. This is a reserved parameter. Set it to {@code 0}.
* @return Returns {@code true} if the callback is registered successfully; returns {@code false} otherwise.
* @since 7
*/
addDeathRecipient(recipient: DeathRecipient, flags: number): boolean;
/**
* Deregisters a callback used to receive death notifications of a remote object.
*
* @param recipient Indicates the callback to be deregistered.
* @param flags Indicates the flag of the death notification. This is a reserved parameter. Set it to {@code 0}.
* @return Returns {@code true} if the callback is deregistered successfully; returns {@code false} otherwise.
* @since 7
*/
removeDeathRecipient(recipient: DeathRecipient, flags: number): boolean;
/**
* Queries the interface descriptor of remote object.
*
* @return Returns the interface descriptor.
* @since 7
*/
getInterfaceDescriptor(): string;
/**
* Sends a request to the peer object.
*
* If the peer object and {@code RemoteProxy} are on the same device, the request is sent by the IPC driver.
* If they are on different devices, the request is sent by the socket driver.
*
* @param code Indicates the message code of the request.
* @param data Indicates the {@link MessageParcel} object storing the data to be sent.
* @param reply Indicates the {@link MessageParcel} object receiving the response data.
* @param options Indicates a synchronous (default) or asynchronous request.
* @return Returns a promise.
* @throws RemoteException Throws this exception if a remote object exception occurs.
* @since 7
*/
sendRequest(code: number, data: MessageParcel, reply: MessageParcel, options: MessageOption): Promise This method is static.
*
* @return Returns an {@link IRemoteObject} reference of the registered service.
* @since 7
*/
static getContextObject(): IRemoteObject;
/**
* Obtains the PID of a proxy.
*
* This method is static. The PID is a positive integer during the communication between
* the {@link RemoteProxy} object and {@link RemoteObject} object, and resumes to {@code 0}
* when the communication ends. If this method is called from the {@link RemoteProxy} object,
* {@code 0} is returned; if this method is called from the {@link RemoteObject} object,
* the PID of the corresponding {@link RemoteProxy} object is returned.
*
* @return Returns the PID of the proxy.
* @since 7
*/
static getCallingPid(): number;
/**
* Obtains the UID of a proxy.
*
* This method is static. The UID is a positive integer during the communication between
* the {@link RemoteProxy} object and {@link RemoteObject} object, and resumes to {@code 0}
* when the communication ends. If this method is called from the {@link RemoteProxy} object,
* {@code 0} is returned; if this method is called from the {@link RemoteObject} object,
* the UID of the corresponding {@link RemoteProxy} object is returned.
*
* @return Returns the UID of the proxy.
* @since 7
*/
static getCallingUid(): number;
/**
* Obtains the ID of the device where the peer process resides.
*
* This method is static.
*
* @return Returns the ID of the device where the peer process resides.
* @since 7
*/
static getCallingDeviceID(): string;
/**
* Obtains the ID of the local device.
*
* This method is static.
*
* @return Returns the ID of the local device.
* @since 7
*/
static getLocalDeviceID(): string;
/**
* Checks whether a call is made on the same device.
*
* This method is static.
*
* @return Returns {@code true} if the call is made on the same device; returns {@code false} otherwise.
* @since 7
*/
static isLocalCalling(): boolean;
/**
* Flushes all pending commands from a specified {@link RemoteProxy} to the corresponding {@link RemoteObject}.
*
* This method is static. You are advised to call this method before performing any time-sensitive operations.
*
* @param object Indicates the specified {@link RemoteProxy}.
* @return Returns {@code 0} if the operation succeeds; returns an error code if the input object is empty
* or {@link RemoteObject}, or the operation fails.
* @since 7
*/
static flushCommands(object: IRemoteObject): number;
/**
* Replaces the UID and PID of the remote user with those of the local user.
*
* This method is static. It can be used in scenarios like authentication.
*
* @return Returns a string containing the UID and PID of the remote user.
* @since 7
*/
static resetCallingIdentity(): string;
/**
* Restores the UID and PID to those of the remote user.
*
* This method is static. It is usually called after {@code resetCallingIdentity} is used
* and requires the UID and PID of the remote user returned by {@code resetCallingIdentity}.
*
* @param identity Indicates the string containing the UID and PID of the remote user,
* which is returned by {@code resetCallingIdentity}.
* @return Returns {@code true} if the operation succeeds; returns {@code false} otherwise.
* @since 7
*/
static setCallingIdentity(identity: string): boolean;
}
}
export default rpc;