Hyperledger(ファブリック実装)でトランザクションを実行できます。ユーザーのキーを渡すことによってユーザーが開始したすべてのトランザクションとそのペイロードの詳細を確認したいと思います。
例えば:
A transfers 10 units to B
A transfers 5 units to C
D transfers 8 units to A
Aのキーを渡すと、ファブリックはAのすべてのトランザクションを提供する必要があります。方法はありますか?または、どのファブリックAPI関数呼び出しを使用する必要がありますか?
チェーンコードで適切なインデックス作成およびクエリ機能を開発できます。
トランザクションごとに、ユーザーをキーとして内部キー/値ストア(stub.PutState)に詳細を格納し、クエリ(stub.GetState)でユーザーに関連付けられているすべてのトランザクションを返します。
/chain/blocks/{Block}
エンドポイントは指定されたブロックでトランザクションの順序付きリストを運びます。
/chain
エンドポイントを使用してチェーンの高さ(ブロック数)を取得し、/chain/blocks/{Block}
RESTエンドポイントを使用して各ブロックからトランザクションを取得します。
最良かつ最も簡単な方法は、shim package関数を使用することです。
GetHistoryForKey(キー文字列)
ドキュメントにあるように:
GetHistoryForKey関数は、チェーンコードによって呼び出され、時間の経過に伴うキー値の履歴を返すことができます。 GetHistoryForKeyは、読み取り専用クエリに使用することを目的としています。
誰かがJava SDkとgochaincodeの組み合わせを必要とする場合。
ここで答えました 同様の質問
Javaコード
public List<HistoryDao> getUFOHistory(String key) throws Exception {
String[] args = { key };
Logger.getLogger(QueryChaincode.class.getName()).log(Level.INFO, "UFO communication history - " + args[0]);
Collection<ProposalResponse> responses1Query = ucc.getChannelClient().queryByChainCode("skynetchaincode", "getHistoryForUFO", args);
String stringResponse = null;
ArrayList<HistoryDao> newArrayList = new ArrayList<>();
for (ProposalResponse pres : responses1Query) {
stringResponse = new String(pres.getChaincodeActionResponsePayload());
Logger.getLogger(QueryChaincode.class.getName()).log(Level.INFO, stringResponse);
newArrayList = gson.fromJson(stringResponse, new TypeToken<ArrayList<HistoryDao>>() {
}.getType());
}
if (null == stringResponse)
stringResponse = "Not able to find any ufo communication history";
return newArrayList;
}
chancodeの実装は次のようになります
コードに移動
func (t *SmartContract) getHistoryForUFO(APIstub shim.ChaincodeStubInterface, args []string) sc.Response {
if len(args) < 1 {
return shim.Error("Incorrect number of arguments. Expecting 1")
}
ufoId := args[0]
resultsIterator, err := APIstub.GetHistoryForKey(ufoId)
if err != nil {
return shim.Error(err.Error())
}
defer resultsIterator.Close()
var buffer bytes.Buffer
buffer.WriteString("[")
bArrayMemberAlreadyWritten := false
for resultsIterator.HasNext() {
response, err := resultsIterator.Next()
if err != nil {
return shim.Error(err.Error())
}
// Add a comma before array members, suppress it for the first array member
if bArrayMemberAlreadyWritten == true {
buffer.WriteString(",")
}
buffer.WriteString("{\"TxId\":")
buffer.WriteString("\"")
buffer.WriteString(response.TxId)
buffer.WriteString("\"")
buffer.WriteString(", \"Value\":")
// if it was a delete operation on given key, then we need to set the
//corresponding value null. Else, we will write the response.Value
//as-is (as the Value itself a JSON)
if response.IsDelete {
buffer.WriteString("null")
} else {
buffer.WriteString(string(response.Value))
}
buffer.WriteString(", \"Timestamp\":")
buffer.WriteString("\"")
buffer.WriteString(time.Unix(response.Timestamp.Seconds, int64(response.Timestamp.Nanos)).String())
buffer.WriteString("\"")
buffer.WriteString(", \"IsDelete\":")
buffer.WriteString("\"")
buffer.WriteString(strconv.FormatBool(response.IsDelete))
buffer.WriteString("\"")
buffer.WriteString("}")
bArrayMemberAlreadyWritten = true
}
buffer.WriteString("]")
fmt.Printf("- History returning:\n%s\n", buffer.String())
return shim.Success(buffer.Bytes())
}
ご不明な点がございましたらお知らせください。
Composer-clientを使用している場合は、Historianコマンドを使用するだけです。
var historian = await businessNetworkConnection.getHistorian();
historian.getAll().then(historianRecords => console.log(historianRecords));