Я пытаюсь выдать некоторые Fabtokens пользователям, а затем использовать их в различных сценариях, таких как передача, погашение и т. Д. Я следую документации по Node SDK здесь: https://fabric -sdk-node.github.io/master/tutorial-fabtoken.html
Вот как они выполняют операции Fabtoken:
// create a TokenClient instance from client
const tokenclient = client.newTokenClient(mychannel);
// create a transaction ID for "issuer"
const txId = client.newTransactionID();
// create two parameters for issue, one for user1 and one for user2
const param1 = {
owner: user1.getIdentity().serialize(),
type: 'USD',
quantity: '500',
};
const param2 = {
owner: user2.getIdentity().serialize(),
type: 'EURO',
quantity: '300',
};
// create the token request for issue
const issueRequest = {
params: [param1, param2],
txId: txId,
};
// issuer calls issue method to issue tokens to user1 and user2
const result = await tokenClient.issue(issueRequest);
А затем используют другой tokenClient для вывода списка токенов пользователя 1:
const user1Tokenclient = client1.newTokenClient(mychannel);
// user1 lists tokens
const mytokens = await user1TokenClient.list();
// iterate the tokens to get token id, type, and quantity for each token
for (const token of tokens) {
// get token.id, token.type, and token.quantity
// token.id will be used for transfer and redeem
}
Это упомянуто на странице класса клиента Node SDK здесь: https://fabric -sdk-node.github.io / master / Client.html , что переключает userContexts с тем же экземпляром клиентаявляется анти-паттерном и не рекомендуется, так как экземпляры клиента имеют состояние.
Как они предполагают, я создаю свои клиентские экземпляры в разных пользовательских контекстах.Вот как я создаю своих клиентов, устанавливаю их пользовательский контекст и создаю свои экземпляры tokenClient:
const adminClient = new Fabric_Client();
const admin = await adminClient.createUser(user_opts);
adminClient.setUserContext(admin, true);
let adminConfig = {
admin: admin,
adminClient: adminClient,
adminTokenClient: adminClient.newTokenClient(channel)
}
const server = await serverClient.createUser(server_opts);
serverClient.setUserContext(server, true);
let serverConfig = {
server: server,
serverClient: serverClient,
serverTokenClient: serverClient.newTokenClient(channel)
}
Позже я использую эти config
объекты для выдачи некоторых токенов разным пользователям.Как я выдаю токены на свою учетную запись сервера из учетной записи издателя (администратора):
const txId = adminConfig.adminClient.newTransactionID();
let issueQuery = {
tokenClient: adminConfig.adminTokenClient,
txId: txId,
channel: channel,
params: []
}
for(let i=0; i < 3; ++i) {
let param = {
owner: serverConfig.server.getIdentity().serialize(),
type: 'test',
quantity: '1'
}
issueQuery.params.push(param);
}
let issueTx = await waitForIssue(issueQuery);
Это успешно выдает три токена на сервер, как и ожидалось.Проблема в том, что когда я пытаюсь получить доступ к токенам моего сервера, как в примере, который они предоставляют, используя похожий код:
let server_tokens = await serverConfig.serverTokenClient.list();
for (let server_token of server_tokens) {
console.log(server_token.id);
}
Результат просто пуст, и я не получаю никаких сообщений об ошибках.Однако, когда я проверяю транзакцию, используя queryTransaction(txId)
для транзакции выпуска токена, которую я генерирую, я вижу, что владельцем выданных токенов в этой транзакции является сервер, и поэтому я могу быть уверен, что смогу успешно выдать токенысервер.Есть ли другой способ проверить токены моего сервера?Или я не должен использовать различный клиентский и пользовательский контекст для каждого пользователя, как они предлагают?Потому что раньше я мог видеть токены сервера, когда использовал один клиент и один пользовательский контекст для выдачи и вывода списка токенов.Но этот подход вызвал у меня проблемы, когда я пытался передавать свои токены асинхронно.