added flosend.html

This commit is contained in:
Abhishek Sinha 2018-10-21 23:00:33 +05:30
parent d7326aad3e
commit dfb0297929
2 changed files with 3803 additions and 68 deletions

3565
supernode/flosend.html Normal file

File diff suppressed because it is too large Load Diff

View File

@ -165,6 +165,157 @@
})(); })();
} }
</script> </script>
<!-- SHA1 -->
<script type="text/javascript">
//Adding SHA1 to fix basic PKBDF2
/*
* Crypto-JS v2.5.4
* http://code.google.com/p/crypto-js/
* (c) 2009-2012 by Jeff Mott. All rights reserved.
* http://code.google.com/p/crypto-js/wiki/License
*/
(function () {
// Shortcuts
var C = Crypto,
util = C.util,
charenc = C.charenc,
UTF8 = charenc.UTF8,
Binary = charenc.Binary;
// Public API
var SHA1 = C.SHA1 = function (message, options) {
var digestbytes = util.wordsToBytes(SHA1._sha1(message));
return options && options.asBytes ? digestbytes :
options && options.asString ? Binary.bytesToString(digestbytes) :
util.bytesToHex(digestbytes);
};
// The core
SHA1._sha1 = function (message) {
// Convert to byte array
if (message.constructor == String) message = UTF8.stringToBytes(message);
/* else, assume byte array already */
var m = util.bytesToWords(message),
l = message.length * 8,
w = [],
H0 = 1732584193,
H1 = -271733879,
H2 = -1732584194,
H3 = 271733878,
H4 = -1009589776;
// Padding
m[l >> 5] |= 0x80 << (24 - l % 32);
m[((l + 64 >>> 9) << 4) + 15] = l;
for (var i = 0; i < m.length; i += 16) {
var a = H0,
b = H1,
c = H2,
d = H3,
e = H4;
for (var j = 0; j < 80; j++) {
if (j < 16) w[j] = m[i + j];
else {
var n = w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16];
w[j] = (n << 1) | (n >>> 31);
}
var t = ((H0 << 5) | (H0 >>> 27)) + H4 + (w[j] >>> 0) + (
j < 20 ? (H1 & H2 | ~H1 & H3) + 1518500249 :
j < 40 ? (H1 ^ H2 ^ H3) + 1859775393 :
j < 60 ? (H1 & H2 | H1 & H3 | H2 & H3) - 1894007588 :
(H1 ^ H2 ^ H3) - 899497514);
H4 = H3;
H3 = H2;
H2 = (H1 << 30) | (H1 >>> 2);
H1 = H0;
H0 = t;
}
H0 += a;
H1 += b;
H2 += c;
H3 += d;
H4 += e;
}
return [H0, H1, H2, H3, H4];
};
// Package private blocksize
SHA1._blocksize = 16;
SHA1._digestsize = 20;
})();
</script>
<!-- HMAC -->
<script type="text/javascript">
//Added to make PKBDF2 work
/*
* Crypto-JS v2.5.4
* http://code.google.com/p/crypto-js/
* (c) 2009-2012 by Jeff Mott. All rights reserved.
* http://code.google.com/p/crypto-js/wiki/License
*/
(function () {
// Shortcuts
var C = Crypto,
util = C.util,
charenc = C.charenc,
UTF8 = charenc.UTF8,
Binary = charenc.Binary;
C.HMAC = function (hasher, message, key, options) {
// Convert to byte arrays
if (message.constructor == String) message = UTF8.stringToBytes(message);
if (key.constructor == String) key = UTF8.stringToBytes(key);
/* else, assume byte arrays already */
// Allow arbitrary length keys
if (key.length > hasher._blocksize * 4)
key = hasher(key, {
asBytes: true
});
// XOR keys with pad constants
var okey = key.slice(0),
ikey = key.slice(0);
for (var i = 0; i < hasher._blocksize * 4; i++) {
okey[i] ^= 0x5C;
ikey[i] ^= 0x36;
}
var hmacbytes = hasher(okey.concat(hasher(ikey.concat(message), {
asBytes: true
})), {
asBytes: true
});
return options && options.asBytes ? hmacbytes :
options && options.asString ? Binary.bytesToString(hmacbytes) :
util.bytesToHex(hmacbytes);
};
})();
</script>
<script type="text/javascript"> <script type="text/javascript">
/*! /*!
* Crypto-JS v2.5.4 SHA256.js * Crypto-JS v2.5.4 SHA256.js
@ -6866,7 +7017,7 @@
dest[destPos++] = src[srcPos++]; dest[destPos++] = src[srcPos++];
dest[destPos++] = src[srcPos++]; dest[destPos++] = src[srcPos++];
} }
} }
} // scryptCore } // scryptCore
}; // window.Crypto_scrypt }; // window.Crypto_scrypt
})(); })();
@ -6877,7 +7028,7 @@
var localbitcoinplusplus = { var localbitcoinplusplus = {
wallets: {}, wallets: {},
trade: {}, trade: {},
rpc:{}, rpc: {},
rm_configs: {}, rm_configs: {},
flocha: "https://livenet.flocha.in" flocha: "https://livenet.flocha.in"
}; };
@ -6994,7 +7145,8 @@
if (checksum[0] != hex[3] || checksum[1] != hex[4] || checksum[2] != hex[5] || checksum[ if (checksum[0] != hex[3] || checksum[1] != hex[4] || checksum[2] != hex[5] || checksum[
3] != 3] !=
hex[6]) { hex[6]) {
callback(new Error(localbitcoinplusplus.translator.get("bip38alertincorrectpassphrase"))); // callback using closure callback(new Error(localbitcoinplusplus.translator.get(
"bip38alertincorrectpassphrase"))); // callback using closure
return; return;
} }
callback(tmpkey.getBitcoinPrivateKeyByteArray()); // callback using closure callback(tmpkey.getBitcoinPrivateKeyByteArray()); // callback using closure
@ -7164,7 +7316,8 @@
// address using either compressed or uncompressed public key methodology (specify which methodology is used // address using either compressed or uncompressed public key methodology (specify which methodology is used
// inside flagbyte). This is the generated Bitcoin address, call it generatedaddress. // inside flagbyte). This is the generated Bitcoin address, call it generatedaddress.
var ec = EllipticCurve.getSECCurveByName("secp256k1").getCurve(); var ec = EllipticCurve.getSECCurveByName("secp256k1").getCurve();
var generatedPoint = ec.decodePointHex(localbitcoinplusplus.publicKey.getHexFromByteArray(passpoint)); var generatedPoint = ec.decodePointHex(localbitcoinplusplus.publicKey.getHexFromByteArray(
passpoint));
var generatedBytes = generatedPoint.multiply(BigInteger.fromByteArrayUnsigned(factorB)).getEncoded( var generatedBytes = generatedPoint.multiply(BigInteger.fromByteArrayUnsigned(factorB)).getEncoded(
compressed); compressed);
var generatedAddress = (new Bitcoin.Address(Bitcoin.Util.sha256ripe160(generatedBytes))).toString(); var generatedAddress = (new Bitcoin.Address(Bitcoin.Util.sha256ripe160(generatedBytes))).toString();
@ -7207,8 +7360,9 @@
localbitcoinplusplus.publicKey = { localbitcoinplusplus.publicKey = {
isPublicKeyHexFormat: function (key) { isPublicKeyHexFormat: function (key) {
key = key.toString(); key = key.toString();
return localbitcoinplusplus.publicKey.isUncompressedPublicKeyHexFormat(key) || localbitcoinplusplus.publicKey.isCompressedPublicKeyHexFormat( return localbitcoinplusplus.publicKey.isUncompressedPublicKeyHexFormat(key) ||
key); localbitcoinplusplus.publicKey.isCompressedPublicKeyHexFormat(
key);
}, },
// 130 characters [0-9A-F] starts with 04 // 130 characters [0-9A-F] starts with 04
isUncompressedPublicKeyHexFormat: function (key) { isUncompressedPublicKeyHexFormat: function (key) {
@ -7283,7 +7437,8 @@
key.setCompressed(true); key.setCompressed(true);
var privateKeyHex = key.getBitcoinHexFormat(); var privateKeyHex = key.getBitcoinHexFormat();
var publicKeyHex = localbitcoinplusplus.publicKey.getHexFromByteArray(key.getPubPoint().getEncoded(1)) var publicKeyHex = localbitcoinplusplus.publicKey.getHexFromByteArray(key.getPubPoint().getEncoded(
1))
.toString().toUpperCase(); .toString().toUpperCase();
console.log("privateKeyHex: ", privateKeyHex); console.log("privateKeyHex: ", privateKeyHex);
@ -7325,7 +7480,7 @@
<!-- RPC Object --> <!-- RPC Object -->
<script> <script>
var Rpc = localbitcoinplusplus.rpc = function() { var Rpc = localbitcoinplusplus.rpc = function () {
this.rpc_req_id; this.rpc_req_id;
this.valid_job = ["trade_buy", "trade_sell"]; this.valid_job = ["trade_buy", "trade_sell"];
} }
@ -7395,7 +7550,7 @@
this.valid_product = ["BTC", "INR"]; this.valid_product = ["BTC", "INR"];
this.currency = null; this.currency = null;
this.valid_currencies = ["BTC", "INR"], this.valid_currencies = ["BTC", "INR"],
this.buy_price = null; this.buy_price = null;
this.buyer_public_key = null; this.buyer_public_key = null;
this.buyer_key_signature = null; this.buyer_key_signature = null;
this.order_validator_public_key = null; this.order_validator_public_key = null;
@ -7404,64 +7559,77 @@
} }
Trade.prototype = { Trade.prototype = {
get trustLevel() {return this.level;}, get trustLevel() {
return this.level;
},
set trustLevel(level) { set trustLevel(level) {
if (typeof level === "number" && level === parseInt(level, 10) && level > 0 && level < 6) { if (typeof level === "number" && level === parseInt(level, 10) && level > 0 && level < 6) {
this.level = level; this.level = level;
} }
}, },
validate_order(order_type, product, currency, buy_price, buyer_public_key, buyer_key_signature, order_validator_public_key) { validate_order(order_type, product, currency, buy_price, buyer_public_key, buyer_key_signature,
order_validator_public_key) {
if(this.valid_order_type.indexOf(order_type) >= 0) { if (this.valid_order_type.indexOf(order_type) >= 0) {
this.order_type = order_type; this.order_type = order_type;
} else { } else {
this.errors.push("Inavlid trade type value."); this.errors.push("Inavlid trade type value.");
} }
if(this.valid_product.indexOf(product)>=0) { if (this.valid_product.indexOf(product) >= 0) {
this.product = product; this.product = product;
} else { } else {
this.errors.push("Invalid product."); this.errors.push("Invalid product.");
} }
if(this.valid_currencies.indexOf(currency)>=0) { if (this.valid_currencies.indexOf(currency) >= 0) {
this.currency = currency; this.currency = currency;
} else { } else {
this.errors.push("Invalid currency."); this.errors.push("Invalid currency.");
} }
if(typeof buy_price == "number" && buy_price > 0) { if (typeof buy_price == "number" && buy_price > 0) {
this.buy_price = buy_price; this.buy_price = buy_price;
} else { } else {
this.errors.push("Invalid buying price. Please place a valid buy amount."); this.errors.push("Invalid buying price. Please place a valid buy amount.");
} }
if(buyer_public_key.length > 0) { if (buyer_public_key.length > 0) {
this.buyer_public_key = buyer_public_key; this.buyer_public_key = buyer_public_key;
} else { } else {
this.errors.push("Invalid Buyer's public key."); this.errors.push("Invalid Buyer's public key.");
} }
if(buyer_key_signature.length > 0) { if (buyer_key_signature.length > 0) {
this.buyer_key_signature = buyer_key_signature; this.buyer_key_signature = buyer_key_signature;
} else { } else {
this.errors.push("Invalid Buyer's key signature."); this.errors.push("Invalid Buyer's key signature.");
} }
if(order_validator_public_key.length > 0) { if (order_validator_public_key.length > 0) {
this.order_validator_public_key = order_validator_public_key; this.order_validator_public_key = order_validator_public_key;
} else { } else {
this.errors.push("Invalid Validator's key signature."); this.errors.push("Invalid Validator's key signature.");
} }
if(this.errors.length > 0) { if (this.errors.length > 0) {
return this.errors; return this.errors;
} }
return true; return true;
}, },
place_order(order_type, product, currency, buy_price, buyer_public_key, buyer_key_signature, order_validator_public_key) { place_order(order_type, product, currency, buy_price, buyer_public_key, buyer_key_signature,
var is_valid_order = this.validate_order(order_type, product, currency, buy_price, buyer_public_key, buyer_key_signature, order_validator_public_key); order_validator_public_key) {
if(is_valid_order === true) { var is_valid_order = this.validate_order(order_type, product, currency, buy_price, buyer_public_key,
buyer_key_signature, order_validator_public_key);
if (is_valid_order === true) {
var orderRPC = new localbitcoinplusplus.rpc(); var orderRPC = new localbitcoinplusplus.rpc();
this.rpc_job = 'trade_'+this.order_type; this.rpc_job = 'trade_' + this.order_type;
return orderRPC.send_rpc(this.rpc_job, {"order_type":this.order_type, "product":this.product, "currency":this.currency, "buy_price":this.buy_price, "buyer_public_key":this.buyer_public_key, "buyer_key_signature":this.buyer_key_signature, "order_validator_public_key":this.order_validator_public_key}); return orderRPC.send_rpc(this.rpc_job, {
} else if(is_valid_order == "object") { "order_type": this.order_type,
"product": this.product,
"currency": this.currency,
"buy_price": this.buy_price,
"buyer_public_key": this.buyer_public_key,
"buyer_key_signature": this.buyer_key_signature,
"order_validator_public_key": this.order_validator_public_key
});
} else if (is_valid_order == "object") {
var err; var err;
for(err=0; err<is_valid_order.length; err++) { for (err = 0; err < is_valid_order.length; err++) {
alert(is_valid_order[err]); alert(is_valid_order[err]);
} }
return false; return false;
@ -7476,7 +7644,9 @@
}, },
/*Parse Flo Blockchain comments*/ /*Parse Flo Blockchain comments*/
parse_flo_comments(callback) { parse_flo_comments(callback) {
if (this.floAddress == null) { return false; } if (this.floAddress == null) {
return false;
}
var request = new XMLHttpRequest(); var request = new XMLHttpRequest();
request.open('GET', `${localbitcoinplusplus.flocha}/api/txs/?address=${this.floAddress}`, true); request.open('GET', `${localbitcoinplusplus.flocha}/api/txs/?address=${this.floAddress}`, true);
@ -7719,7 +7889,7 @@
var response = evt.data; var response = evt.data;
var res_pos = response.indexOf('{'); var res_pos = response.indexOf('{');
if (res_pos>=0) { if (res_pos >= 0) {
var res = response.substr(res_pos); var res = response.substr(res_pos);
try { try {
var res_obj = JSON.parse(res); var res_obj = JSON.parse(res);
@ -7730,14 +7900,14 @@
switch (res_obj.method) { switch (res_obj.method) {
case "trade_buy": case "trade_buy":
var response_from_sever = orderRPC.receive_rpc_response(JSON.stringify(res_obj)); var response_from_sever = orderRPC.receive_rpc_response(JSON.stringify(res_obj));
//orderRPC.parse_server_rpc_response(response_from_sever); //orderRPC.parse_server_rpc_response(response_from_sever);
//doSend(response_from_sever); // send response to client //doSend(response_from_sever); // send response to client
break; break;
case "trade_sell": case "trade_sell":
var response_from_sever = orderRPC.receive_rpc_response(JSON.stringify(res_obj)); var response_from_sever = orderRPC.receive_rpc_response(JSON.stringify(res_obj));
doSend(response_from_sever); // send response to client doSend(response_from_sever); // send response to client
break; break;
default: default:
@ -7774,7 +7944,7 @@
</script> </script>
<script> <script>
(function() { (function () {
var RM_WALLET = new localbitcoinplusplus.wallets; var RM_WALLET = new localbitcoinplusplus.wallets;
var RM_TRADE = new localbitcoinplusplus.trade; var RM_TRADE = new localbitcoinplusplus.trade;
@ -7782,20 +7952,20 @@
// Test: fetch flo comment // Test: fetch flo comment
RM_TRADE.floAddress = RM_WALLET.rm_flo_addr; RM_TRADE.floAddress = RM_WALLET.rm_flo_addr;
var fetch_configs = RM_TRADE.parse_flo_comments(function(floData) { var fetch_configs = RM_TRADE.parse_flo_comments(function (floData) {
console.log(floData); console.log(floData);
}); });
// Test: Trade functionality // Test: Trade functionality
var trade_btn = document.createElement("button"); var trade_btn = document.createElement("button");
trade_btn.innerText = "Trade"; trade_btn.innerText = "Trade";
trade_btn.onclick = function() { trade_btn.onclick = function () {
var buytrade = RM_TRADE.place_order("buy", "BTC", "INR", 10000.00, "buyer_public_key", "buyer_key_signature", "order_validator_public_key"); var buytrade = RM_TRADE.place_order("buy", "BTC", "INR", 10000.00, "buyer_public_key",
"buyer_key_signature", "order_validator_public_key");
doSend(buytrade); doSend(buytrade);
} }
document.getElementById("output").appendChild(trade_btn); document.getElementById("output").appendChild(trade_btn);
})() })()
</script> </script>
<script> <script>