interface_sdk-js/api/@ohos.data.distributedDataObject.d.ts
wufengshan 1a7e2ea54e 删除api9权限废弃相关描述
Signed-off-by: wufengshan <wufengshan@huawei.com>
2022-06-01 09:39:34 +08:00

158 lines
5.3 KiB
TypeScript

/*
* Copyright (c) 2022 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.
*/
import {AsyncCallback, Callback} from './basic';
/**
* Provides interfaces to sync distributed object
*
* @name distributedDataObject
* @since 8
* @syscap SystemCapability.DistributedDataManager.DataObject.DistributedObject
*/
declare namespace distributedDataObject {
/**
* Create distributed object
*
* @param source Init data of distributed object
* @return Returns the distributed object
* @since 8
*/
function createDistributedObject(source: object): DistributedObject;
/**
* Generate a random sessionId
*
* @return Returns the random sessionId
* @since 8
*/
function genSessionId(): string;
/**
* @since 9
*/
interface SaveSuccessResponse {
/**
* sessionId of saved object
* @since 9
*/
sessionId: string;
/**
* version of saved object, can compare with DistributedObject.__version
* @since 9
*/
version: number;
/**
* deviceid that data saved
* data is "local", means save in local device
* otherwise, means the networkId of device
* @since 9
*/
deviceId: string;
}
/**
* @since 9
*/
interface RevokeSaveSuccessResponse {
/**
* @since 9
*/
sessionId: string;
}
/**
* Object create by {@link createDistributedObject}.
*
* @syscap SystemCapability.DistributedDataManager.DataObject.DistributedObject
* @since 8
*/
interface DistributedObject {
/*
* Change object session
*
* @param sessionId The sessionId to be joined, if empty, leave all session
* @return Operation result, true is success, false is failed
* @permission ohos.permission.DISTRIBUTED_DATASYNC
* @since 8
*/
setSessionId(sessionId?: string): boolean;
/**
* On watch of change
*
* @param callback The callback of change
* @since 8
*/
on(type: 'change', callback: Callback<{ sessionId: string, fields: Array<string> }>): void;
/**
* Off watch of change
*
* @param callback If not null, off the callback, if undefined, off all callbacks
* @since 8
*/
off(type: 'change', callback?: Callback<{ sessionId: string, fields: Array<string> }>): void;
/**
* On watch of status
*
* @param callback Indicates the observer of object status changed.
* sessionId: The sessionId of the changed object
* networkId: NetworkId of the changed device
* status: 'online' The object became online on the device and data can be synced to the device
* 'offline' The object became offline on the device and the object can not sync any data
* @since 8
*/
on(type: 'status', callback: Callback<{ sessionId: string, networkId: string, status: 'online' | 'offline' }>): void;
/**
* Off watch of status
*
* @param callback If not null, off the callback, if undefined, off all callbacks
* @since 8
*/
off(type: 'status', callback?: Callback<{ sessionId: string, deviceId: string, status: 'online' | 'offline' }>): void;
/**
* Save object, after save object data successfully, the object data will not release when app existed, and resume data on saved device after app existed
* the saved data secure level is S0, it is not safe, can only save public data, if there is privacy data, you should encrypt it
*
* the saved data will be released when
* 1. saved after 24h
* 2. app uninstalled
* 3. after resume data success, system will auto delete the saved data
*
* @param deviceId Indicates the device that will resume the object data
* @since 9
*/
save(deviceId: string, callback: AsyncCallback<SaveSuccessResponse>): void;
save(deviceId: string): Promise<SaveSuccessResponse>;
/**
* Revoke save object, delete saved object immediately, if object is saved in local device, it will delete saved data on all trusted device
* if object is saved in other device, it will delete data in local device.
*
* @since 9
*/
revokeSave(callback: AsyncCallback<RevokeSaveSuccessResponse>): void;
revokeSave(): Promise<RevokeSaveSuccessResponse>;
}
}
export default distributedDataObject;