1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | /* 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/>. */ /** * @file transfer.js * @author Marek Kotewicz <marek@ethdev.com> * @date 2015 */ var web3 = require('../web3'); var ICAP = require('./icap'); var namereg = require('./namereg'); var contract = require('./contract'); /** * Should be used to make ICAP transfer * * @method transfer * @param {String} iban number * @param {String} from (address) * @param {Value} value to be tranfered * @param {Function} callback, callback */ var transfer = function (from, iban, value, callback) { var icap = new ICAP(iban); Iif (!icap.isValid()) { throw new Error('invalid iban address'); } Iif (icap.isDirect()) { return transferToAddress(from, icap.address(), value, callback); } Eif (!callback) { var address = namereg.addr(icap.institution()); return deposit(from, address, value, icap.client()); } namereg.addr(icap.insitution(), function (err, address) { return deposit(from, address, value, icap.client(), callback); }); }; /** * Should be used to transfer funds to certain address * * @method transferToAddress * @param {String} address * @param {String} from (address) * @param {Value} value to be tranfered * @param {Function} callback, callback */ var transferToAddress = function (from, address, value, callback) { return web3.eth.sendTransaction({ address: address, from: from, value: value }, callback); }; /** * Should be used to deposit funds to generic Exchange contract (must implement deposit(bytes32) method!) * * @method deposit * @param {String} address * @param {String} from (address) * @param {Value} value to be tranfered * @param {String} client unique identifier * @param {Function} callback, callback */ var deposit = function (from, address, value, client, callback) { var abi = [{"constant":false,"inputs":[{"name":"name","type":"bytes32"}],"name":"deposit","outputs":[],"type":"function"}]; return contract(abi).at(address).deposit(client, { from: from, value: value }, callback); }; module.exports = transfer; |