2017-08-30 1 views
2

Dans notre cas d'utilisation, nous devons ajouter deux états de sortie avec des contrats différents à une transaction. J'ai essayé d'ajouter plusieurs états à la transaction dans withItems. J'appelle ce flux d'un RPC mais il déclenche une exception en tant que java.lang.IllegalArgumentException: List has more than one element. lors de la signature de la transaction.Corda: Ajout d'états de sortie multiples dans une seule transaction

Voilà comment je suis d'ajouter plusieurs états de sortie: -

val outputstate1 = IouState1(dataModel1, me, otherParty) 
val outputstate2 = IouState2(dataModel2, me, otherParty) 
val cmd1 = Command(IouContract1.Commands.Create(), state1.participants.map { it.owningKey }) 
val cmd2 = Command(IouContract2.Commands.Initiated(), state2.participants.map { it.owningKey }) 
val txBuilder = TransactionBuilder(TransactionType.General, notary).withItems(state1, state2, cmd1, cmd2) 
progressTracker.currentStep = VERIFYING_TRANSACTION 

// Verifying the transaction. 
txBuilder.toWireTransaction().toLedgerTransaction(serviceHub).verify() 

progressTracker.currentStep = SIGNING_TRANSACTION 
// Signing the transaction. 
val partSignedTx = serviceHub.signInitialTransaction(txBuilder) 

progressTracker.currentStep = GATHERING_SIGS 
// Send the state to the counterparty, and receive it back with their signature. 
val fullySignedTx = subFlow(CollectSignaturesFlow(partSignedTx, GATHERING_SIGS.childProgressTracker())) 

// Finalising the transaction. 
progressTracker.currentStep = FINALISING_TRANSACTION 
// Notarise and record the transaction in both parties' vaults. 
return subFlow(FinalityFlow(fullySignedTx, FINALISING_TRANSACTION.childProgressTracker())).single() 

Trace de la pile: -

net.corda.core.flows.FlowException: java.lang.IllegalArgumentException: List has more than one element. 
    at net.corda.core.flows.SignTransactionFlow.call(CollectSignaturesFlow.kt:202) ~[corda-core-0.14.0.jar:?] 
    at net.corda.core.flows.SignTransactionFlow.call(CollectSignaturesFlow.kt:175) ~[corda-core-0.14.0.jar:?] 
    at net.corda.core.flows.FlowLogic.subFlow(FlowLogic.kt:166) ~[corda-core-0.14.0.jar:?] 
    at com.dwlabcorda.salescontract.LOCReceiverFlow.call(LOCContractFlow.kt:107) ~[tradefinancecorda-0.1.jar:?] 
    at com.dwlabcorda.salescontract.LOCReceiverFlow.call(LOCContractFlow.kt:95) ~[tradefinancecorda-0.1.jar:?] 
    at net.corda.node.services.statemachine.FlowStateMachineImpl.run(FlowStateMachineImpl.kt:101) [corda-node-0.14.0.jar:?] 
    at net.corda.node.services.statemachine.FlowStateMachineImpl.run(FlowStateMachineImpl.kt:33) [corda-node-0.14.0.jar:?] 
    at co.paralleluniverse.fibers.Fiber.run1(Fiber.java:1067) [quasar-core-0.7.6-jdk8.jar:0.7.6] 
    at co.paralleluniverse.fibers.Fiber.exec(Fiber.java:767) [quasar-core-0.7.6-jdk8.jar:0.7.6] 
    at co.paralleluniverse.fibers.RunnableFiberTask.doExec(RunnableFiberTask.java:100) [quasar-core-0.7.6-jdk8.jar:0.7.6] 
    at co.paralleluniverse.fibers.RunnableFiberTask.run(RunnableFiberTask.java:91) [quasar-core-0.7.6-jdk8.jar:0.7.6] 
    at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) [?:1.8.0_144] 
    at java.util.concurrent.FutureTask.run(Unknown Source) [?:1.8.0_144] 
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(Unknown Source) [?:1.8.0_144] 
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(Unknown Source) [?:1.8.0_144] 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) [?:1.8.0_144] 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) [?:1.8.0_144] 
    at net.corda.node.utilities.AffinityExecutor$ServiceAffinityExecutor$1$thread$1.run(AffinityExecutor.kt:69) [corda-node-0.14.0.jar:?] 
Caused by: java.lang.IllegalArgumentException: List has more than one element. 
    at kotlin.collections.CollectionsKt___CollectionsKt.single(_Collections.kt:471) ~[kotlin-stdlib-1.1.1.jar:1.1.1] 
    at com.dwlabcorda.salescontract.LOCReceiverFlow$call$signTransactionFlow$1.checkTransaction(LOCContractFlow.kt:100) ~[tradefinancecorda-0.1.jar:?] 
    at net.corda.core.flows.SignTransactionFlow.call(CollectSignaturesFlow.kt:199) ~[corda-core-0.14.0.jar:?] 
    ... 17 more 
+0

Cela devrait aller. Je soupçonne que votre problème est ailleurs. Pouvez-vous poster le reste du flux? – joel

+0

mis à jour le code de l'ensemble du flux .. – bakriOnFire

+0

Merci - pouvez-vous également ajouter la trace de la pile complète? Puisque je ne vois rien de fâcheux ci-dessus, je suppose que le problème pourrait être dans le code du contrat (que 'CollectSignaturesFlow' va invoquer). Comme le dit Stefano, vérifiez si vous appelez 'single' sur les sorties de vos contrats. – joel

Répondre

2

probablement vous avez utilisé un .single() coulé dans un de vos contrats est maintenant lancer une exception

+0

oui j'avais utilisé val out = tx.outputsOfType () .single() "L'expéditeur et le destinataire ne peuvent pas être la même entité." en utilisant (out.party1! = out.party2) .. comment puis-je le changer..get (0) et obtenir (1) throws une exception .. – bakriOnFire

+0

Vous ne pouvez pas utiliser .single(), puis créer deux sorties de tapez IouState, première chose que vous devez d'abord choisir si vous pouvez produire plusieurs IOUState ou seulement un IOUState –

+0

'get (0)' ne devrait pas lancer une exception. Quelle exception voyez-vous bakriOnFire? – joel