跳到主要内容

删除企业恢复密钥

场景介绍

为应用提供删除企业恢复密钥的能力,用于在企业恢复密钥发生泄漏、禁用企业恢复密钥时删除相关数据,使之前导出的企业恢复密钥失效。

接口说明

详细接口说明可参考接口文档

接口名描述
deleteEnterpriseRecoveryKey(userId: number, signature: Uint8Array): Promise<number>使用Promise方式删除企业恢复密钥相关数据。

开发步骤

  1. 导入模块。

    import { recoveryKey } from '@kit.EnterpriseDataGuardKit';
    import { BusinessError, osAccount } from '@kit.BasicServicesKit';
  2. 先调用接口getAuthChallenge,获取挑战值并签名,传入需要删除企业恢复密钥的用户ID和挑战值的签名,再调用接口deleteEnterpriseRecoveryKey,删除企业恢复密钥相关数据。

    async function testDeleteEnterpriseRecoveryKey() {
    try {
    let accountManager: osAccount.AccountManager = osAccount.getAccountManager();
    let userId: number = await accountManager.getOsAccountLocalId();
    // 在实际应用中,signature 应替换为由企业的公钥、私钥和挑战值生成的签名。
    let signature: Uint8Array = new Uint8Array([0]);
    recoveryKey.deleteEnterpriseRecoveryKey(userId, signature).then((ret: number) => {
    console.info(`Succeeded in deleting enterprise recovery key.`);
    }).catch((err: BusinessError) => {
    console.error(`Failed to delete enterprise recovery key. Code: ${err.code}, message: ${err.message}`);
    });
    } catch (e) {
    console.error(`Failed to testDeleteEnterpriseRecoveryKey. Code: ${e.code}, message: ${e.message}`);
    }
    }