Currency simulator on tilde.town and other tildeboxes on tildeverse.org
Go to file
login 305ab2bd8c Fixes for tilde.guru to tcoin.cpp and ntcoin_freebsd_tildeguru
/usr/bin/whoami doesn't give the euid's username, but the uid's on FreeBSD, so did the same thing I did for tilde.institute, but for tilde.guru too and introduced a new flag for it, TILDEGURU.
2021-09-30 15:17:52 +00:00
tcoin/base Initial Commit 2018-03-06 13:42:50 +11:00
LICENSE Updated LICENSE year to 2021 2021-09-25 04:51:46 +10:00
README.md Updated README.md with the correct instructions to use ntcoin 2020-12-22 05:25:06 -05:00
npcoin Adding chmod u+x to scripts (and scrypt) 2019-09-30 10:16:52 +00:00
ntcoin Update the way pcoin_keys works to use a folder/directory instead of a single file 2021-06-30 16:18:51 +00:00
ntcoin_freebsd_tildeguru Fixes for tilde.guru to tcoin.cpp and ntcoin_freebsd_tildeguru 2021-09-30 15:17:52 +00:00
ntcoin_openbsd_tildeinstitute Update the way pcoin_keys works to use a folder/directory instead of a single file 2021-06-30 16:18:51 +00:00
pcoin.cpp Update the way pcoin_keys works to use a folder/directory instead of a single file 2021-06-30 16:18:51 +00:00
scrypt scrypt binary file's permissions were modified 2021-01-06 13:01:45 +00:00
scrypt_freebsd FreeBSD-specific compilation of scrypt was required 2021-09-25 01:52:28 +00:00
tcc tildecoin-check file included 2019-11-13 15:11:16 -07:00
tcoin.cpp Fixes for tilde.guru to tcoin.cpp and ntcoin_freebsd_tildeguru 2021-09-30 15:17:52 +00:00

README.md

tcoin

Currency simulator on tilde.town and other tildeboxes on tildeverse.org

Instructions to get started

  1. Clone the repo.
  2. Create a service user specifically for tcoin.
  3. Make sure you have bash, realpath, echo, touch, mkdir, g++, head, true, base64, and cat are available.
  4. Run ./ntcoin a b c d as the service user, where a, b, c and d are defined as follows:
    • a: the absolute path to the directory (without the trailing slash) where the tcoin folder containing all the users' data will be stored (i.e., the script will create the directory a/tcoin/)
    • b: the absolute path to the directory (without the trailing slash) where the tcoin and pcoin executables will be located, i.e., all users will have to have r-x permissions on b so that they can access the executables b/tcoin and b/pcoin. Please note that b/tcoin and b/pcoin will have the suid bit set. This means that when they run b/tcoin and b/pcoin, it will be with the uid of the service user (not their own uid). This is how they are able to send and receive coins only through the executables but not modify the a/tcoin/ themselves.
    • c: an integer number of tildecoins that every user starts with. This is stored in a/tcoin/base/base.txt, and for universal-basic-income-style inflation, one can modify a/tcoin/base/base.txt using a cronjob. This will increase everybody's coins in real time.
    • d: a host name (in quotation marks, e.g., d = "tilde.town") that will appear in tcoin --help.

Instructions to create program accounts

  1. Run b/npcoin a as the service user in the parent directory of the tcoin folder, i.e., if the tcoin folder is in directory with absolute path x, then run cd x; b/npcoin a. Here, a is the name of the program account you want to create, and b is the absolute path to the tcoin repository that contains the npcoin script. Program accounts should start with a capital letter (e.g., My_program_account or My-program-account).
  2. Add a line (ending with one newline character) to tcoin/secrets/pcoin_keys in the following format (assuming the name of the program is My_program_account): My_program_account <a 64-character random alphanumeric (either all lowercase, or mixed-case will also work) string>
  3. The string will be the key that the program uses to access and operate its account, and must be given to the requester of the program account securely (and currently, manually). I usually use random.org to generate these 64-character strings because I don't trust pseudorandom number generators (even if they are cryptographically-secure pseudorandom number generators). Anybody who can guess a key can use that program's account.
  4. Program-account creation is currently not automated because of concerns about name-squatting and similarly-named program names.