harmony 鸿蒙@ohos.distributedDeviceManager (Device Management)

  • 2023-10-30
  • 浏览 (620)

@ohos.distributedDeviceManager (Device Management)

The deviceManager module provides APIs for distributed device management.

Applications can call the APIs to:

  • Subscribe to or unsubscribe from device state changes.
  • Discover untrusted devices nearby.
  • Authenticate or deauthenticate a device.
  • Query the trusted device list.
  • Query local device information, including the device name, type, and ID.

NOTE

The initial APIs of this module are supported since API version 10. Newly added APIs will be marked with a superscript to indicate their earliest API version.

Modules to Import

import deviceManager from '@ohos.distributedDeviceManager';

deviceManager.createDeviceManager

createDeviceManager(bundleName: string): DeviceManager;

Creates a DeviceManager instance. The DeviceManager instance is the entry for invoking the APIs for distributed device management. It can be used to obtain information about trusted devices and local devices.

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
bundleName string Yes Bundle name of the application.

Return value

Name Description
DeviceManager DeviceManager instance created.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  try {
    let dmInstance = deviceManager.createDeviceManager("ohos.samples.jshelloworld");
  } catch(err) {
    let e: BusinessError = err as BusinessError;
    console.error("createDeviceManager errCode:" + e.code + ",errMessage:" + e.message);
  }

deviceManager.releaseDeviceManager

releaseDeviceManager(deviceManager: DeviceManager): void;

Releases a DeviceManager instance that is no longer used.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
deviceManager DeviceManager Yes DeviceManager instance to release.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'
  import deviceManager from '@ohos.distributedDeviceManager'

  try {
    let dmInstance = deviceManager.createDeviceManager("ohos.samples.jshelloworld");
    deviceManager.releaseDeviceManager(dmInstance);
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("release device manager errCode:" + e.code + ",errMessage:" + e.message);
  }

DeviceBasicInfo

Represents the basic information about a distributed device.

System capability: SystemCapability.DistributedHardware.DeviceManager

Name Type Mandatory Description
deviceId string Yes Unique ID of the device. The value is the udid-hash (hash value of the UDID) and appid encrypted using SHA-256.
deviceName string Yes Device name.
deviceType string Yes Device type.
networkId string No Network ID of the device.

DeviceStateChange

Enumerates the device states.

System capability: SystemCapability.DistributedHardware.DeviceManager

Name Value Description
UNKNOWN 0 The device state is unknown after the device goes online. Before the device state changes to available, distributed services cannot be used.
AVAILABLE 1 The information between devices has been synchronized in the Distributed Data Service (DDS) module, and the device is ready for running distributed services.
UNAVAILABLE 2 The device goes offline, and the device state is unknown.

DeviceManager

Provides APIs to obtain information about trusted devices and local devices. Before calling any API in DeviceManager, you must use createDeviceManager to create a DeviceManager instance, for example, dmInstance.

getAvailableDeviceListSync

getAvailableDeviceListSync(): Array<DeviceBasicInfo>;

Obtains all trusted devices synchronously.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Return value

Name Description
Array<DeviceBasicInfo> List of trusted devices obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  try {
    let deviceInfoList: Array<deviceManager.DeviceBasicInfo> = dmInstance.getAvailableDeviceListSync();
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getAvailableDeviceListSync errCode:" + e.code + ",errMessage:" + e.message);
  }

getAvailableDeviceList

getAvailableDeviceList(callback:AsyncCallback&lt;Array&lt;DeviceBasicInfo&gt;&gt;): void;

Obtains all trusted devices. This API uses an asynchronous callback to return the result.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
callback AsyncCallback&lt;Array&lt;DeviceBasicInfo&gt;&gt; Yes Callback invoked to return the list of trusted devices.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  try {
    dmInstance.getAvailableDeviceList((err: BusinessError, data: Array<deviceManager.DeviceBasicInfo>) => {
      if (err) {
        console.error("getAvailableDeviceList errCode:" + err.code + ",errMessage:" + err.message);
        return;
      }
      console.log('get available device info: ' + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getAvailableDeviceList errCode:" + e.code + ",errMessage:" + e.message);
  }

getAvailableDeviceList

getAvailableDeviceList(): Promise&lt;Array&lt;DeviceBasicInfo&gt;&gt;;

Obtains all trusted devices. This API uses a promise to return the result.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Return value

Type Description
Promise&lt;Array&lt;DeviceBasicInfo&gt;&gt; Promise used to return the result.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  dmInstance.getAvailableDeviceList().then((data: Array<deviceManager.DeviceBasicInfo>) => {
    console.log('get available device info: ' + JSON.stringify(data));
    }).catch((err: BusinessError) => {
      console.error("getAvailableDeviceList errCode:" + err.code + ",errMessage:" + err.message);
  });

getLocalDeviceNetworkId

getLocalDeviceNetworkId(): string;

Obtains the network ID of the local device.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Return value

Name Description
string Network ID of the local device obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    let deviceNetworkId: string = dmInstance.getLocalDeviceNetworkId();
    console.log('local device networkId: ' + JSON.stringify(deviceNetworkId));
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getLocalDeviceNetworkId errCode:" + e.code + ",errMessage:" + e.message);
  }

getLocalDeviceName

getLocalDeviceName(): string;

Obtains the local device name.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Return value

Name Description
string Name of the local device obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    let deviceName: string = dmInstance.getLocalDeviceName();
    console.log('local device name: ' + JSON.stringify(deviceName));
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getLocalDeviceName errCode:" + e.code + ",errMessage:" + e.message);
  }

getLocalDeviceType

getLocalDeviceType(): number;

Obtains the local device type.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Return value

Name Description
number Local device type obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    let deviceType: number = dmInstance.getLocalDeviceType();
    console.log('local device type: ' + JSON.stringify(deviceType));
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getLocalDeviceType errCode:" + e.code + ",errMessage:" + e.message);
  }

getLocalDeviceId

getLocalDeviceId(): string;

Obtains the local device ID.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Return value

Name Description
string Local device ID obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    let deviceId: string = dmInstance.getLocalDeviceId();
    console.log('local device id: ' + JSON.stringify(deviceId));
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getLocalDeviceId errCode:" + e.code + ",errMessage:" + e.message);
  }

getDeviceName

getDeviceName(networkId: string): string;

Obtains the device name based on the network ID of the specified device.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
networkId string Yes Network ID of the device.

Return value

Name Description
string Device name obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    // Network ID of the device, which can be obtained from the trusted device list.
    let networkId = "xxxxxxx"
    let deviceName: string = dmInstance.getDeviceName(networkId);
    console.log('device name: ' + JSON.stringify(deviceName)); 
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getDeviceName errCode:" + e.code + ",errMessage:" + e.message);
  }

getDeviceType

getDeviceType(networkId: string): number;

Obtains the device type based on the network ID of the specified device.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
networkId string Yes Network ID of the device.

Return value

Name Description
number Device type obtained.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    // Network ID of the device, which can be obtained from the trusted device list.
    let networkId = "xxxxxxx"
    let deviceType: number = dmInstance.getDeviceType(networkId);
    console.log('device type: ' + JSON.stringify(deviceType)); 
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("getDeviceType errCode:" + e.code + ",errMessage:" + e.message);
  }

startDiscovering

startDiscovering(discoverParam: {[key:&nbsp;string]:&nbsp;Object} , filterOptions?: {[key:&nbsp;string]:&nbsp;Object} ): void;

Starts to discover devices nearby. The discovery process automatically stops when 2 minutes have elapsed. A maximum of 99 devices can be discovered.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
discoverParam {[key:&nbsp;string]:&nbsp;Object} Yes Identifier of the device to discover. It specifies the type of the target to discover.
discoverTargetType: The default discovery target is device. The value is 1.
filterOptions {[key:&nbsp;string]:&nbsp;Object} No Options for filtering discovered devices. The default value is undefined, which means to discover offline devices. The following key values are carried:
availableStatus(0-1): Discover trusted devices only. The value 0 indicates that the device is untrusted.
- 0: The device is offline. The client needs to call bindTarget to bind the device.
- 1: The device is online and can be connected.
discoverDistance(0-100): Discover devices within a certain distance (in cm) from the local device.
authenticationStatus(0-1): Discover devices based on the authentication status.
- 0: The device is not authenticated.
- 1: The device has been authenticated.
authorizationType(0-2): Discover devices based on the authorization type.
- 0: device authenticated by a temporarily agreed session key.
- 1: device authenticated by a key of the same account.
- 2: devices authenticated by a credential key of different accounts.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.
11600104 Discovery repeats.

Example

  import { BusinessError } from '@ohos.base'

  interface DiscoverParam {
    discoverTargetType: number
  }

  interface FilterOptions {
    availableStatus: number,
    discoverDistance: number,
    authenticationStatus: number,
    authorizationType: number
  }

  let discoverParam: Record<string, number> = {
    'discoverTargetType': 1
  };
  let filterOptions: Record<string, number> = {
    'availableStatus': 0
  };

  try {
    dmInstance.startDiscovering(discoverParam, filterOptions); // When devices are discovered, discoverSuccess is called to notify the application.
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("startDiscovering errCode:" + e.code + ",errMessage:" + e.message);
  }

stopDiscovering

stopDiscovering(): void;

Stops device discovery.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.
11600104 Stop discovery repeats.

Example

  import { BusinessError } from '@ohos.base'

  try {
    dmInstance.stopDiscovering();
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("stopDiscovering errCode:" + e.code + ",errMessage:" + e.message);
  }

bindTarget

bindTarget(deviceId: string, bindParam: {[key:&nbsp;string]:&nbsp;Object} , callback: AsyncCallback&lt;{deviceId: string}>): void;

Binds a device.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
deviceId string Yes Device ID.
bindParam {[key:&nbsp;string]:&nbsp;Object} Yes Authentication parameters. You can determine the key-value pair to be passed in. By default, the following key values are carried:
bindType: binding type.
- 1: PIN.
- 2: QR code.
- 3: NFC.
- 4: No interaction.
targetPkgName: bundle name of the target to bind.
appName: application that attempts to bind the target.
appOperation: reason for the application to bind the target.
customDescription: detailed description of the operation.
callback AsyncCallback&lt;{deviceId:&nbsp;string,&nbsp;}&gt; Yes Callback invoked to return the authentication result.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.
11600103 Bind invalid.

Example

  import { BusinessError } from '@ohos.base'

  class Data {
    deviceId: string = ""
  }

  // Information about the device to authenticate. The information can be obtained from the device discovery result.
  let deviceId = "XXXXXXXX";
  let bindParam: Record<string, string|number> = {
    'authType': 1, // Authentication type. The value 1 means PIN authentication.
    targetPkgName: 'xxxx',
    appName: 'xxxx',
    appOperation: 'xxxx',
    customDescription: 'xxxx'
  }

  try {
    dmInstance.bindTarget(deviceId, bindParam, (err: BusinessError, data: Data) => {
      if (err) {
          console.error("bindTarget errCode:" + err.code + ",errMessage:" + err.message);
          return;
      }
      console.info("bindTarget result:" + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("bindTarget errCode:" + e.code + ",errMessage:" + e.message);
  }

unbindTarget

unbindTarget(deviceId: string): void;

Unbinds a device.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
deviceId string Yes Device ID.

Error codes

For details about the error codes, see Device Management Error Codes.

ID Error Message
11600101 Failed to execute the function.

Example

  import { BusinessError } from '@ohos.base'

  try {
    let deviceId = "XXXXXXXX";
    dmInstance.unbindTarget(deviceId);
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("unbindTarget errCode:" + e.code + ",errMessage:" + e.message);
  }

replyUiAction

replyUiAction(action: number, actionResult: string): void;

Replies to the user’s UI operation. This API can be used only by the PIN HAP of the deviceManager.

Required permissions: ohos.permission.ACCESS_SERVICE_DM

System capability: SystemCapability.DistributedHardware.DeviceManager

System API: This is a system API.

Parameters

Name Type Mandatory Description
action number Yes User operation.
actionResult string Yes Operation result.

Example

  import { BusinessError } from '@ohos.base'

 try {
    /*
      action = 0 - Grant the permission.
      action = 1 - Revoke the permission.
      action = 2 - The user operation in the permission request dialog box times out.
      action = 3 - Cancel the display of the PIN box.
      action = 4 - Cancel the display of the PIN input box.
      action = 5 - Confirm the input in the PIN input box.
    */
    let operation = 0;
    dmInstance.replyUiAction(operation, "extra")
    } catch (err) {
      let e: BusinessError = err as BusinessError;
      console.error("replyUiAction errCode:" + e.code + ",errMessage:" + e.message);
  }

on(‘replyResult’)

on(type: ‘replyResult’, callback: Callback&lt;{ param: string}&gt;): void;

Subscribes to the UI operation reply result.

Required permissions: ohos.permission.ACCESS_SERVICE_DM

System capability: SystemCapability.DistributedHardware.DeviceManager

System API: This is a system API.

Parameters

Name Type Mandatory Description
type string Yes Event type to subscribe to. The value replyResult indicates the reply result of the UI operation.
callback Callback&lt;{&nbsp;param:&nbsp;string}&gt; Yes Callback invoked to return the UI status.

Example

  import { BusinessError } from '@ohos.base'

  class Data {
    param: string = ""
  }

  interface TmpStr {
    verifyFailed: boolean
  }

  try {
    dmInstance.on('replyResult', (data: Data) => {
    console.log("replyResult executed, dialog closed" + JSON.stringify(data))
    let tmpStr: TmpStr = JSON.parse(data.param)
    let isShow = tmpStr.verifyFailed
    console.log("replyResult executed, dialog closed" + isShow)
  });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("replyResult errCode:" + e.code + ",errMessage:" + e.message);
  }

off(‘replyResult’)

off(type: ‘replyResult’, callback?: Callback&lt;{ param: string}&gt;): void;

Unsubscribes from the UI operation reply result.

Required permissions: ohos.permission.ACCESS_SERVICE_DM

System capability: SystemCapability.DistributedHardware.DeviceManager

System API: This is a system API.

Parameters

Name Type Mandatory Description
type string Yes Event type to unsubscribe from. The value replyResult indicates the reply result of the UI operation.
callback Callback&lt;{&nbsp;param:&nbsp;string}&gt; No Callback for the UI status.

Example

  import { BusinessError } from '@ohos.base'

  try {
    dmInstance.off('replyResult');
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("replyResult errCode:" + e.code + ",errMessage:" + e.message);
  }

on(‘deviceStateChange’)

on(type: ‘deviceStateChange’, callback: Callback&lt;{ action: DeviceStateChange, device: DeviceBasicInfo }&gt;): void;

Subscribes to changes in the device state.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘deviceStateChange’ indicates a device state change event.
callback Callback&lt;{&nbsp;action:&nbsp;DeviceStateChange,&nbsp;device:&nbsp;DeviceBasicInfo&nbsp;}&gt; Yes Callback invoked to return the device information and state.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  class Data {
    action: deviceManager.DeviceStateChange = 0
    device: deviceManager.DeviceBasicInfo = {
      deviceId: "",
      deviceName: "",
      deviceType: "",
      networkId: "",
    }
  }

  try {
    dmInstance.on('deviceStateChange', (data: Data) => {
      console.info("deviceStateChange on:" + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("deviceStateChange errCode:" + e.code + ",errMessage:" + e.message);
  }

off(‘deviceStateChange’)

off(type: ‘deviceStateChange’, callback?: Callback&lt;{ action: DeviceStateChange, device: DeviceBasicInfo }&gt;): void;

Unsubscribes from changes in the device state.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘deviceStateChange’ indicates a device state change event.
callback Callback&lt;{&nbsp;action:&nbsp;deviceStateChange,&nbsp;device:&nbsp;DeviceBasicInfo&nbsp;}&gt; No Callback for the device information and state.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  class Data {
    action: deviceManager.DeviceStateChange = 0
    device: deviceManager.DeviceBasicInfo = {
      deviceId: "",
      deviceName: "",
      deviceType: "",
      networkId: "",
    }
  }

  try {
    dmInstance.off('deviceStateChange', (data: Data) => {
      console.info('deviceStateChange' + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("deviceStateChange errCode:" + e.code + ",errMessage:" + e.message);
  }

on(‘discoverSuccess’)

on(type: ‘discoverSuccess’, callback: Callback&lt;{ device: DeviceBasicInfo }&gt;): void;

Subscribes to device discovery events.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘discoverSuccess’ indicates an event of successful device discovery.
callback Callback&lt;{&nbsp;device:&nbsp;DeviceBasicInfo&nbsp;}&gt; Yes Callback invoked to return a device discovery event.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  class Data {
    device: deviceManager.DeviceBasicInfo = {
      deviceId: "",
      deviceName: "",
      deviceType: "",
      networkId: "",
    }
  }
  
  try {
    dmInstance.on('discoverSuccess', (data: Data) => {
      console.info("discoverSuccess:" + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("discoverSuccess errCode:" + e.code + ",errMessage:" + e.message);
  }

off(‘discoverSuccess’)

off(type: ‘discoverSuccess’, callback?: Callback&lt;{ device: DeviceBasicInfo }&gt;): void;

Unsubscribes from device discovery events.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘discoverSuccess’ indicates a device discovery event.
callback Callback&lt;{&nbsp;device:&nbsp;DeviceBasicInfo&nbsp;}&gt; No Callback for the device discovery event.

Example

  import deviceManager from '@ohos.distributedDeviceManager'
  import { BusinessError } from '@ohos.base'

  class Data {
    device: deviceManager.DeviceBasicInfo = {
      deviceId: "",
      deviceName: "",
      deviceType: "",
      networkId: "",
    }
  }

  try {
    dmInstance.off('discoverSuccess', (data: Data) => {
      console.info('discoverSuccess' + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("discoverSuccess errCode:" + e.code + ",errMessage:" + e.message);
  }

on(‘deviceNameChange’)

on(type: ‘deviceNameChange’, callback: Callback&lt;{ deviceName: string }&gt;): void;

Subscribes to device name changes.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘deviceNameChange’ indicates a device name change event.
callback Callback&lt;{&nbsp;deviceName:&nbsp;string}&gt; Yes Callback invoked to return the device name change.

Example

  import { BusinessError } from '@ohos.base'

  class Data {
    deviceName: string = ""
  }

  try {
    dmInstance.on('deviceNameChange', (data: Data) => {
        console.info("deviceNameChange on:" + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("deviceNameChange errCode:" + e.code + ",errMessage:" + e.message);
  }

off(‘deviceNameChange’)

off(type: ‘deviceNameChange’, callback?: Callback&lt;{ deviceName: string }&gt;): void;

Unsubscribes from device name changes.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘deviceNameChange’ indicates a device name change event.
callback Callback&lt;{&nbsp;deviceName:&nbsp;string}&gt; No Callback for the device name change.

Example

  import { BusinessError } from '@ohos.base'

  class Data {
    deviceName: string = ""
  }

  try {
    dmInstance.off('deviceNameChange', (data: Data) => {
      console.info('deviceNameChange' + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("deviceNameChange errCode:" + e.code + ",errMessage:" + e.message);
  }

on(‘discoverFailure’)

on(type: ‘discoverFailure’, callback: Callback&lt;{ reason: number }&gt;): void;

Subscribes to device discovery failures.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘discoverFailure’ indicates an event reported when device discovery fails.
callback Callback&lt;{&nbsp;reason:&nbsp;number&nbsp;}&gt; Yes Callback invoked to return a device discovery failure.

Example

  import { BusinessError } from '@ohos.base'

  class Data {
    reason: number = 0
  }

  try {
    dmInstance.on('discoverFailure', (data: Data) => {
        console.info("discoverFailure on:" + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("discoverFailure errCode:" + e.code + ",errMessage:" + e.message);
  }

off(‘discoverFailure’)

off(type: ‘discoverFailure’, callback?: Callback&lt;{ reason: number }&gt;): void;

Unsubscribes from device discovery failures.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘discoverFailure’ indicates an event reported when device discovery fails.
callback Callback&lt;{&nbsp;reason:&nbsp;number&nbsp;}&gt; No Callback for the device discovery failure.

Example

  import { BusinessError } from '@ohos.base'

  class Data {
    reason: number = 0
  }

  try {
    dmInstance.off('discoverFailure', (data: Data) => {
      console.info('discoverFailure' + JSON.stringify(data));
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("discoverFailure errCode:" + e.code + ",errMessage:" + e.message);
  }

on(‘serviceDie’)

on(type: ‘serviceDie’, callback?: Callback&lt;{}&gt;): void;

Subscribes to dead events of the DeviceManager service.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘serviceDie’ indicates an event reported when the DeviceManager service is terminated unexpectedly.
callback Callback&lt;{}&gt; No Callback invoked when a dead event of the DeviceManager service occurs.

Example

  import { BusinessError } from '@ohos.base'

  try {
    dmInstance.on("serviceDie", () => {
      console.info("serviceDie on");
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("serviceDie errCode:" + e.code + ",errMessage:" + e.message);
  }

off(‘serviceDie’)

off(type: ‘serviceDie’, callback?: Callback&lt;{}&gt;): void;

Unsubscribes from dead events of the DeviceManager service.

Required permissions: ohos.permission.DISTRIBUTED_DATASYNC

System capability: SystemCapability.DistributedHardware.DeviceManager

Parameters

Name Type Mandatory Description
type string Yes Event type. The value ‘serviceDie’ indicates an event reported when the DeviceManager service is terminated unexpectedly.
callback Callback&lt;{}&gt; No Callback for the dead event of the DeviceManager service.

Example

  import { BusinessError } from '@ohos.base'

  try {
    dmInstance.off("serviceDie", () => {
      console.info("serviceDie off");
    });
  } catch (err) {
    let e: BusinessError = err as BusinessError;
    console.error("serviceDie errCode:" + e.code + ",errMessage:" + e.message);
  }

你可能感兴趣的鸿蒙文章

harmony 鸿蒙APIs

harmony 鸿蒙System Common Events (To Be Deprecated Soon)

harmony 鸿蒙System Common Events

harmony 鸿蒙API Reference Document Description

harmony 鸿蒙Enterprise Device Management Overview (for System Applications Only)

harmony 鸿蒙BundleStatusCallback

harmony 鸿蒙@ohos.bundle.innerBundleManager (innerBundleManager)

harmony 鸿蒙@ohos.distributedBundle (Distributed Bundle Management)

harmony 鸿蒙@ohos.bundle (Bundle)

harmony 鸿蒙@ohos.enterprise.EnterpriseAdminExtensionAbility (EnterpriseAdminExtensionAbility)

0  赞