以太坊/ Solidity在geth控制台中获取smartcontract事件

时间:2017-05-17 15:54:02

标签: ethereum solidity smartcontracts

所以我试图检索我的smartcontract

生成的事件

var abi = [{
  "constant": false,
  "inputs": [{
    "name": "_value",
    "type": "int32"
  }],
  "name": "changeLowerTrigger",
  "outputs": [],
  "payable": false,
  "type": "function"
}, {
  "constant": true,
  "inputs": [],
  "name": "metric",
  "outputs": [{
    "name": "name",
    "type": "string",
    "value": "place_holder_metric_name_to_be_autogenerated"
  }, {
    "name": "value",
    "type": "int32",
    "value": "7"
  }],
  "payable": false,
  "type": "function"
}, {
  "constant": false,
  "inputs": [{
    "name": "_value",
    "type": "int32"
  }],
  "name": "changeUpperTrigger",
  "outputs": [],
  "payable": false,
  "type": "function"
}, {
  "constant": false,
  "inputs": [{
    "name": "_value",
    "type": "int32"
  }],
  "name": "update",
  "outputs": [],
  "payable": false,
  "type": "function"
}, {
  "anonymous": false,
  "inputs": [{
    "indexed": false,
    "name": "_value",
    "type": "int32"
  }],
  "name": "ValueChanged",
  "type": "event"
}, {
  "anonymous": false,
  "inputs": [{
    "indexed": false,
    "name": "_alarm",
    "type": "string"
  }, {
    "indexed": false,
    "name": "_value",
    "type": "int32"
  }],
  "name": "Alarm",
  "type": "event"
}]
var MyContract = web3.eth.contract(abi);

var myContractInstance = MyContract.at(
  '0x3B03c46Dfc878FeF9fAe8de4E32a6718f2E250e9');

var events = myContractInstance.allEvents();

// watch for changes
events.watch(function(error, event) {
  if (!error)
    console.log(event);
});

// Or pass a callback to start watching immediately
var events = myContractInstance.allEvents(function(error, log) {
  console.log(err, log);
});

但它只返回:

> events
{
  callbacks: [function(error, log)],
  filterId: "0xd6af6f5a7273fe21452f00c4682456",
  getLogsCallbacks: [],
  implementation: {
    getLogs: function(),
    newFilter: function(),
    poll: function(),
    uninstallFilter: function()
  },
  options: {
    address: "0x3B03c46Dfc878FeF9fAe8de4E32a6718f2E250e9",
    from: undefined,
    fromBlock: undefined,
    to: undefined,
    toBlock: undefined,
    topics: []
  },
  pollFilters: [],
  requestManager: {
    polls: {
      0xd6af6f5a7273fe21452f00c4682456: {
        data: {...},
        id: "0xd6af6f5a7273fe21452f00c4682456",
        callback: function(error, messages),
        uninstall: function()
      }
    },
    provider: {
      newAccount: function(),
      send: function github.com/ethereum/go-ethereum/console.(*bridge).Send-fm(),
      sendAsync: function github.com/ethereum/go-ethereum/console.(*bridge).Send-fm(),
      sign: function(),
      unlockAccount: function()
    },
    timeout: {},
    poll: function(),
    reset: function(keepIsSyncing),
    send: function(data),
    sendAsync: function(data, callback),
    sendBatch: function(data, callback),
    setProvider: function(p),
    startPolling: function(data, pollId, callback, uninstall),
    stopPolling: function(pollId)
  },
  formatter: function(),
  get: function(callback),
  stopWatching: function(callback),
  watch: function(callback)
}

但我想要的是,最底层的下一张图片中显示的事件(例如,值更改值:7): enter image description here

由于事件在ETH-Wallet中显示,应该有办法。我只是想要一种方法来获取geth控制台(或类似物)中的最新事件。 感谢任何帮助,我有点失落,并且有一些我生命中最糟糕的谷歌搜索。

1 个答案:

答案 0 :(得分:1)

您需要做的就是在结果对象上调用get()并将其发布到您的答案中。它在官方文档中有描述,可以找到here