используя обещания и asyn c для protobuf js loadcall - PullRequest
0 голосов
/ 21 февраля 2020

Я пытаюсь найти лучший способ переписать следующий код:

var api = function(id, contract) {
  var callback = function (error, root) {
    if (error)
      throw error;
    var by = Buffer.from(contract,'base64')
    var es = root.lookupType("Contract")
    var esMsg = es.decode(by)
    var esBytes = es.encode(esMsg).finish()
    signature = id.sign(esBytes).toString('base64')
  }
  return new Promise((resolve, reject) => {
     protobuf.load("contract.proto", callback)
  })
}
var signContract = async(privateKey, contract) => {
  let signature
  var id = await crypto.keys.unmarshalPrivateKey(Buffer.from(privateKey, 'base64'))
  result = await api(id,contract,signature)
}

function getSessionSignature (hash, time) {
  return config.id + ":" + hash + ":" + time
}
module.exports = configure(({ ky }) => {
  return async function * signbatch (input, options) {

    var contracts = input.Contracts

      for (var i = 0 ; i < contracts.length ; i++) {
        contracts[i].contract = await signContract(config.PrivKey, contracts[i].contract)
      }

      //add signed contracts to the searchParams
      searchParams.append("arg", JSON.stringify(contracts))

      let res
      res = await ky.post('storage/upload/signbatch', {
        searchParams
      }).json()
      yield JSON.stringify({})
    } else {
      yield JSON.stringify({error:"Private key not found"})
    }
  }
})

Моя проблема заключается в том, как написать код знака asyn c для передачи в privateKey и переменных контракта в api var function и вернуть подпись обратно в переменную результата, которая будет назначена контрактам [i] .contract? Обратите внимание, что функция id.sign (..) - это Promise внутри функции обратного вызова.

1 Ответ

1 голос
/ 22 февраля 2020

Вам нужно разрешить обещание в функции api, документы предполагают, что вы можете использовать здесь вариант с одним аргументом, например,

var root = await protobuf.load("contract.proto");
... // (The code you currently by have in 'callback'
return signature;

Поскольку генератор равен async, yield выдаст Promise которые вы можете (очевидно) обрабатывать с помощью .then или await

...