Skip to content

CloudCoinConsortium/bitshares_upload

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

BITSHARES UPLOAD

Deposit

  • Send .stack file to depository
  • Send message/memo to Bitshares Wallet
  • Wallet distributes token to end user

Withdraw

  • Wallet Receives tokens
  • Message to CloudBank
  • Send .stack to end user

IP Address

[[Hidden]]

Configuration and System Dependencies

  • Ubuntu 20.04 LTS
  • ruby 2.7.1p83 (2020-03-31 revision a0c7c23c9c) [x86_64-linux]
  • Rails 5.2.4.3
  • Create directories:
    • /storage/upload
    • /storage/download

Paths

/ or /deposit - Upload Files

CloudCoin Services Reference

Print Welcome: GET https://bank.cloudcoin.global/service/print_welcome

Echo Service: GET https://bank.cloudcoin.global/service/[email protected]&pk=00000000000000000000000000000000

Deposit Service:

POST https://bank.cloudcoin.global/service/deposit_one_stack

[email protected]
stack=
{
	"cloudcoin": [
		{ 
		"nn":"1", 
		"sn":"1112240", 
		"an": ["f5a52ee881daaae548c24a8eaff7176c", "415c2375a6fa48c4661f5af8d7c95541", "73e067b7b47c1556deebdca33f9a09fb", "9b90d265d102a565a702813fa2211f54", "e3e191ca987c8010a3adc49c6fc18417",
			"baa7578e207b7cfaa0b8336d7ed4a4f8", "6d8a5c66a589532fe9e5dc3932650cfa", "1170b354e097f2d90132869631409bd3", "b7bc83e8ee7529ff9f874866b901cf15", "a37f6c4af8fbcfbc4d77880fc29ddfbc",
			"277668208e9bafd9393aebd36945a2c3", "ef50088c8218afe53ce2ecd655c2c786", "b7bbb01fbe6c3a830a17bd9a842b46c0", "737360e18596d74d784f563ca729aaea", "e054a34f2790fd3353ea26e5d92d9d2f",
			"7051afef36dc388e65e982bc853be417", "ea22cbae0394f6c6918691f2e2f2e267", "95d1278f54b5daca5898c62f267b6364", "b98560e11b7142d1addf5b9cf32898da", "e325f615f93ed682c7aadf6b2d77c17a",
			"3e8f9d74290fe31d416b90db3a0d2ab1", "c92d1656ded0a4f68e5171c8331e0aea", "7a9cee66544934965bca0c0cb582ba73", "7a55437fa98c1b10d7f47d84f9accdf0", "c3577cced2d428f205355522bc1119b6"],
		"ed":"7-2019",
		"pown":"ppppppppppppppppppppppppp",
		"aoid": []
		}

	]
}

Get Receipt Service: GET https://bank.cloudcoin.global/service/get_receipt?rn=ef50088c8218afe53ce2ecd655c2c786&[email protected]

Show Coins: GET https://bank.cloudcoin.global/service/show_coins?pk=00000000000000000000000000000000&[email protected]

How to Connet to Your Remote Server?

Deployment Instructions

git pull
bundle install --deployment --without development test
bundle exec rake assets:precompile db:migrate RAILS_ENV=production
  • Restart Services:
passenger-config restart-app $(pwd)
sudo service nginx restart

Nginx configuration file

File: /etc/nginx/sites-enabled/bitshares_upload.conf

server {
    listen 80;
    server_name sell.cloudcoin.global;

    # Tell Nginx and Passenger where your app's 'public' directory is
    root /var/www/bitshares_upload/code/public;

    # set client body size to 20M #
    client_max_body_size 20M;

    # Turn on Passenger
    passenger_enabled on;
    passenger_ruby /home/dynamic/.rvm/gems/ruby-2.5.1/wrappers/ruby;
}

Using SSL with Passenger in Production

NGINX and Passenger Debug

  • service nginx configtest
  • /usr/sbin/nginx -t

References

Steps to get on Bitshares (Depreciated)

  1. Setup your own Testnet Delayed Node
  2. Testnet Bitshares Watcher (staggered orders that will be collected from your uploads)
  3. Implement Gateway functionalities (On-Off ramp to BitShares)
  4. Once you connect on-off to the issuer of dummy cloudcoin, script can handle transfers internally your BTS testnet account is issuing tokens/transfer to users on BTS testnet doing upload of CloudCoins through your app - real cloudcoins

So, on one side - BTS testnet delayed node and watcher + script on other side - Ropsten Testnet ETH node + watcher + script

Library: link

Staging Server

Get a VPS from Digital Ocean with the config: 8 GB Memory / 160 GB Disk / Debian 8.10 x64

  • Multi-threading through Boost library for witness_node
  • witness_node keeps one thread for consensus only

Create a 50 GB Swap File:

fallocate -l 50G /swapfile

Verify that the correct amount of space was reserved:

ls -lh /swapfile

Make the file only accessible to root:

chmod 600 /swapfile

Verify the permissions change:

ls -lh /swapfile

Mark the file as swap space:

mkswap /swapfile

Enable the swap file, allowing our system to start utilizing it:

swapon /swapfile

Verify that the swap is available:

swapon --show

and

free -h

Install software

sudo apt-get update && sudo apt-get install gcc-4.9 g++-4.9 cmake make \
                     libbz2-dev libdb++-dev libdb-dev \
                     libssl-dev openssl libreadline-dev \
                     autoconf libtool git libcurl4-openssl-dev \
                     autotools-dev build-essential \
                     g++ libbz2-dev libicu-dev python-dev screen -y

Running Witness Node using screen

/bitshares/bitshares-core/programs/witness_node:$ screen -dmS cctestnet ./witness_node

$ screen -r cctestnet

References