Please see the newer repo at https://github.com/NEARFoundation/transaction-tracking-app instead of this repo, which is legacy.
Transaction Tracker App (TTA) produces a report that helps teams across the ecosystem to see a simplified view of all transactions over a certain period (e.g. the Finance/Legal/Operations team uses it to reconcile their transactions and stay compliant).
Ledgers like https://explorer.near.org don't always provide a simple view of when money changes hands (i.e. NEAR tokens or fungible tokens from one NEAR account to another).
TTA allows you to specify a NEAR mainnet account ID and see a table of all transactions involding the transfer of NEAR tokens or fungible tokens into or out of that account. You can export the table as CSV.
When you specify one or more NEAR acccount IDs, those account IDs get saved to your browser's localStorage. Additionally, the server starts downloading all transactions (from the private indexer) for those account IDs and processes them and saves the data into TTA's Mongo database, which is what powers the table you see in your browser. The downloads can take a while (because the tables are huge), and a cron job keeps track of their progress.
- The frontend is a React app in the "frontend" folder.
/frontend/src/index.html
is a great place to start exploring. Note that it loads in/frontend/src/index.tsx
, where you can learn how the frontend connects to the NEAR blockchain.
- The backend is an Express app (with cron jobs and a Mongo database) in the "backend" folder.
- The backend relies on a private clone of the NEAR Explorer indexer, a large PostgreSQL database (certain tables are ~1 TB). We use our own clone of NEAR Explorer (on a bare metal Hetzner server) instead of using the public credentials of the actual NEAR Explorer because the complicated queries take too long and time out.
- There is also a folder called "shared" for code that both apps use.
- Tests use jest. You can run via
yarn test
.
To run this project locally (as an operations engineer, or a developer looking to deliver code):
- Get a Nix-based development environment (Linux, Mac, WSL).
- Get and setup Docker for your environment.
- Clone this repo and get into the project.
- run
docker-compose up
- App will be available at: http://localhost:8085/ (frontend) and http://localhost:8086/ (backend)
To run this project locally (as a developer running a fully local development environment)
-
Make sure you've installed Node.js ≥ 18.
nvm use 18
. -
Install and start Mongo using the instructions in its own section below.
-
cp frontend/.env.development frontend/.env.development.local && cp backend/.env.development backend/.env.development.local
-
Edit the values for each of those local env files. If you set REACT_APP_ALLOW_DELETING_FROM_DATABASE to "true" in
frontend/.env.development.local
and ALLOW_DELETING_FROM_DATABASE to "true" inbackend/.env.development.local
, you will see a button in the frontend that allows you to delete records from the database, which is useful when you are manually testing whether transaction processing is working after editing the SQL queries.- Similarly, if you ever want to nuke your local Mongo cache, you can run
yarn drop_actions_and_tasks_and_types
.
- Similarly, if you ever want to nuke your local Mongo cache, you can run
-
Install PostreSQL:
brew install postgresql brew services start postgresql psql postgres \du CREATE ROLE testuser WITH LOGIN PASSWORD 'secret'; ALTER ROLE testuser CREATEDB; CREATE ROLE dev WITH LOGIN PASSWORD 'public'; ALTER ROLE dev CREATEDB; \q psql postgres -U testuser CREATE DATABASE tta_test_db; GRANT ALL PRIVILEGES ON DATABASE tta_test_db TO testuser; \list \q psql postgres -U dev CREATE DATABASE local_explorer; GRANT ALL PRIVILEGES ON DATABASE local_explorer TO dev; \list \q
-
Install dependencies for frontend and backend:
yarn install_all
-
Seed the local dev database via
yarn seed
. -
(optional)
POSTGRESQL_CONNECTION_STRING=___ ./backend/test_helpers/updateTestData.sh
(where___
is the mainnet Postgres credentials string) -
yarn test
-
Start the backend:
yarn backend_dev
-
In a second terminal, start the frontend:
yarn dev
(seepackage.json
for a full list ofscripts
you can run withyarn
). TODO: Check whether https://www.npmjs.com/package/concurrently would help. -
Visit http://localhost:1234/ in the browser.
Go ahead and play with the app and the code. As you make frontend code changes, the app will automatically reload.
brew tap mongodb/brew
brew update -v
brew install [email protected]
brew services start [email protected]
brew install mongosh
mongosh
use admin
show databases
db.createUser(
{
user: "MongoTestDbUser",
pwd: "MongoTestDbSecretPhrase",
roles: [ { role: "readWrite", db: "test" } ]
}
)
db.createUser(
{
user: "MongoDbUser",
pwd: "MongoDbSecretPhrase",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
show users
exit
https://medium.com/@haxzie/getting-started-with-mongodb-setting-up-admin-and-user-accounts-4fdd33687741 was useful.
*.test.ts
files live right next to whatever file they are testing.
backend/src/helpers/updateTransactions.test.ts
contains tests about the complicated SQL queries that process each of the ~40 transaction types.
To test that updateTransactions
works correctly, first ensure that backend/test_helpers/expectedOutput.csv
contains the values that you want. (Ideally we will have more than 1 row per transaction type.)
Then run yarn update_test_data
. This command will download all of the real-world data from the mainnet indexer Postgres database into SQL files that the automated tests will use when seeing your local database (the mock indexer). (See https://stackoverflow.com/a/20909045/ for how the update_test_data script works.)
To avoid downloading terabytes of data from the remote database (private indexer), the scripts look in expectedOutput.csv
to see exactly which transaction hashes matter.
The output of updateTestData.sh
is backend/test_helpers/internal/testData.sql
, which is how tests can see the local PostgreSQL test database (mock indexer).
The inputs for backend/src/helpers/updateTransactions.test.ts
come from expectedOutput.csv
(its transaction hashes and account IDs), and of course so do the expected outputs.
Then run yarn test
to run the tests.
- Visit https://docs.google.com/spreadsheets/d/1g3yymiHP2QJqwLrJdwma8gu-J92XCbZR-DDpObmu_2o/edit#gid=726351924
- The FLO team has decided that this is the official list of transaction types.
- Sort the rows by "keep" descending, "phase" ascending, "txType" ascending.
- (We can't try to skip this step by creating a sorted "filter view" in Google Sheets because the "Download" step doesn't honor filter views.)
- For rows where "keep" === 1, search for occurrences of "E+". If any numeric values are using this kind of (exponential) notation, you need to correct the cell (write out the full number instead).
- You might need to prepend the value with a single quote (').
- File > Download > .ods (choose a temporary folder somewhere).
- (We need this extra step before CSV because Google Sheets doesn't save the double-quotes correctly.)
- Open the .ods file in LibreOffice.
- Delete the rows where "keep" is not "1".
- Delete these columns: "keep", "errors", "phase".
- File > Save As > Text CSV (.csv)
- Choose to save to
backend/test_helpers/expectedOutput.csv
- Check the boxes for "Save cell content as shown" and "Quote all text cells"