Skip to content
This repository has been archived by the owner on Jun 18, 2024. It is now read-only.

Latest commit

 

History

History
174 lines (127 loc) · 5.01 KB

README_reference.md

File metadata and controls

174 lines (127 loc) · 5.01 KB

Reference Notes

  • Random notes, hopefully helpful on occasion. Probably not helpful on first look.

Linting

  • pep8 code style
  • Can check for linter errors before submitting a pull request:
    # (some configuration in setup.cfg)
    pycodestyle

Tests

  • Examples:

    cd src
    
    # run tests (verbose mode)
    python -m unittest -v
    
    # run tests matching ...
    python -m unittest -k "test_redelegate"
    
    # run exact test
    python -m unittest tests.tests.test_osmo.TestOsmo.test_redelegate
    
    # run tests with different granularity
    python -m unittest tests.tests.test_osmo.TestOsmo
    python -m unittest tests.tests.test_osmo
    
    # run tests in file
    python -m unittest tests/tests/test_osmo.py
    
    # run special tests that require certain network/db/settings
    SPECIALTEST=1 python -m unittest
    
  • Tests located at tests/tests/test*.py

  • Note: test suite very limited at the moment. It should expand over time.

Usage as staketaxcsv module

  >>> import staketaxcsv
  >>> help(staketaxcsv.api)
  >>>
  >>> address = "<SOME_ADDRESS>"
  >>> txid = "<SOME_TXID>"
  >>>
  >>> staketaxcsv.formats()
  ['default', 'balances', 'accointing', 'bitcointax', 'coinledger', 'coinpanda', 'cointelli', 'cointracking', 'cointracker', 'cryptio', 'cryptocom', 'cryptotaxcalculator', 'cryptoworth', 'koinly', 'recap', 'taxbit', 'tokentax', 'zenledger']
  >>>
  >>> staketaxcsv.tickers()
  ['ALGO', 'ATOM', 'BLD', 'BTSG', 'DVPN', 'EVMOS', 'FET', 'HUAHUA', 'IOTX', 'JUNO', 'KUJI', 'LUNA1', 'LUNA2', 'OSMO', 'REGEN', 'SOL', 'STARS']
  >>>
  >>> # write single transaction CSV
  >>> staketaxcsv.transaction("ATOM", address, txid, "koinly")
  ...
  >>> # write koinly CSV
  >>> staketaxcsv.csv("OSMO", address, "koinly")
  ...
  >>> # write all CSVs (koinly, cointracking, etc.)
  >>> staketaxcsv.csv_all("OSMO", address)
  ...
  >>> # check address is valid
  >>> staketaxcsv.has_csv("OSMO", address)
  True
  >>>> # write true wallet balance CSV
  >>> staketaxcsv.historical_balances("OSMO", "osmo1ku03asknjnx7dse9jgujc529vwscp6n50z5wet")
  ...

Docker

Sample of using a docker container

# build the docker container
docker build --platform linux/amd64 --tag staketaxcsv .

# Run/enter/mount docker container 
docker run --platform linux/amd64 -it --volume $PWD:/staketaxcsv staketaxcsv bash

# See README.md Usage section to run script(s)
# https://github.com/hodgerpodger/staketaxcsv#usage

PYTHONPATH Issues

  • It may be necessary to edit the PYTHONPATH if you encounter import errors.
  • For example, you can add to ~/.bash_profile or ~/.bashrc (and restart shell):
    export PYTHONPATH=$PYTHONPATH:<INSERT_PATH_TO_REPO_HERE>/src`
    

Run CSV job with no transaction limit

This is a common support request. I provide some details here for those interested. Steps:

  1. Follow Install section or Docker section to install python/packages. For those familiar with docker, I recommend Docker section.
  2. Run CSV script using --limit flag
# Load environment variables from sample.env (add to ~/.bash_profile or ~/.bashrc to avoid doing every time)
set -o allexport
source sample.env
set +o allexport

# Run CSV job with custom high transaction limit
cd src
python3 staketaxcsv/report_sol.py <wallet_address> --limit 100000 --format all

Ideal Configuration

Default code was made to work out of the box. These are changes that require manual actions. They improve reliability (RPC Node settings) or speed (DB Cache) when compared to default version.

RPC Node settings

  • Default sample.env points to public RPC nodes. This generally works but sometimes better alternatives may exist (i.e. private nodes).
  • Edit/uncomment sample.env to change environment variable settings (and reload sample.env).

DB Cache

Use of a database for caching is ideal to speed up certain RPC queries (especially SOL). Here is the script usage to enable caching:

cd src

# --cache flag requires working implementation of Cache class (common/cache.py)
python3 staketaxcsv/report_osmo.py <wallet_address> --cache

To enable --cache, you must configure an aws connection for the boto3 code found in src/common/Cache.py:

Alternatively, you may implement your own Cache class (common/cache.py).

Installing python 3.9 on macOS

  • Personal method--google is probably better

    # Install brew (see https://brew.sh/)
    
    # python 3.9.9
    brew install openssl readline sqlite3 xz zlib
    brew install pyenv
    pyenv install 3.9.9
    
    # use virtualenv
    brew install virtualenv
    virtualenv -p ~/.pyenv/versions/3.9.9/bin/python3.9 env
    source env/bin/activate
    
    # install pip packages (same as README.md)
    pip3 install -r requirements.txt

Update recognized tokens for solana report to latest

cd src
python staketaxcsv/sol/tickers/gather/jupiter.py