jl777
9c428a2172
|
7 years ago | |
---|---|---|
.. | ||
DB | 7 years ago | |
SVM | 8 years ago | |
confs | 8 years ago | |
genesis | 8 years ago | |
tmp | 8 years ago | |
DEXstats.h | 7 years ago | |
LP_RTmetrics.c | 7 years ago | |
LP_bitcoin.c | 7 years ago | |
LP_cache.c | 7 years ago | |
LP_coins.c | 7 years ago | |
LP_commands.c | 7 years ago | |
LP_forwarding.c | 8 years ago | |
LP_include.h | 7 years ago | |
LP_messages.c | 8 years ago | |
LP_nativeDEX.c | 7 years ago | |
LP_network.c | 7 years ago | |
LP_ordermatch.c | 7 years ago | |
LP_peers.c | 7 years ago | |
LP_portfolio.c | 7 years ago | |
LP_prices.c | 7 years ago | |
LP_remember.c | 7 years ago | |
LP_rpc.c | 7 years ago | |
LP_scan.c | 7 years ago | |
LP_secp.c | 7 years ago | |
LP_signatures.c | 7 years ago | |
LP_socket.c | 7 years ago | |
LP_statemachine.c | 7 years ago | |
LP_stats.c | 7 years ago | |
LP_swap.c | 7 years ago | |
LP_tradebots.c | 7 years ago | |
LP_transaction.c | 7 years ago | |
LP_utxo.c | 7 years ago | |
LP_utxos.c | 7 years ago | |
LP_zeroconf.c | 7 years ago | |
Makefile | 7 years ago | |
PAX.c | 8 years ago | |
README.md | 8 years ago | |
assetchains.old | 7 years ago | |
autofill | 7 years ago | |
autoprice | 7 years ago | |
autotrade | 7 years ago | |
balance | 7 years ago | |
balance_loop | 7 years ago | |
barterDEX.c | 7 years ago | |
baserelswaps | 7 years ago | |
bestfit | 7 years ago | |
bitcoin.c | 8 years ago | |
bitcoin.h | 8 years ago | |
bitfinex.c | 8 years ago | |
bitstamp.c | 8 years ago | |
bittrex.c | 8 years ago | |
bot_buy | 7 years ago | |
bot_list | 7 years ago | |
bot_pause | 7 years ago | |
bot_resume | 7 years ago | |
bot_sell | 7 years ago | |
bot_settings | 7 years ago | |
bot_status | 7 years ago | |
bot_statuslist | 7 years ago | |
bot_stop | 7 years ago | |
btc38.c | 8 years ago | |
btce.c | 8 years ago | |
buy | 7 years ago | |
cancelorder | 7 years ago | |
checkbalance.c | 9 years ago | |
claim | 7 years ago | |
client | 7 years ago | |
client_osx | 7 years ago | |
coinbase.c | 8 years ago | |
coins | 7 years ago | |
coins.json | 7 years ago | |
coinswaps | 7 years ago | |
debug | 7 years ago | |
deletemessages | 7 years ago | |
deposit | 7 years ago | |
disable | 7 years ago | |
dividends | 7 years ago | |
electrum | 7 years ago | |
electrum.chips | 7 years ago | |
electrum.chips2 | 7 years ago | |
electrum.kmd | 7 years ago | |
electrum.kmd2 | 7 years ago | |
electrum.kmd3 | 7 years ago | |
electrums | 7 years ago | |
enable | 7 years ago | |
exchange_supports.h | 8 years ago | |
exchange_undefs.h | 8 years ago | |
fxcm.c | 8 years ago | |
getcoin | 7 years ago | |
getcoins | 7 years ago | |
getmessages | 7 years ago | |
getpeers | 7 years ago | |
getpeersIP | 7 years ago | |
getprices | 7 years ago | |
getrawtransaction | 7 years ago | |
getutxos | 7 years ago | |
goal | 7 years ago | |
goals | 7 years ago | |
guistats | 7 years ago | |
help | 7 years ago | |
huobi.c | 8 years ago | |
instaforex.c | 8 years ago | |
install | 7 years ago | |
inv | 7 years ago | |
invreset | 7 years ago | |
jumblr.c | 8 years ago | |
lakebtc.c | 8 years ago | |
listunspent | 7 years ago | |
loop | 7 years ago | |
m_js | 7 years ago | |
message | 7 years ago | |
millis | 7 years ago | |
mm.c | 7 years ago | |
mnzservers | 7 years ago | |
myprice | 7 years ago | |
myprices | 7 years ago | |
nodeinstall | 7 years ago | |
notarizations | 7 years ago | |
numutxos | 7 years ago | |
nxtae.c | 8 years ago | |
okcoin.c | 8 years ago | |
orderbook | 7 years ago | |
ordermatch | 7 years ago | |
parselog | 7 years ago | |
passphrase | 8 years ago | |
pendings | 7 years ago | |
poloniex.c | 8 years ago | |
portfolio | 7 years ago | |
pricearray | 7 years ago | |
processfiles | 7 years ago | |
profile | 7 years ago | |
pub | 7 years ago | |
pubkeystats | 7 years ago | |
quadriga.c | 8 years ago | |
recentswaps | 7 years ago | |
run | 7 years ago | |
run_osx | 7 years ago | |
secretaddresses | 7 years ago | |
sell | 7 years ago | |
sendrawtransaction | 7 years ago | |
setconfirms | 7 years ago | |
setpassphrase | 7 years ago | |
setprice | 7 years ago | |
snapshot | 7 years ago | |
snapshot_balance | 7 years ago | |
snapshot_loop | 7 years ago | |
stats.c | 7 years ago | |
statsdisp | 7 years ago | |
status | 7 years ago | |
stop | 7 years ago | |
swapstatus | 7 years ago | |
trade | 7 years ago | |
tradesarray | 7 years ago | |
truefx.c | 8 years ago | |
trust | 7 years ago | |
trusted | 7 years ago | |
unconf.c | 8 years ago | |
userpass | 7 years ago | |
withdraw | 7 years ago |
README.md
Latest Readme is at http://pad.supernet.org/barterdex-readme
DEPENDENCIES First of all you are going to need to have the komodod daemon and the assetchains running. Install dependency packages: sudo apt-get install build-essential pkg-config libc6-dev m4 g++-multilib autoconf libtool libncurses5-dev unzip git python zlib1g-dev wget bsdmainutils automake libboost-all-dev libssl-dev libprotobuf-dev protobuf-compiler libqt4-dev libqrencode-dev libdb++-dev ntp ntpdate vim software-properties-common curl libcurl4-gnutls-dev cmake clang Some Linux machines are now providing nanomsg package version 1.0. If it is available via package manager, you can install it from there. Else, you should use github repo of nanomsg and compile it yourself. For Ubuntu 14.04 you need to install it yourself cd /tmp wget https://github.com/nanomsg/nanomsg/archive/1.0.0.tar.gz -O nanomsg-1.0.0.tar.gz tar -xzvf nanomsg-1.0.0.tar.gz cd nanomsg-1.0.0 mkdir build cd build cmake .. -DCMAKE_INSTALL_PREFIX=/usr cmake --build . sudo cmake --build . --target install sudo ldconfig Or the following for 16.04 git clone https://github.com/nanomsg/nanomsg cd nanomsg cmake . make sudo make install sudo ldconfig COMPILE LP NODE To compile the BarterDEX you need to build iguana one time: cd ~ git clone https://github.com/jl777/SuperNET cd SuperNET/iguana git checkout dev ./m_LP IGUANA DAEMON STARTUP Then launch the iguana daemon by executing: ../agents/iguana & Now iguana should be running and providing port 7778 API: 127.0.0.1:7778 page in the browser will show the API testpage, but for marketmaker these functions are not used very much. it is port 7779 that is used and the marketmaker program is what provides those functions. BarterDEX EXCHANGE INSTALL cd ~/SuperNET/iguana/exchanges ./install Now, move to ~/SuperNET/iguana/dexscripts: cd ~/SuperNET/iguana/dexscripts Now in the ~/SuperNET/iguana/dexscripts directory you will have example scripts that you can change without new git updates overwriting them. These scripts will have example commands that you will need to customize to work with the coins you want to trade. Of course, if a new update to a script is made and you dont run install again then you wont have the latest versions. For example: if you want to enable the JUMBLR coin, you need to edit the enable file: nano ~SuperNET/iguana/dexscripts/enable copy the default command and paste it below but with the coin edited to JUMBLR in this case: curl --url "http://127.0.0.1:7779" --data "{"userpass":"$userpass","method":"enable","coin":"JUMBLR"}" The same will happen for any other script in the dexscripts directory. You will need to edit the scripts to include or exclude the coins you want to trade. IMPORTANT: All these scripts are expecting a userpass file, which contains the definition of the $userpass variable to authenticate API access. This avoids evil webpages that try to issue port 7779 calls to steal your money. At first you wont know the value of userpass. To find out, just run any API script. The first one will return all the required data, the "userpass" field is first and you can copy that value and put it into ~/SuperNET/iguana/dexscripts/userpass file. If you dont, all subsequent API calls will get authorization errors.The userpass variable is linked to each passphrase and that is defined in the passphrase file. Put your passphrase in that file. You can find templates for these two files in the iguana/exchanges dir. (you need to copy the edited version of these files to ~/SuperNET/iguana/dexscripts). cd ~/SuperNET/iguana/dexscripts ./enable (look for the userpass passphrase that will be generated and copy it) Now you have to paste the passphrase in both userpass and passphrase files: nano ./userpass nano ./passphrase ( paste the passphrase generated into the files where it says: “”) EXCHANGE CLIENT STARTUP Next step is to actually start the marketmaker from ~/SuperNET/iguana/dexscripts. cd ~/SuperNET/iguana/dexscripts ./client (for client mode) or ./run (for LPnode mode) Assuming you created the userpass file properly, you can now issue barterDEX api calls using all the scripts in the dexscripts dir. Please look at these scripts, they are simple curl invocations of a couple lines. Nothing scary and should be self explanatory. The help script displays all the api endpoints you should need. You can customize any of the dexscripts for your desired usage, make sure you edit them with the right coins, as if you issue a script for BTC it will do it for BTC instead of the coin you wanted. These scripts wont read your mind, they just do what is in them FUNDING SMARTADDRESS In order to start trading, you need to fund your smartaddress (as listed on the first API call return) from the getcoins API call. To see which is your smart address go to ~/SuperNET/iguana/dexscritps and execute: ./getcoins To make sure you have utxo pairs for both the bob and alice usage, it is best to send utxo in triplets of X, 1.2 X and 0.01 X. So if X is 10, send 10, 12, and 0.1 coins using sendtoaddress to your smartaddress. This means you will have to send 3 different transactions to the same address with 3 different quantities for example: If i want to fund my komodo smartaddress with 100 komodo i need to first send a tx with 100kmd then another tx with 120kmd and a third tx with only 10kmd After this, it should appear in the inventory. To see the inventory you need to execute: ./inv SETTING PRICE To set price you need to edit the ./setprice script in the dexscripts folder. This scripts contains a curl command that looks like this: curl --url "http://127.0.0.1:7779" --data "{"userpass":"$userpass","method":"setprice","base":"REVS","rel":"KMD","price":1.234}" In this command you should edit the coin (in this case is REVS) and then set the price per coin based in Komodo. In the command above we are setting a price of 1.23KMD per REVS. After you setprice (./setprice), then it will appear in orderbooks with that coin in either the base or rel.