2014-11-17 14:46:46 +00:00
|
|
|
/*
|
|
|
|
This file is part of ethereum.js.
|
|
|
|
|
|
|
|
ethereum.js is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
ethereum.js is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
|
|
along with ethereum.js. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2015-04-20 19:59:35 +00:00
|
|
|
/**
|
|
|
|
* @file contract.js
|
|
|
|
* @author Marek Kotewicz <marek@ethdev.com>
|
2014-11-17 14:46:46 +00:00
|
|
|
* @date 2014
|
|
|
|
*/
|
|
|
|
|
2015-03-08 17:18:52 +00:00
|
|
|
var web3 = require('../web3');
|
2015-04-09 21:30:18 +00:00
|
|
|
var solAbi = require('../solidity/abi');
|
2015-03-08 17:18:52 +00:00
|
|
|
var utils = require('../utils/utils');
|
2015-04-20 20:06:49 +00:00
|
|
|
var SolidityEvent = require('./event');
|
2015-04-20 16:16:15 +00:00
|
|
|
var SolidityFunction = require('./function');
|
2014-11-17 14:46:46 +00:00
|
|
|
|
2015-04-20 19:59:35 +00:00
|
|
|
var addFunctionsToContract = function (contract, desc) {
|
2015-04-20 16:16:15 +00:00
|
|
|
desc.filter(function (json) {
|
|
|
|
return json.type === 'function';
|
|
|
|
}).map(function (json) {
|
2015-04-21 17:41:57 +00:00
|
|
|
return new SolidityFunction(json, contract.address);
|
2015-04-20 16:16:15 +00:00
|
|
|
}).forEach(function (f) {
|
|
|
|
f.attachToContract(contract);
|
2014-11-17 14:46:46 +00:00
|
|
|
});
|
2015-01-29 12:32:32 +00:00
|
|
|
};
|
2015-01-22 13:37:34 +00:00
|
|
|
|
2015-04-21 17:41:57 +00:00
|
|
|
var addEventsToContract = function (contract, desc) {
|
2015-04-20 19:59:35 +00:00
|
|
|
desc.filter(function (json) {
|
|
|
|
return json.type === 'event';
|
|
|
|
}).map(function (json) {
|
2015-04-21 17:41:57 +00:00
|
|
|
return new SolidityEvent(json, contract.address);
|
2015-04-20 19:59:35 +00:00
|
|
|
}).forEach(function (e) {
|
|
|
|
e.attachToContract(contract);
|
|
|
|
});
|
2015-01-29 12:32:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method should be called when we want to call / transact some solidity method from javascript
|
|
|
|
* it returns an object which has same methods available as solidity contract description
|
|
|
|
* usage example:
|
|
|
|
*
|
|
|
|
* var abi = [{
|
|
|
|
* name: 'myMethod',
|
|
|
|
* inputs: [{ name: 'a', type: 'string' }],
|
|
|
|
* outputs: [{name: 'd', type: 'string' }]
|
|
|
|
* }]; // contract abi
|
|
|
|
*
|
2015-02-24 09:36:54 +00:00
|
|
|
* var MyContract = web3.eth.contract(abi); // creation of contract prototype
|
2015-01-29 12:32:32 +00:00
|
|
|
*
|
2015-02-24 09:36:54 +00:00
|
|
|
* var contractInstance = new MyContract('0x0123123121');
|
2015-01-29 12:32:32 +00:00
|
|
|
*
|
2015-02-24 09:36:54 +00:00
|
|
|
* contractInstance.myMethod('this is test string param for call'); // myMethod call (implicit, default)
|
|
|
|
* contractInstance.call().myMethod('this is test string param for call'); // myMethod call (explicit)
|
2015-02-24 12:00:24 +00:00
|
|
|
* contractInstance.sendTransaction().myMethod('this is test string param for transact'); // myMethod sendTransaction
|
2015-02-24 09:36:54 +00:00
|
|
|
*
|
|
|
|
* @param abi - abi json description of the contract, which is being created
|
2015-01-29 12:32:32 +00:00
|
|
|
* @returns contract object
|
|
|
|
*/
|
2015-02-24 09:36:54 +00:00
|
|
|
var contract = function (abi) {
|
|
|
|
|
|
|
|
// return prototype
|
2015-03-30 21:48:03 +00:00
|
|
|
return Contract.bind(null, abi);
|
2015-02-24 09:36:54 +00:00
|
|
|
};
|
|
|
|
|
2015-04-20 16:16:15 +00:00
|
|
|
var Contract = function (abi, options) {
|
2015-01-29 12:32:32 +00:00
|
|
|
|
2015-04-20 16:16:15 +00:00
|
|
|
this.address = '';
|
2015-04-09 21:30:18 +00:00
|
|
|
if (utils.isAddress(options)) {
|
2015-04-20 16:16:15 +00:00
|
|
|
this.address = options;
|
2015-04-20 12:38:08 +00:00
|
|
|
} else { // is an object!
|
2015-04-09 21:30:18 +00:00
|
|
|
// TODO, parse the rest of the args
|
2015-04-20 12:38:08 +00:00
|
|
|
options = options || {};
|
2015-04-09 21:30:18 +00:00
|
|
|
var args = Array.prototype.slice.call(arguments, 2);
|
|
|
|
var bytes = solAbi.formatConstructorParams(abi, args);
|
2015-04-20 12:38:08 +00:00
|
|
|
options.data += bytes;
|
2015-04-20 16:16:15 +00:00
|
|
|
this.address = web3.eth.sendTransaction(options);
|
2015-04-09 21:30:18 +00:00
|
|
|
}
|
|
|
|
|
2015-04-20 19:59:35 +00:00
|
|
|
addFunctionsToContract(this, abi);
|
2015-04-21 17:41:57 +00:00
|
|
|
addEventsToContract(this, abi);
|
2015-04-20 16:16:15 +00:00
|
|
|
};
|
2014-11-17 14:46:46 +00:00
|
|
|
|
2015-04-21 17:41:57 +00:00
|
|
|
Contract.prototype.call = function () {
|
|
|
|
console.error('contract.call is deprecated');
|
2015-04-20 19:59:35 +00:00
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
2015-04-21 17:41:57 +00:00
|
|
|
Contract.prototype.sendTransaction = function () {
|
|
|
|
console.error('contract.sendTransact is deprecated');
|
2015-04-20 19:59:35 +00:00
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
2014-11-17 14:46:46 +00:00
|
|
|
module.exports = contract;
|
2015-01-14 11:01:11 +00:00
|
|
|
|