Hyperledger Indy 创建 RevocationRegistry 失败,由于 schema_ref 导致 credDefId 格式错误

Hyperledger Indy Creating RevocationRegistry Fails, malformed credDefId because of schema_ref

我目前正在尝试将撤销注册表定义 (revRegDef) 写入 Indy Getting Started 中所示的 Hyperledger Indy 池中。 工作流程是这样的:

  1. 创建架构
  2. 使用 schemaId,创建凭证定义 (credDef)
  3. 使用 credDefId,创建一个 revRegDef

由于我需要使用 Java,我将适当的请求添加到 Java Sample, i uploaded my modified version here 的分类帐中。

创建架构和 credDef 工作正常,但是当我发送最后一个请求时,我收到以下错误消息:

reason -> client request invalid: InvalidClientRequest("Format of credDefId field is not acceptable. 
Expected: 'did:marker:signature_type:schema_ref' or 'did:marker:signature_type:schema_ref:tag'",)

此时,提到的 credDefId 如下所示:Th7MpTaRZVRYnPiabds81Y:3:CL:Th7MpTaRZVRYnPiabds81Y:2:gvt:1.0:Tag1 而 schemaId 是 Th7MpTaRZVRYnPiabds81Y:2:gvt:1.0

显然不符合上述模式,但是 Ledger.buildCredDefReq() 函数 returns 和 credDefId 是这样的,所以我希望它是正确的。

编辑:虽然我的旧答案有效,但它只是一个解决方法和完整的废话。以下应该是创建凭据模式、凭据定义和撤销注册表定义的正确方法。

// Create Credential Schema
String name = "schema_name";
String schemaAttrs = new JSONArray().put("name").put("age").toString();
AnoncredsResults.IssuerCreateSchemaResult schema =
        Anoncreds.issuerCreateSchema(verinym, name, "1.0", schemaAttrs).get();
String schemaId = schema.getSchemaId();
String schemaJson = schema.getSchemaJson();
JSONObject schemaRes = new JSONObject(Ledger.signAndSubmitRequest(PoolUtils.getInstance(), wallet, verinym,
        Ledger.buildSchemaRequest(verinym, schemaJson).get()
).get());
int schemaSeqNo = schemaRes.getJSONObject("result").getJSONObject("txnMetadata").getInt("seqNo");
schemaJson = new JSONObject(schemaJson).put("seqNo", schemaSeqNo).toString();

// Create Credential Definition
AnoncredsResults.IssuerCreateAndStoreCredentialDefResult credDef =
        Anoncreds.issuerCreateAndStoreCredentialDef(
                wallet, verinym, schemaJson, "tag", null,
                new JSONObject().put("support_revocation", true).toString()
        ).get();

// creating credDef req and sending it to the ledger
JSONObject credDefRes = new JSONObject(
        Ledger.signAndSubmitRequest(
                PoolUtils.getInstance(), wallet, verinym,
                Ledger.buildCredDefRequest(verinym, credDef.getCredDefJson()).get()
        ).get()
);
int credSeqNo = credDefRes.getJSONObject("result").getJSONObject("txnMetadata").getInt("seqNo");

// Create Revocation Registry Definition
String tailsWriterConfig = new JSONObject().put("base_dir", "/tmp/indy_tails").put("uri_pattern", "").toString();
BlobStorageWriter tails = BlobStorageWriter.openWriter("default", tailsWriterConfig).get();
AnoncredsResults.IssuerCreateAndStoreRevocRegResult revocRegDef = Anoncreds.issuerCreateAndStoreRevocReg(
        wallet, verinym, null, "contractDef", credDefId,
        "{}", tails
).get();
JSONObject revocRegDefRes = new JSONObject(
        Ledger.signAndSubmitRequest(PoolUtils.getInstance(), wallet, verinym,
                Ledger.buildRevocRegDefRequest(verinym, revocRegDef.getRevRegDefJson()).get()
        ).get());
revocRegDefSeqNo = revocRegDefRes.getJSONObject("result").getJSONObject("txnMetadata").getInt("seqNo");

学习是分类帐returns重要价值的创造定义

此外,没有任何地方提到您需要创建初始吊销注册表项:

// Create initial revocation entry
JSONObject revocRegEntryRes = new JSONObject(Ledger.signAndSubmitRequest(PoolUtils.getInstance(), wallet, verinym,
Ledger.buildRevocRegEntryRequest(verinym, revocRegDef.getRevRegId(),
"CL_ACCUM", revocRegDef.getRevRegEntryJson()).get()).get());