Corda:如何将 AndComposition 与 VaultCustomQueryCriteria 一起使用

Corda: How to use the AndComposition with a VaultCustomQueryCriteria

我使用 RPC 客户端(Java Spring 引导应用程序)连接到 Corda 4.6 节点。

我想 运行 具有以下查询条件的自定义保险库查询:

QueryCriteria stateStatusCriteria = new VaultQueryCriteria(StateStatus.ALL);
QueryCriteria myFieldCriteria = new VaultCustomQueryCriteria(
  Builder.equal(getField("myField", PersistentMyState.class), myValue)
);
return stateStatusCriteria.and(myFieldCriteria);
// Also tried: return myFieldCriteria.and(stateStatusCriteria);

这与 Corda documentation 中的示例非常相似。

但是,我只检索了 UNCONSUMED 个状态。这里会出什么问题?

以下代码片段有效,但我需要一个 AndComposition,因为我想稍后添加更多自定义条件:

QueryCriteria myFieldCriteria = new VaultCustomQueryCriteria(
  Builder.equal(getField("myField", PersistentMyState.class), myValue), 
  StateStatus.ALL
);
return myFieldCriteria ;

此外,任何有关如何在 Corda 中激活 Hibernate 日志记录的提示都将受到赞赏。我在带有 PostgreSQL 数据库的 Kubernetes 集群中 corda/corda-zulu-java1.8-4.6:RELEASE 图像 运行ning 中使用自定义 CorDapps。

** 更新 **

VaultCustomQueryCriteria默认设置stateStatus = UNCONSUMEDits constructor:

    data class VaultCustomQueryCriteria<L : StatePersistable>(
        val expression: CriteriaExpression<L, Boolean>,
        override val status: Vault.StateStatus = Vault.StateStatus.UNCONSUMED,
        override val contractStateTypes: Set<Class<out ContractState>>? = null,
        override val relevancyStatus: Vault.RelevancyStatus = Vault.RelevancyStatus.ALL)

因此,如果您不传递 StateStatus,查询将始终 return UNCONSUMED 状态并且 Hibernate 的 and() 谓词将不起作用,以防您也有CONSUMED 个州。 在 github 上还有一个 this 有趣的问题,有类似的案例。 所以基本上你的第一个片段应该是这样的:

QueryCriteria stateStatusCriteria = new VaultQueryCriteria(StateStatus.ALL);
QueryCriteria myFieldCriteria = new VaultCustomQueryCriteria(
Builder.equal(getField("myField", PersistentMyState.class), myValue), StateStatus.ALL);
return stateStatusCriteria.and(myFieldCriteria);

要激活 Hibernate 记录器,您必须更新 cordapp 中的 log4j.xml 文件以添加 Hibernate 配置,可能是这样的:

<Configuration monitorInterval="60">
<Properties>
    <Property name="log-path">PropertiesConfiguration</Property>
</Properties>
<Appenders>
    <Console name="Console-Appender" target="SYSTEM_OUT">
        <PatternLayout>
            <pattern>
                [%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
            </pattern>>
        </PatternLayout>
    </Console>
</Appenders>
<Loggers>
    <Logger name="org.hibernate.SQL" level="debug" additivity="false">
        <AppenderRef ref="Console-Appender"/>
    </Logger>
    <Logger name="org.hibernate.type.descriptor.sql" level="trace" additivity="false">
        <AppenderRef ref="Console-Appender"/>
    </Logger>
    <Root level="info">
        <AppenderRef ref="Console-Appender"/>
    </Root>
</Loggers>